Golang 为什么需要用反射

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

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

Go 复制代码
package main

import (
	"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 []string
	var 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
}
相关推荐
历程里程碑5 分钟前
Linux 2 指令(2)进阶:内置与外置命令解析
linux·运维·服务器·c语言·开发语言·数据结构·ubuntu
有谁看见我的剑了?6 分钟前
使用 go get github.com/go-sql-driver/mysql 驱动失败
golang
王燕龙(大卫)9 分钟前
rust入门
开发语言·rust
无心水10 分钟前
2、Go语言源码文件组织与命令源码文件实战指南
开发语言·人工智能·后端·机器学习·golang·go·gopath
2501_9445264211 分钟前
Flutter for OpenHarmony 万能游戏库App实战 - 主题切换实现
android·开发语言·javascript·python·flutter·游戏·django
张张努力变强12 分钟前
C++ 类和对象(三):拷贝构造函数与赋值运算符重载之核心实现
开发语言·c++
福楠13 分钟前
C++ STL | set、multiset
c语言·开发语言·数据结构·c++·算法
一晌小贪欢14 分钟前
Python 健壮性进阶:精通 TCP/IP 网络编程与 requirements.txt 的最佳实践
开发语言·网络·python·网络协议·tcp/ip·python基础·python小白
enfpZZ小狗15 分钟前
基于C++的反射机制探索
开发语言·c++·算法
曹牧15 分钟前
C#:WebReference
开发语言·c#