tracking: insert basically working
This commit is contained in:
parent
4787e4ffce
commit
51401bf909
3 changed files with 37 additions and 5 deletions
|
@ -36,7 +36,7 @@ insert into {{ $tablename }} (
|
||||||
{{- end -}})
|
{{- end -}})
|
||||||
values (
|
values (
|
||||||
{{- range $j, $c := .columns -}}
|
{{- range $j, $c := .columns -}}
|
||||||
{{- if ne $j 0 -}}, {{ end }}${{ $j }}
|
{{- if ne $j 0 -}}, {{ end }}${{ add1 $j }}
|
||||||
{{- end -}})
|
{{- end -}})
|
||||||
`
|
`
|
||||||
)
|
)
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
package tracking
|
package tracking
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"encoding/json"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
lib "git.sr.ht/~cco/go-scopes"
|
lib "git.sr.ht/~cco/go-scopes"
|
||||||
|
@ -10,15 +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.Payload
|
Data lib.Data
|
||||||
Container *container
|
Container *container
|
||||||
}
|
}
|
||||||
|
|
||||||
type container struct {
|
type container struct {
|
||||||
|
tableName string
|
||||||
headFields []string
|
headFields []string
|
||||||
indexes [][]string
|
indexes [][]string
|
||||||
storage *sql.Storage
|
storage *sql.Storage
|
||||||
|
@ -26,23 +28,47 @@ type container struct {
|
||||||
|
|
||||||
func Container(db *sql.Storage) *container {
|
func Container(db *sql.Storage) *container {
|
||||||
return &container{
|
return &container{
|
||||||
|
tableName: "tracks",
|
||||||
headFields: []string{"taskId", "userName"},
|
headFields: []string{"taskId", "userName"},
|
||||||
indexes: [][]string{[]string{"taskId", "userName"}, []string{"userName"}},
|
indexes: [][]string{[]string{"taskId", "userName"}, []string{"userName"}},
|
||||||
storage: db,
|
storage: db,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func Insert(cont *container, tr Track) int64 {
|
||||||
|
var columns []string
|
||||||
|
var values []any
|
||||||
|
for _, k := range cont.headFields {
|
||||||
|
columns = append(columns, k)
|
||||||
|
values = append(values, tr.Head[k])
|
||||||
|
}
|
||||||
|
columns = append(columns, "Data")
|
||||||
|
b, _ := json.Marshal(tr.Data)
|
||||||
|
values = append(values, b)
|
||||||
|
db := cont.storage
|
||||||
|
data := map[string]interface{}{
|
||||||
|
"schema": db.Schema,
|
||||||
|
"tablename": cont.tableName,
|
||||||
|
"columns": columns,
|
||||||
|
}
|
||||||
|
sql := storage.BuildSql(SqlInsert, data)
|
||||||
|
if n, err := db.Exec(sql, values...); err == nil {
|
||||||
|
return n
|
||||||
|
}
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
func Create(cont *container) *container {
|
func Create(cont *container) *container {
|
||||||
db := cont.storage
|
db := cont.storage
|
||||||
data := map[string]interface{}{
|
data := map[string]interface{}{
|
||||||
"schema": db.Schema,
|
"schema": db.Schema,
|
||||||
"tablename": "tracks",
|
"tablename": cont.tableName,
|
||||||
"headFields": cont.headFields,
|
"headFields": cont.headFields,
|
||||||
"indexes": cont.indexes,
|
"indexes": cont.indexes,
|
||||||
"params": db.Params,
|
"params": db.Params,
|
||||||
}
|
}
|
||||||
sql := storage.BuildSql(SqlCreate, data)
|
sql := storage.BuildSql(SqlCreate, data)
|
||||||
println(sql)
|
//println(sql)
|
||||||
_, err := db.Exec(sql)
|
_, err := db.Exec(sql)
|
||||||
if err == nil {
|
if err == nil {
|
||||||
return cont
|
return cont
|
||||||
|
|
|
@ -3,6 +3,7 @@ package scopes
|
||||||
import (
|
import (
|
||||||
tbase "testing"
|
tbase "testing"
|
||||||
|
|
||||||
|
lib "git.sr.ht/~cco/go-scopes"
|
||||||
"git.sr.ht/~cco/go-scopes/common/testing"
|
"git.sr.ht/~cco/go-scopes/common/testing"
|
||||||
"git.sr.ht/~cco/go-scopes/core/message"
|
"git.sr.ht/~cco/go-scopes/core/message"
|
||||||
sql "git.sr.ht/~cco/go-scopes/storage"
|
sql "git.sr.ht/~cco/go-scopes/storage"
|
||||||
|
@ -67,6 +68,11 @@ func BaseTest(t *testing.T, cfg *sql.Cfg, db *sql.Storage) {
|
||||||
func TrackingTest(t *testing.T, cfg *sql.Cfg, db *sql.Storage) {
|
func TrackingTest(t *testing.T, cfg *sql.Cfg, db *sql.Storage) {
|
||||||
cont := tracking.Container(db)
|
cont := tracking.Container(db)
|
||||||
tracking.Create(cont)
|
tracking.Create(cont)
|
||||||
|
track := tracking.Track{
|
||||||
|
Head: map[string]string{"taskId": "t01", "userName": "john"},
|
||||||
|
Data: lib.Map{},
|
||||||
|
}
|
||||||
|
tracking.Insert(cont, track)
|
||||||
}
|
}
|
||||||
|
|
||||||
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