fix insert track: return trackId
This commit is contained in:
parent
d870a695f4
commit
662868cae1
3 changed files with 29 additions and 15 deletions
|
@ -38,7 +38,7 @@ insert into {{ $tablename }} (
|
||||||
{{- range $j, $c := .columns -}}
|
{{- range $j, $c := .columns -}}
|
||||||
{{- if ne $j 0 -}}, {{ end }}${{ add1 $j }}
|
{{- if ne $j 0 -}}, {{ end }}${{ add1 $j }}
|
||||||
{{- end -}})
|
{{- end -}})
|
||||||
`
|
returning trackid`
|
||||||
)
|
)
|
||||||
|
|
||||||
var SqlCreate, SqlInsert *template.Template
|
var SqlCreate, SqlInsert *template.Template
|
||||||
|
|
|
@ -11,12 +11,16 @@ import (
|
||||||
sql "git.sr.ht/~cco/go-scopes/storage"
|
sql "git.sr.ht/~cco/go-scopes/storage"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Track struct {
|
type track struct {
|
||||||
TrackId uint
|
trackId uint
|
||||||
Head map[string]string
|
head map[string]string
|
||||||
TimeStamp *time.Time
|
timeStamp *time.Time
|
||||||
Data lib.Data
|
data lib.Data
|
||||||
Container *container
|
container *container
|
||||||
|
}
|
||||||
|
|
||||||
|
func (tr *track) TrackId() uint {
|
||||||
|
return tr.trackId
|
||||||
}
|
}
|
||||||
|
|
||||||
type container struct {
|
type container struct {
|
||||||
|
@ -26,7 +30,14 @@ type container struct {
|
||||||
storage *sql.Storage
|
storage *sql.Storage
|
||||||
}
|
}
|
||||||
|
|
||||||
func Container(db *sql.Storage) *container {
|
func SimpleTrack(taskId, userName string, data lib.Map) track {
|
||||||
|
return track{
|
||||||
|
head: map[string]string{"taskId": taskId, "userName": userName},
|
||||||
|
data: data,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func SimpleContainer(db *sql.Storage) *container {
|
||||||
return &container{
|
return &container{
|
||||||
tableName: "tracks",
|
tableName: "tracks",
|
||||||
headFields: []string{"taskId", "userName"},
|
headFields: []string{"taskId", "userName"},
|
||||||
|
@ -35,15 +46,15 @@ func Container(db *sql.Storage) *container {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func Insert(cont *container, tr Track) int64 {
|
func (cont *container) Insert(tr *track) uint {
|
||||||
var columns []string
|
var columns []string
|
||||||
var values []any
|
var values []any
|
||||||
for _, k := range cont.headFields {
|
for _, k := range cont.headFields {
|
||||||
columns = append(columns, k)
|
columns = append(columns, k)
|
||||||
values = append(values, tr.Head[k])
|
values = append(values, tr.head[k])
|
||||||
}
|
}
|
||||||
columns = append(columns, "Data")
|
columns = append(columns, "Data")
|
||||||
b, _ := json.Marshal(tr.Data)
|
b, _ := json.Marshal(tr.data)
|
||||||
values = append(values, b)
|
values = append(values, b)
|
||||||
db := cont.storage
|
db := cont.storage
|
||||||
data := map[string]interface{}{
|
data := map[string]interface{}{
|
||||||
|
@ -52,13 +63,16 @@ func Insert(cont *container, tr Track) int64 {
|
||||||
"columns": columns,
|
"columns": columns,
|
||||||
}
|
}
|
||||||
sql := storage.BuildSql(SqlInsert, data)
|
sql := storage.BuildSql(SqlInsert, data)
|
||||||
if n, err := db.Exec(sql, values...); err == nil {
|
if res := storage.QueryCol[uint](db, sql, values...); res != nil {
|
||||||
return n
|
trid := res[0]
|
||||||
|
tr.trackId = trid
|
||||||
|
tr.container = cont
|
||||||
|
return trid
|
||||||
}
|
}
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
|
|
||||||
func Create(cont *container) *container {
|
func (cont *container) CreateTable() *container {
|
||||||
db := cont.storage
|
db := cont.storage
|
||||||
data := map[string]interface{}{
|
data := map[string]interface{}{
|
||||||
"schema": db.Schema,
|
"schema": db.Schema,
|
||||||
|
|
|
@ -70,7 +70,7 @@ func TrackingTest(t *testing.T, cfg *sql.Cfg, db *sql.Storage) {
|
||||||
cont.CreateTable()
|
cont.CreateTable()
|
||||||
track := tracking.SimpleTrack("t01", "john", lib.Map{})
|
track := tracking.SimpleTrack("t01", "john", lib.Map{})
|
||||||
cont.Insert(&track)
|
cont.Insert(&track)
|
||||||
t.AssertEqual(track.TrackId, uint(1))
|
t.AssertEqual(track.TrackId(), uint(1))
|
||||||
}
|
}
|
||||||
|
|
||||||
func MessageTest(t *testing.T, cfg *sql.Cfg, db *sql.Storage) {
|
func MessageTest(t *testing.T, cfg *sql.Cfg, db *sql.Storage) {
|
||||||
|
|
Loading…
Add table
Reference in a new issue