我尝试使用golang的本机sql apis在Golang中执行此查询。
type DB struct {
*sql.DB
}
type IUser interface {
CreateUserTable() (sql.Result, error)
}
//InitDB initializes the database
func InitDB() *DB {
db, err := sql.Open(dbDriver, dbName)
if err != nil {
log.Fatal("failed to initialize database: ",err)
}
err2 := db.Ping()
if err2 != nil {
log.Fatal(err2)
}
// var database *DB
// database.AutoMigrate(&domain.User{})
return &DB{db}
}
func (db *DB) CreateUserTable() (sql.Result, error) {
statement := "CREATE TABLE %s (%s, %s, %s, %s)"
v := []interface{}{"User", "ID int PRIMARY KEY NOT NULL", "Name varchar(100) UNIQUE", "Email varchar(100) UNIQUE", "Address varchar(100) ", "Username varchar(100) UNIQUE"}
return db.Exec(fmt.Sprintf(statement, v...))
}
当我尝试在main函数中执行上面的操作时:
func main() {
db := model.InitDB()
newFunc(db)
}
func newFunc(db model.IUser) {
r, err := db.CreateUserTable()
if err != nil {
fmt.Println("Error executing query - ", err)
}
fmt.Println(r)
}
它给了我错误:
执行查询时出错 - 接近"%":语法错误
如何解决这个问题? (我使用的是sqlite3驱动程序)
答案 0 :(得分:0)
您的代码存在问题。在CREATE TABLE中缺少一个%s参数。
将代码更新为
声明:=“CREATE TABLE%s(%s,%s,%s,%s,%s)”