解决go数据表查询结构体对应字段null问题(sqlx converting NULL to string is unsupported)

方法一:将结构体对应字段类型设为指针类型,一劳永逸,不用担心json序列化与反序列化问题

// User 用户结构体(对应mysql表)
type User struct {
	Id         int       `db:"id"`
	Code       *string   `db:"code"`
	NickName   string    `db:"nick_name"`
	Phone      string    `db:"phone"`
	Password   string    `db:"password"`
	CreateTime time.Time `db:"create_time"`
	Sex        int       `db:"sex"`
	Email      string    `db:"email"`
}

例如上述的Code字段,不设置为指针类型的话,查询时mysql里为null的话序列化就会出现“sqlx converting NULL to string is unsupported”,或者在设计表的时候字符串类型设计默认值为空字符串

方法二:将结构体对应字段设置为sql.NullString,另外构建一个结构体在应用使用

// User 用户结构体(对应mysql表)
type User struct {
	Id         int             `db:"id"`
	Code       sql.NullString  `db:"code"`
	NickName   sql.NullString  `db:"nick_name"`
	Phone      sql.NullString  `db:"phone"`
	Password   sql.NullString  `db:"password"`
	CreateTime format.JsonTime `db:"create_time"`
	Sex        int             `db:"sex"`
	Email      sql.NullString  `db:"email"`
}

//应用层使用
type UEntity struct {
	Id         int
	Code       string
	NickName   string
	Phone      string
	Password   string
	CreateTime format.JsonTime
	Sex        int
	Email      string
}

//数据库结构体与应用层使用的结构体转换
func copyValue(user User, uEntity UEntity) UEntity {
	uEntity.Id = user.Id
	uEntity.Code = user.Code.String
	uEntity.NickName = user.NickName.String
	uEntity.Phone = user.Phone.String
	uEntity.Password = user.Password.String
	uEntity.CreateTime = user.CreateTime
	uEntity.Email = user.Email.String
	return uEntity
}
  • 10
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Go 语言中,你可以使用第三方的 MySQL 驱动程序来连接和操作数据库。下面是一个示例代码,展示了如何使用 Go 语言查询 MySQL 数据库,并返回某一个表中一个字段状态为1的关联字段数据总和,并将结果存储到结构体中的某一个字段: ```go package main import ( "database/sql" "fmt" _ "github.com/go-sql-driver/mysql" ) type Result struct { TotalSum int } func main() { db, err := sql.Open("mysql", "username:password@tcp(hostname:port)/database") if err != nil { fmt.Println("Failed to connect to MySQL:", err) return } defer db.Close() // 构建查询语句 query := "SELECT SUM(related_column_name) as total_sum FROM table_name WHERE status = 1" // 执行查询语句 rows, err := db.Query(query) if err != nil { fmt.Println("Failed to execute query:", err) return } defer rows.Close() // 读取结果 var result Result if rows.Next() { err = rows.Scan(&result.TotalSum) if err != nil { fmt.Println("Failed to scan result:", err) return } } else { fmt.Println("No result found") } fmt.Println("Total sum:", result.TotalSum) } ``` 请将 `username`、`password`、`hostname`、`port` 和 `database` 替换为你的 MySQL 连接信息,将 `related_column_name` 替换为要计算总和的关联字段名,将 `table_name` 替换为要查询的表名。然后使用该代码连接到你的 MySQL 数据库,执行查询语句,并将结果存储到结构体 `Result` 的 `TotalSum` 字段中,最后打印输出该字段的值。 请注意,在实际应用中,你可能需要根据实际情况进行错误处理、连接池管理等其他的操作。同时,确保你已经在你的 Go 项目中导入了 `database/sql` 和 MySQL 驱动的相关包,以及正确配置了数据库连接信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值