diff options
author | gber <guido+github.com@berhoerster.name> | 2020-05-14 14:28:04 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-05-14 23:28:04 +0900 |
commit | db4c9426f851c76327db11e1b5301e520e0e048b (patch) | |
tree | b000f81621099e2bf04d716d3d4c09c1a81ac8bd /sqlite3_test.go | |
parent | Fix #808: remove goconvey (#809) (diff) | |
download | golite-db4c9426f851c76327db11e1b5301e520e0e048b.tar.gz golite-db4c9426f851c76327db11e1b5301e520e0e048b.tar.xz |
Enable all prefixes for named parameters and allow for unused named parameters (#811)
* Allow unused named parameters
Try to bind all named parameters and ignore those not used.
* Allow "@" and "$" for named parameters
* Add tests for named parameters
Co-authored-by: Guido Berhoerster <guido+go-sqlite3@berhoerster.name>
Diffstat (limited to 'sqlite3_test.go')
-rw-r--r-- | sqlite3_test.go | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/sqlite3_test.go b/sqlite3_test.go index 4b8fe01..d5b0cea 100644 --- a/sqlite3_test.go +++ b/sqlite3_test.go @@ -1778,6 +1778,45 @@ func TestInsertNilByteSlice(t *testing.T) { } } +func TestNamedParam(t *testing.T) { + tempFilename := TempFilename(t) + defer os.Remove(tempFilename) + db, err := sql.Open("sqlite3", tempFilename) + if err != nil { + t.Fatal("Failed to open database:", err) + } + defer db.Close() + + _, err = db.Exec("drop table foo") + _, err = db.Exec("create table foo (id integer, name text, amount integer)") + if err != nil { + t.Fatal("Failed to create table:", err) + } + + _, err = db.Exec("insert into foo(id, name, amount) values(:id, @name, $amount)", + sql.Named("bar", 42), sql.Named("baz", "quux"), + sql.Named("amount", 123), sql.Named("corge", "waldo"), + sql.Named("id", 2), sql.Named("name", "grault")) + if err != nil { + t.Fatal("Failed to insert record with named parameters:", err) + } + + rows, err := db.Query("select id, name, amount from foo") + if err != nil { + t.Fatal("Failed to select records:", err) + } + defer rows.Close() + + rows.Next() + + var id, amount int + var name string + rows.Scan(&id, &name, &amount) + if id != 2 || name != "grault" || amount != 123 { + t.Errorf("Expected %d, %q, %d for fetched result, but got %d, %q, %d:", 2, "grault", 123, id, name, amount) + } +} + var customFunctionOnce sync.Once func BenchmarkCustomFunctions(b *testing.B) { |