0
0
mirror of https://gitlab.com/cznic/sqlite.git synced 2025-05-17 23:26:41 +00:00
Files
go-sqlite/sqlite_go18_test.go

50 lines
972 B
Go
Raw Permalink Normal View History

2017-05-01 23:49:25 +03:00
// Copyright 2017 The Sqlite Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
//go:build go1.8
2019-12-18 17:51:11 +01:00
// +build go1.8
2017-05-01 23:49:25 +03:00
2018-11-06 18:03:25 +01:00
package sqlite // import "modernc.org/sqlite"
2017-05-01 23:49:25 +03:00
import (
"database/sql"
2024-07-10 14:14:25 +02:00
"os"
2017-05-01 23:49:25 +03:00
"reflect"
"testing"
)
func TestNamedParameters(t *testing.T) {
2024-07-10 14:14:25 +02:00
dir, db := tempDB(t)
2017-05-01 23:49:25 +03:00
defer func() {
db.Close()
2024-07-10 14:14:25 +02:00
os.RemoveAll(dir)
2017-05-01 23:49:25 +03:00
}()
_, err := db.Exec(`
create table t(s1 varchar(32), s2 varchar(32), s3 varchar(32), s4 varchar(32));
insert into t values(?, @aa, $aa, @bb);
`, "1", sql.Named("aa", "one"), sql.Named("bb", "two"))
if err != nil {
t.Fatal(err)
}
rows, err := db.Query("select * from t")
if err != nil {
t.Fatal(err)
}
rec := make([]string, 4)
for rows.Next() {
if err := rows.Scan(&rec[0], &rec[1], &rec[2], &rec[3]); err != nil {
t.Fatal(err)
}
}
w := []string{"1", "one", "one", "two"}
if !reflect.DeepEqual(rec, w) {
t.Fatal(rec, w)
}
}