sql: Ошибка сканирования индекса столбца 0, имя "": неподдерживаемое сканирование, сохранение драйвера. Тип значения int64 в тип * main.SMSBlast? - PullRequest
0 голосов
/ 15 февраля 2019

Сейчас я пытаюсь использовать api restful, где столбец SequenceID не является автоматическим повышением, потому что нарочно моя проблема с библиотечным гормом, когда я считаю это: countSequenceId: = db.Debug (). Table ("SMSBlast2"). Count (& smsblast1), результатом является sql: ошибка сканирования по индексу столбца 0, имя "": не поддерживается сканирование, сохранение драйвера. Введите тип int64 в тип * main.SMSBlast

package main

import (
    "encoding/json"
    "fmt"
    "github.com/gorilla/mux"
    "github.com/jinzhu/gorm"
    _ "github.com/jinzhu/gorm/dialects/mssql"
    "log"
    "net/http"
    "strconv"
    "time"
)

type SMSBlast struct {
    SequenceID   int `gorm:"primary_key";column:"SequenceID"`
    MobilePhone string `gorm:"column:MobilePhone"`
    Output  string  `gorm:"column:Output"`
    WillBeSentDate *time.Time `gorm:"column:WillBeSentDate"`
    SentDate *time.Time `gorm:"column:SentDate"`
    Status *string `gorm:"column:Status"`
    DtmUpd time.Time `gorm:"column:DtmUpd"`
}

func (SMSBlast) TableName() string {
    return "SMSBlast2"
}


func insertSMSBlast(w http.ResponseWriter, r *http.Request){
    fmt.Println("New Insert Created")
    db, err := gorm.Open("mssql", "sqlserver://sa:@localhost:1433?database=CONFINS")
    if err != nil{
        panic("failed to connect database")
    }
    defer db.Close()


    vars := mux.Vars(r)
    mobilephone := vars["mobilephone"]
    output := vars["output"]

    var(
        smsblast1 SMSBlast
    )
    countSequenceId := db.Debug().Raw("SELECT COUNT (*) FROM SMSBlast2").Scan(&smsblast1)
    fmt.Println(countSequenceId)
    msg, err :=  json.Marshal(countSequenceId)
    if err != nil{
        fmt.Println(err.Error())
    }



    sequenceid1,_ := strconv.Atoi(string(msg))
    fmt.Println("SequenceID : " , sequenceid1)

    smsblasts := SMSBlast{SequenceID: sequenceid1,MobilePhone: mobilephone,Output:output, DtmUpd: time.Now()}
    prindata := db.Create(&smsblasts)
    fmt.Println(prindata)
}


func handleRequests(){
    myRouter := mux.NewRouter().StrictSlash(true)
    myRouter.HandleFunc("/smsblaststest",allSMSBlasts).Methods("POST")
    myRouter.HandleFunc("/smsblaststestInsert/{mobilephone}/{output}", insertSMSBlast).Methods("POST")
    log.Fatal(http.ListenAndServe(":8080",myRouter))

}

func main(){
    fmt.Println("SMSBLASTS ORM")
    handleRequests()
}

1 Ответ

0 голосов
/ 17 февраля 2019

Вы, похоже, предполагаете, что методы Гормона вернут вам результат.Это не так, как это работает.Gorm возвращает ошибку или ноль, и вы передаете ссылку на переменную, где вы хотите сохранить результаты.Таким образом, чтобы использовать Count () для чего-то, вы должны написать что-то вроде

var count int
db.Model(&SMSBlast{}).Count(&count)
fmt.Printf("count: %d\n", count)

Тем не менее, если вы просто хотите убедиться, что вы получаете новый идентификатор последовательности каждый раз, почему бы вам не использовать автоприращение?

type SMSBlast struct {
    SequenceID   int `gorm:"primary_key";column:"SequenceID";"AUTO_INCREMENT"`
    ... 
}
...