DB.Exec args всегда приводит к ошибке для моего заполнителя - PullRequest
0 голосов
/ 07 мая 2018

У меня есть сценарий SQL с переменной, которую я хочу установить из Golang.

SET @foo_bar_invitation_id = ?;
SELECT @foo_bar_invitation_id;

Т.е. я хочу установить?в "foobar".Мой код:

package main

import (
        "io/ioutil"
        "log"

        "database/sql"

        _ "github.com/go-sql-driver/mysql"
)

type handler struct{ db *sql.DB }

func (h handler) runsql() (err error) {
        sqlscript, err := ioutil.ReadFile("script.sql")
        if err != nil {
                return
        }
        _, err = h.db.Exec(string(sqlscript), "foobar")
        if err != nil {
                log.Println(err)
        }
        return
}

Всегда приводит к Error 1064: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'SELECT @foo_bar_invitation_id' at line 2

Я тестирую с помощью кода, сгенерированного gotests:

import (
        "database/sql"
        "os"
        "testing"

        _ "github.com/go-sql-driver/mysql"
)

var db *sql.DB

func TestMain(m *testing.M) {
        db, _ = sql.Open("mysql", os.Getenv("DSN"))
        defer db.Close()
        os.Exit(m.Run())
}

func Test_handler_runsql(t *testing.T) {
        type fields struct {
                db *sql.DB
        }
        tests := []struct {
                name    string
                fields  fields
                wantErr bool
        }{{
                "Check ID can be set",
                fields{db: db},
                false,
        }}
        for _, tt := range tests {
                t.Run(tt.name, func(t *testing.T) {
                        h := handler{
                                db: tt.fields.db,
                        }
                        if err := h.runsql(); (err != nil) != tt.wantErr {
                                t.Errorf("handler.step2runsql() error = %v, wantErr %v", err, tt.wantErr)
                        }
                })
        }
}

Мой DSN строка подключения включает ?multiStatements=true&sql_mode=TRADITIONAL.

Надеюсь, я просто не понимаю, как DB.Exec args interpolation / placeholder работает, но мне трудно найти примеры .

1 Ответ

0 голосов
/ 07 мая 2018

Ответ состоял в том, чтобы установить для интерполяционных параметров значение true. https://github.com/go-sql-driver/mysql#interpolateparams

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...