fix insert track: return trackId

This commit is contained in:
Helmut Merz 2024-03-25 22:26:16 +01:00
parent d870a695f4
commit 662868cae1
3 changed files with 29 additions and 15 deletions

View file

@ -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

View file

@ -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,

View file

@ -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) {