第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

SQLite 行通過 shell 返回,但不在 Go 中

SQLite 行通過 shell 返回,但不在 Go 中

Go
米琪卡哇伊 2022-06-13 16:39:10
我有一個 SQLite 查詢,它在 shell 中返回預(yù)期的結(jié)果。但是,當我在 Go 程序中運行相同的查詢時,不會掃描任何值。這是我的查詢:sqlite> select html, text from messages where id="17128ab240e7526e";|Hey there在這種情況下,htmlisNULL并且text具有字符串"Hey there"。該表具有其他列和索引。這是我等效的 Go 代碼:package mainimport (    "database/sql"    "log"    _ "github.com/mattn/go-sqlite3")func main() {    filename := "emails.db"    conn, err := sql.Open("sqlite3", filename)    if err != nil {        log.Fatal(err)    }    row, err := conn.Query("select html, text from messages where id = ?", "17128ab240e7526e")    defer row.Close()    if err != nil {        log.Fatal(err)    }    hasRow := row.Next()    log.Println("Has row:", hasRow)    var html, text string    row.Scan(&html, &text)    log.Println("HTML:", html)    log.Println("TEXT:", text)}輸出是:$ go run main.go2020/07/05 21:10:14 Has row: true2020/07/05 21:10:14 HTML: 2020/07/05 21:10:14 TEXT: 有趣的是,這只發(fā)生在該列為html空時。如果html不為空,則無論text該列的值是否為空,都按預(yù)期返回數(shù)據(jù)。什么可以解釋這種行為?
查看完整描述

1 回答

?
慕的地10843

TA貢獻1785條經(jīng)驗 獲得超8個贊

根據(jù)評論,我修改了使用的程序COALESCE并且工作正常。


關(guān)鍵是:不能scan NULL直接轉(zhuǎn)成字符串,Coalesce可以通過Query中的函數(shù)來克服這個問題。


row, err := conn.Query("select coalesce(html,'is-null'),text from messages where id =?", "17128ab240e7526e")

defer row.Close()

輸出:


arun@debian:stackoverflow$ go run main.go

2020/07/06 10:08:08 Has row: true

HTML: is-null

TEXT: Hey there


查看完整回答
反對 回復(fù) 2022-06-13
  • 1 回答
  • 0 關(guān)注
  • 129 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號