- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
假设我有一个结构Profile 和sql 表profiles。
type Profile struct {
ID int `json:"id"`
CreatedAt time.Time `json:"created_at"`
UpdatedAt time.Time `json:"updated_at"`
FirstName string `json:"first_name"`
LastName string `json:"last_name"`
Age int `json:"age"`
}
然后,我从 profiles 表中获取一条记录,分配到 Profile 结构中。
这些字段是allow null,所以我使用了sql.NullString、sql.NullInt64、pq.NullTime 在分配给结构之前检查有效值。
// ... DB.Query(...)
// ... rows.Next()
// ... rows.Scan()
// ...
if firstName.Valid {
p.FirstName = firstName.String
}
if lastName.Valid {
p.LastName = lastName.String
}
if age.Valid {
p.Age = age.Int64
}
// ...
如果我有超过 10 个表,每个表有超过 30 列,我必须一次又一次地检查所有变量。这使得代码变得丑陋,有人有任何让它变得漂亮的建议吗?
最佳答案
你根本不应该这样过牌。可空类型旨在直接在结构中使用:
type Profile struct {
ID sql.NullInt64 `json:"id"`
CreatedAt time.Time `json:"created_at"`
UpdatedAt time.Time `json:"updated_at"`
FirstName sql.NullString `json:"first_name"`
LastName sql.NullString `json:"last_name"`
Age sql.NullInt64 `json:"age"`
}
然后使用例如 product.FirstName.String()
访问这些值。没有理由检查 product.FirstName.Valid
除非你真正关心 nil
和空值之间的区别(在你的问题的例子中,你显然不我不关心这个区别)。
在某些情况下可能更合适的替代方法是只使用指针:
type Profile struct {
ID *int `json:"id"`
CreatedAt time.Time `json:"created_at"`
UpdatedAt time.Time `json:"updated_at"`
FirstName *string `json:"first_name"`
LastName *string `json:"last_name"`
Age *int `json:"age"`
}
当然,任何使用这些变量的代码都必须取消引用它们,并检查 nil
,因此这可能并不总是最理想的,具体取决于您如何使用这些值。
第三种选择,如果您从不关心 NULL
值和空值之间的区别,那就是创建您自己的类型,将它们一视同仁。示例:
type myString string
func (s *myString) Scan(src interface{}) error {
if src == nil {
return nil
}
if value, ok := src.(string); ok {
*s = value
return nil
}
return fmt.Errorf("Unsupported type for myString: %T", src)
}
关于mysql - 从 Go 中的 sql 中获取 nil 值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48416958/
在检查对象是否为 nil 时,有人使用 1: if (object == nil) { //... } 有人用 2: if (nil == object) { //... } 1和2有
func InsertApData(w http.ResponseWriter, r *http.Request) { decoder := json.NewDecoder(r.Body)
为什么 nil.to_s 返回 "",而 nil.inspect 返回 "nil"(当显然 .inspect 使用 .to_s 方法) 最佳答案 "inspect" method of the Obj
运行时间 https://play.golang.org/p/sl12vfS9vP package main import "fmt" func main() { err := run()
我可以将三元条件运算符用于 if {} else {} 语句,如下所示:a ? x : y,还是问题?回答 1 : 回答 2。 是否可以使用这种格式来检查,而不是 a 是 true 还是 false,
无法弄清楚这里出了什么问题。按照设计设置说明,用谷歌搜索我能想到的一切,仍然没有运气。 undefined method `email' for # Extracted source (around
今天写一些 rspec 时,我遇到了一些意外的行为,将日期(和时间)实例与 nil 进行比较。这是一个使用原始 ruby 的示例(没有 Rails 或其他库): user@MacBook-Work
我将数据类型的非零值分配给非可选属性,然后将其分配给可选属性,最后用所述数据实例化图像。当可选项通过 if-let 子句时,它的 block 执行,抛出错误: Fatal error: Unexpec
swift 5.1 。 考虑以下。 let x: Any? = nil let y: Any = x print("x \(x)") // x nil pri
请耐心听我解释这一点, 我正在创建一个聊天室,用户可以在其中上传照片供其他人查看。当用户点击图标时,他们可以将照片上传到我的 Firebase 数据库(这已成功完成,我已经对此进行了测试)。照片的 U
我的 xCode 5.0 目前遇到一个奇怪的问题:一个对象在控制台中似乎为 nil,但同时它可以通过代码访问。 图 1:对象似乎为零 图2:NSLog(@"%@", imgDownloader) 的输
我有一个实现协议(protocol)的类,以便添加 3 个变量。我专门设置了图像变量,调试器显示该变量存在,但是在我打印它时在代码中显示为 nil,我的 if let 语句也认为该变量为 nil。 @
这个问题在这里已经有了答案: Swift 2 ( executeFetchRequest ) : error handling (5 个答案) 关闭 7 年前。 开始在 SWIFT 中学习编码,每次
两者 (not 'nil) 和 (not nil) 求值为T,那么'nil和nil有什么区别吗?那么 ''nil 呢?如果 ''nil 的计算结果为 'nil,那么 ''nil 是否也应该计算为 ni
(if '(nil nil) 'print-true 'print-false) (if '(nil) 'print-true 'print-false) 在上面的代码
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: obj.nil? vs. obj == nil 我发现了一个问题 - == nil 和 nil 哪个更好?
此代码段抛出异常: x = nil jsoned = x.to_json puts 'x.to_json=' + jsoned.inspect puts 'back=' + JSON.parse(js
基本上我有一个对象想要传递给前端。我在后端记录了它,它不是空的,但是在前端,当我提醒它时,它变成了空。 ... presentation := &presentationStruct { Obje
我创建了一个自定义错误类型来包装错误,以便在 Golang 中更轻松地进行调试。当有错误要打印时它可以工作,但现在它会引起 panic 。 Demo type Error struct { E
写一个符合我当前问题的标题有点难..我有一个 main() 函数,它使用另一个包 (database_sql) 中的函数。该函数初始化一个全局变量 sql.DB*。初始化后,变量不为nil,但是对于其
我是一名优秀的程序员,十分优秀!