diff options
author | mattn <mattn.jp@gmail.com> | 2015-04-13 11:55:45 +0900 |
---|---|---|
committer | mattn <mattn.jp@gmail.com> | 2015-04-13 11:55:45 +0900 |
commit | 13671e4dd3a82253232deba28caf53061be5be85 (patch) | |
tree | 177fc5461f6bd05dc6376d4b51b9086de388f5df | |
parent | Merge pull request #188 from larsmans/optimize (diff) | |
parent | Fix NULs in text. (diff) | |
download | golite-13671e4dd3a82253232deba28caf53061be5be85.tar.gz golite-13671e4dd3a82253232deba28caf53061be5be85.tar.xz |
Merge pull request #196 from egonelbre/fix-nullstring
Fix NULs in text.
-rw-r--r-- | sqlite3.go | 4 | ||||
-rw-r--r-- | sqlite3_test.go | 39 |
2 files changed, 42 insertions, 1 deletions
@@ -624,7 +624,9 @@ func (rc *SQLiteRows) Next(dest []driver.Value) error { case C.SQLITE_TEXT: var err error var timeVal time.Time - s := C.GoString((*C.char)(unsafe.Pointer(C.sqlite3_column_text(rc.s.s, C.int(i))))) + + n := int(C.sqlite3_column_bytes(rc.s.s, C.int(i))) + s := C.GoStringN((*C.char)(unsafe.Pointer(C.sqlite3_column_text(rc.s.s, C.int(i)))), C.int(n)) switch rc.decltype[i] { case "timestamp", "datetime", "date": diff --git a/sqlite3_test.go b/sqlite3_test.go index aa86011..44e00f1 100644 --- a/sqlite3_test.go +++ b/sqlite3_test.go @@ -945,3 +945,42 @@ func TestNumberNamedParams(t *testing.T) { t.Error("Failed to db.QueryRow: not matched results") } } + +func TestStringContainingZero(t *testing.T) { + tempFilename := TempFilename() + db, err := sql.Open("sqlite3", tempFilename) + if err != nil { + t.Fatal("Failed to open database:", err) + } + defer os.Remove(tempFilename) + defer db.Close() + + _, err = db.Exec(` + create table foo (id integer, name, extra text); + `) + if err != nil { + t.Error("Failed to call db.Query:", err) + } + + const text = "foo\x00bar" + + _, err = db.Exec(`insert into foo(id, name, extra) values($1, $2, $2)`, 1, text) + if err != nil { + t.Error("Failed to call db.Exec:", err) + } + + row := db.QueryRow(`select id, extra from foo where id = $1 and extra = $2`, 1, text) + if row == nil { + t.Error("Failed to call db.QueryRow") + } + + var id int + var extra string + err = row.Scan(&id, &extra) + if err != nil { + t.Error("Failed to db.Scan:", err) + } + if id != 1 || extra != text { + t.Error("Failed to db.QueryRow: not matched results") + } +} |