当前位置: 首页 > news >正文

Golang 为什么需要用反射

本质上是可以动态获取程序运行时的变量(类型)

比如现在我想实现一个通用的db插入函数,支持我传入所有类型的struct,每一种类型的struct是一个单独的表,以struct的名称作为表名,然后插入到不同的表中。

package mainimport ("database/sql""fmt""reflect"_ "github.com/go-sql-driver/mysql" // MySQL driver
)// User 示例用户结构体
type User struct {ID    int    `db:"id"`Name  string `db:"name"`Email string `db:"email"`
}func main() {db, err := sql.Open("mysql", "user:password@tcp(localhost:3306)/dbname")if err != nil {panic(err)}defer db.Close()// 用户提供的任意结构体实例user := User{Name:  "Alice",Email: "alice@example.com",}// 使用反射保存用户实例save(db, user)
}// save 通用保存函数,接受任何结构体实例作为参数
func save(db *sql.DB, model interface{}) error {// 获取结构体实例的反射值和类型val := reflect.ValueOf(model).Elem()typ := val.Type()// 构建INSERT SQL语句var columns []stringvar values []interface{}for i := 0; i < typ.NumField(); i++ {field := typ.Field(i)columns = append(columns, field.Tag.Get("db"))values = append(values, val.Field(i).Interface())}query := fmt.Sprintf("INSERT INTO %s (%s) VALUES (%s)",typ.Name(), // 使用结构体名作为表名strings.Join(columns, ", "),strings.Repeat("?, ", len(columns)-1)+"?") // 参数占位符// 执行SQL语句result, err := db.Exec(query, values...)if err != nil {return err}// 返回受影响行数或其他信息affected, err := result.RowsAffected()if err != nil {return err}fmt.Printf("Saved %d rows.\n", affected)return nil
}

http://www.lryc.cn/news/336610.html

相关文章:

  • 【Linux的进程篇章 - 进程终止和进程等待的理解】
  • 《策略模式(极简c++)》
  • Python向文件里写入数据
  • 【网站项目】校园订餐小程序
  • vue-指令v-for
  • Python项目1 外星人入侵_外星人
  • 导入项目运行后,报错java: Cannot find JDK ‘XX‘ for module ‘XX‘
  • JS rgb,hex颜色值转换
  • Linux| Awk 中“next”命令奇用
  • 基于Springboot的箱包存储系统(有报告)。Javaee项目,springboot项目。
  • JavaScript_语法--变量
  • P1843 奶牛晒衣服
  • 功能强大:JMeter 常用插件全解析
  • vulhub之fastjson篇-1.2.27-rce
  • 基于springboot实现教师工作量管理系统项目【项目源码+论文说明】计算机毕业设计
  • [StartingPoint][Tier1]Crocodile
  • 【Qt】:常用控件(四:显示类控件)
  • gradio简单搭建——关键词简单筛选【2024-4-11优化】
  • docker完美安装分布式任务调度平台XXL-JOB
  • java使用while循环输出2-100的所有素数
  • VSCode中调试C++程序
  • Can Transformer and GNN Help Each Other?
  • 在隐私计算应用中和数链具备哪些技术特点?
  • 【智能家居入门4】(FreeRTOS、MQTT服务器、MQTT协议、微信小程序)
  • 爬取豆瓣(线程、Session)优化版本
  • 拷贝控制总结
  • 无重复字符串的最长子串
  • javaScript Object.hasOwn()的用法
  • MINI2440 开发板 给他干出来了
  • 上海人工智能实验室的书生·浦语大模型学习笔记(第二期第三课——上篇)