From 3d399cd0ef89bb2ebb09b35fbad2dd5e46ac727f Mon Sep 17 00:00:00 2001 From: Liquan Pei Date: Mon, 20 Nov 2023 11:22:25 -0800 Subject: [PATCH] [ENH] Add schema migration to the go coordinator (#1365) ## Description of changes *Summarize the changes made by this PR.* - Improvements & Bug fixes - This diff adds schema migration capability to the go coordinator - New functionality - ... ## Test plan *How are these changes tested?* - [ ] Test manually by verifying the schema generated ## Documentation Changes *Are all docstrings for user-facing APIs updated if required? Do we need to make documentation changes in the [docs repository](https://github.com/chroma-core/docs)?* --- go/coordinator/atlas.hcl | 24 ++++++ go/coordinator/go.mod | 19 +++-- go/coordinator/go.sum | 38 ++++++---- .../metastore/db/dbmodel/collection.go | 10 +-- .../db/dbmodel/collection_metadata.go | 6 +- .../internal/metastore/db/dbmodel/common.go | 6 +- .../internal/metastore/db/dbmodel/database.go | 14 ++-- .../internal/metastore/db/dbmodel/segment.go | 10 +-- .../metastore/db/dbmodel/segment_metadata.go | 6 +- .../internal/metastore/db/dbmodel/tenant.go | 10 +-- go/coordinator/migrations/20231116210409.sql | 74 +++++++++++++++++++ go/coordinator/migrations/atlas.sum | 2 + 12 files changed, 170 insertions(+), 49 deletions(-) create mode 100644 go/coordinator/atlas.hcl create mode 100644 go/coordinator/migrations/20231116210409.sql create mode 100644 go/coordinator/migrations/atlas.sum diff --git a/go/coordinator/atlas.hcl b/go/coordinator/atlas.hcl new file mode 100644 index 00000000000..2883c58d65e --- /dev/null +++ b/go/coordinator/atlas.hcl @@ -0,0 +1,24 @@ +data "external_schema" "gorm" { + program = [ + "go", + "run", + "-mod=mod", + "ariga.io/atlas-provider-gorm", + "load", + "--path", "./internal/metastore/db/dbmodel", + "--dialect", "postgres", + ] +} + +env "gorm" { + src = data.external_schema.gorm.url + dev = "postgres://localhost:5432/dev?sslmode=disable" + migration { + dir = "file://migrations" + } + format { + migrate { + diff = "{{ sql . \" \" }}" + } + } +} diff --git a/go/coordinator/go.mod b/go/coordinator/go.mod index 1412079e69e..d33c6d9946b 100644 --- a/go/coordinator/go.mod +++ b/go/coordinator/go.mod @@ -3,6 +3,7 @@ module github.com/chroma/chroma-coordinator go 1.20 require ( + ariga.io/atlas-provider-gorm v0.1.1 github.com/google/uuid v1.3.1 github.com/pingcap/log v1.1.0 github.com/rs/zerolog v1.31.0 @@ -21,6 +22,7 @@ require ( ) require ( + ariga.io/atlas-go-sdk v0.1.1-0.20231001054405-7edfcfc14f1c // indirect github.com/davecgh/go-spew v1.1.1 // indirect github.com/emicklei/go-restful/v3 v3.9.0 // indirect github.com/evanphx/json-patch v4.12.0+incompatible // indirect @@ -34,8 +36,10 @@ require ( github.com/google/gnostic-models v0.6.8 // indirect github.com/google/go-cmp v0.5.9 // indirect github.com/google/gofuzz v1.2.0 // indirect - github.com/imdario/mergo v0.3.6 // indirect github.com/inconshreveable/mousetrap v1.1.0 // indirect + github.com/jackc/pgpassfile v1.0.0 // indirect + github.com/jackc/pgservicefile v0.0.0-20221227161230-091c0ba34f0a // indirect + github.com/jackc/pgx/v5 v5.3.1 // indirect github.com/jinzhu/inflection v1.0.0 // indirect github.com/jinzhu/now v1.1.5 // indirect github.com/josharian/intern v1.0.0 // indirect @@ -47,7 +51,6 @@ require ( github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect github.com/modern-go/reflect2 v1.0.2 // indirect github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822 // indirect - github.com/pingcap/errors v0.11.4 // indirect github.com/pkg/errors v0.9.1 // indirect github.com/pmezard/go-difflib v1.0.0 // indirect github.com/rogpeppe/go-internal v1.11.0 // indirect @@ -55,11 +58,12 @@ require ( github.com/spf13/pflag v1.0.5 // indirect github.com/stretchr/objx v0.5.1 // indirect go.uber.org/multierr v1.11.0 // indirect - golang.org/x/net v0.17.0 // indirect + golang.org/x/crypto v0.15.0 // indirect + golang.org/x/net v0.18.0 // indirect golang.org/x/oauth2 v0.10.0 // indirect - golang.org/x/sys v0.13.0 // indirect - golang.org/x/term v0.13.0 // indirect - golang.org/x/text v0.13.0 // indirect + golang.org/x/sys v0.14.0 // indirect + golang.org/x/term v0.14.0 // indirect + golang.org/x/text v0.14.0 // indirect golang.org/x/time v0.3.0 // indirect google.golang.org/appengine v1.6.7 // indirect google.golang.org/genproto/googleapis/rpc v0.0.0-20231016165738-49dd2c1f3d0b // indirect @@ -67,7 +71,8 @@ require ( gopkg.in/natefinch/lumberjack.v2 v2.2.1 // indirect gopkg.in/yaml.v2 v2.4.0 // indirect gopkg.in/yaml.v3 v3.0.1 // indirect - k8s.io/api v0.28.3 // indirect + gorm.io/driver/postgres v1.5.2 // indirect + k8s.io/api v0.28.3 k8s.io/klog/v2 v2.100.1 // indirect k8s.io/kube-openapi v0.0.0-20230717233707-2695361300d9 // indirect k8s.io/utils v0.0.0-20230406110748-d93618cff8a2 // indirect diff --git a/go/coordinator/go.sum b/go/coordinator/go.sum index 953031f3e8e..0d994dd99df 100644 --- a/go/coordinator/go.sum +++ b/go/coordinator/go.sum @@ -1,3 +1,7 @@ +ariga.io/atlas-go-sdk v0.1.1-0.20231001054405-7edfcfc14f1c h1:jvi4KB/7DmYYT+Wy2TFImccaBU0+dw7V8Un67NDGuio= +ariga.io/atlas-go-sdk v0.1.1-0.20231001054405-7edfcfc14f1c/go.mod h1:MLvZ9QwZx1KhI6+8XguxHPUPm0/PTTUr46S5GQAe9WI= +ariga.io/atlas-provider-gorm v0.1.1 h1:Y0VsZCQkXJRYIJxenn2BM6sW2u9SkTca5mLvJumqrgE= +ariga.io/atlas-provider-gorm v0.1.1/go.mod h1:jb8uYcN+ul8Nf7OVzi5Vd2y+SQXrI4dHYBEUCiCi/6Q= github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU= github.com/benbjohnson/clock v1.1.0/go.mod h1:J11/hYXuz8f4ySSvYwY0FKfm+ezbsZBKZxNJlLklBHA= github.com/coreos/go-systemd/v22 v22.5.0/go.mod h1:Y58oyj3AT4RCenI/lSvhwexgC+NSVTIJ3seZv2GcEnc= @@ -41,10 +45,14 @@ github.com/google/gofuzz v1.2.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/ github.com/google/pprof v0.0.0-20210720184732-4bb14d4b1be1 h1:K6RDEckDVWvDI9JAJYCmNdQXq6neHJOYx3V6jnqNEec= github.com/google/uuid v1.3.1 h1:KjJaJ9iWZ3jOFZIf1Lqf4laDRCasjl0BCmnEGxkdLb4= github.com/google/uuid v1.3.1/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= -github.com/imdario/mergo v0.3.6 h1:xTNEAn+kxVO7dTZGu0CegyqKZmoWFI0rF8UxjlB2d28= -github.com/imdario/mergo v0.3.6/go.mod h1:2EnlNZ0deacrJVfApfmtdGgDfMuh/nq6Ok1EcJh5FfA= github.com/inconshreveable/mousetrap v1.1.0 h1:wN+x4NVGpMsO7ErUn/mUI3vEoE6Jt13X2s0bqwp9tc8= github.com/inconshreveable/mousetrap v1.1.0/go.mod h1:vpF70FUmC8bwa3OWnCshd2FqLfsEA9PFc4w1p2J65bw= +github.com/jackc/pgpassfile v1.0.0 h1:/6Hmqy13Ss2zCq62VdNG8tM1wchn8zjSGOBJ6icpsIM= +github.com/jackc/pgpassfile v1.0.0/go.mod h1:CEx0iS5ambNFdcRtxPj5JhEz+xB6uRky5eyVu/W2HEg= +github.com/jackc/pgservicefile v0.0.0-20221227161230-091c0ba34f0a h1:bbPeKD0xmW/Y25WS6cokEszi5g+S0QxI/d45PkRi7Nk= +github.com/jackc/pgservicefile v0.0.0-20221227161230-091c0ba34f0a/go.mod h1:5TJZWKEWniPve33vlWYSoGYefn3gLQRzjfDlhSJ9ZKM= +github.com/jackc/pgx/v5 v5.3.1 h1:Fcr8QJ1ZeLi5zsPZqQeUZhNhxfkkKBOgJuYkJHoBOtU= +github.com/jackc/pgx/v5 v5.3.1/go.mod h1:t3JDKnCBlYIc0ewLF0Q7B8MXmoIaBOZj/ic7iHozM/8= github.com/jinzhu/inflection v1.0.0 h1:K317FqzuhWc8YvSVlFMCCUb36O/S9MCKRDI7QkRKD/E= github.com/jinzhu/inflection v1.0.0/go.mod h1:h+uFLlag+Qp1Va5pdKtLDYj+kHp5pxUVkryuEj+Srlc= github.com/jinzhu/now v1.1.5 h1:/o9tlHleP7gOFmsnYNz3RGnqzefHA47wQpKrrdTIwXQ= @@ -81,8 +89,7 @@ github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822/go.mod h1:+n7T8m github.com/onsi/ginkgo/v2 v2.9.4 h1:xR7vG4IXt5RWx6FfIjyAtsoMAtnc3C/rFXBBd2AjZwE= github.com/onsi/gomega v1.27.6 h1:ENqfyGeS5AX/rlXDd/ETokDz93u0YufY1Pgxuy/PvWE= github.com/pingcap/errors v0.11.0/go.mod h1:Oi8TUi2kEtXXLMJk9l1cGmz20kV3TaQ0usTwv5KuLY8= -github.com/pingcap/errors v0.11.4 h1:lFuQV/oaUMGcD2tqt+01ROSmJs75VG1ToEOkZIZ4nE4= -github.com/pingcap/errors v0.11.4/go.mod h1:Oi8TUi2kEtXXLMJk9l1cGmz20kV3TaQ0usTwv5KuLY8= +github.com/pingcap/errors v0.11.5-0.20210425183316-da1aaba5fb63 h1:+FZIDR/D97YOPik4N4lPDaUcLDF/EQPogxtlHB2ZZRM= github.com/pingcap/log v1.1.0 h1:ELiPxACz7vdo1qAvvaWJg1NrYFoY6gqAh/+Uo6aXdD8= github.com/pingcap/log v1.1.0/go.mod h1:DWQW5jICDR7UJh4HtxXSM20Churx4CQL0fwL/SoOSA4= github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= @@ -120,6 +127,7 @@ github.com/stretchr/testify v1.8.4/go.mod h1:sz/lmYIOXD/1dqDmKjjqLyZ2RngseejIcXl github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= github.com/yuin/goldmark v1.2.1/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= go.uber.org/atomic v1.7.0/go.mod h1:fEN4uk6kAWBTFdckzkM89CLk9XfWZrxpCo0nPH17wJc= +go.uber.org/atomic v1.9.0 h1:ECmE8Bn/WFTYwEW/bpKD3M8VtR/zQVbavAoalC1PYyE= go.uber.org/atomic v1.9.0/go.mod h1:fEN4uk6kAWBTFdckzkM89CLk9XfWZrxpCo0nPH17wJc= go.uber.org/automaxprocs v1.5.3 h1:kWazyxZUrS3Gs4qUpbwo5kEIMGe/DAvi5Z4tl2NW4j8= go.uber.org/automaxprocs v1.5.3/go.mod h1:eRbA25aqJrxAbsLO0xy5jVwPt7FQnRgjW+efnwa1WM0= @@ -135,6 +143,8 @@ go.uber.org/zap v1.26.0/go.mod h1:dtElttAiwGvoJ/vj4IwHBS/gXsEu/pZ50mUIRWuG0so= golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= +golang.org/x/crypto v0.15.0 h1:frVn1TEaCEaZcn3Tmd7Y2b5KKPaZ+I32Q2OA3kYp5TA= +golang.org/x/crypto v0.15.0/go.mod h1:4ChreQoLWfG3xLDer1WdlH5NdlQ3+mwnQq1YTKY+72g= golang.org/x/lint v0.0.0-20190930215403-16217165b5de/go.mod h1:6SW0HCj/g11FgYtHlgUYUwCkIfeOF89ocIRzGO/8vkc= golang.org/x/mod v0.2.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= golang.org/x/mod v0.3.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= @@ -144,8 +154,8 @@ golang.org/x/net v0.0.0-20190603091049-60506f45cf65/go.mod h1:HSz+uSET+XFnRR8LxR golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= golang.org/x/net v0.0.0-20200226121028-0de0cce0169b/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= golang.org/x/net v0.0.0-20201021035429-f5854403a974/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU= -golang.org/x/net v0.17.0 h1:pVaXccu2ozPjCXewfr1S7xza/zcXTity9cCdXQYSjIM= -golang.org/x/net v0.17.0/go.mod h1:NxSsAGuq816PNPmqtQdLE42eU2Fs7NoRIZrHJAlaCOE= +golang.org/x/net v0.18.0 h1:mIYleuAkSbHh0tCv7RvjL3F6ZVbLjq4+R7zbOn3Kokg= +golang.org/x/net v0.18.0/go.mod h1:/czyP5RqHAH4odGYxBJ1qz0+CE5WZ+2j1YgoEo8F2jQ= golang.org/x/oauth2 v0.10.0 h1:zHCpF2Khkwy4mMB4bv0U37YtJdTGW8jI0glAApi0Kh8= golang.org/x/oauth2 v0.10.0/go.mod h1:kTpgurOux7LqtuxjuyZa4Gj2gdezIt/jQtGnNFfypQI= golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= @@ -157,15 +167,15 @@ golang.org/x/sys v0.0.0-20200930185726-fdedc70b468f/go.mod h1:h1NjWce9XRLGQEsW7w golang.org/x/sys v0.0.0-20220811171246-fbc7d0a398ab/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.12.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= -golang.org/x/sys v0.13.0 h1:Af8nKPmuFypiUBjVoU9V20FiaFXOcuZI21p0ycVYYGE= -golang.org/x/sys v0.13.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= -golang.org/x/term v0.13.0 h1:bb+I9cTfFazGW51MZqBVmZy7+JEJMouUHTUSKVQLBek= -golang.org/x/term v0.13.0/go.mod h1:LTmsnFJwVN6bCy1rVCoS+qHT1HhALEFxKncY3WNNh4U= +golang.org/x/sys v0.14.0 h1:Vz7Qs629MkJkGyHxUlRHizWJRG2j8fbQKjELVSNhy7Q= +golang.org/x/sys v0.14.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= +golang.org/x/term v0.14.0 h1:LGK9IlZ8T9jvdy6cTdfKUCltatMFOehAQo9SRC46UQ8= +golang.org/x/term v0.14.0/go.mod h1:TySc+nGkYR6qt8km8wUhuFRTVSMIX3XPR58y2lC8vww= golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= golang.org/x/text v0.3.2/go.mod h1:bEr9sfX3Q8Zfm5fL9x+3itogRgK3+ptLWKqgva+5dAk= golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= -golang.org/x/text v0.13.0 h1:ablQoSUd0tRdKxZewP80B+BaqeKJuVhuRxj/dkrun3k= -golang.org/x/text v0.13.0/go.mod h1:TvPlkZtksWOMsz7fbANvkp4WM8x/WCo/om8BMLbz+aE= +golang.org/x/text v0.14.0 h1:ScX5w1eTa3QqT8oi6+ziP7dTV1S2+ALU0bI+0zXKWiQ= +golang.org/x/text v0.14.0/go.mod h1:18ZOQIKpY8NJVqYksKHtTdi31H5itFRjB5/qKTNYzSU= golang.org/x/time v0.3.0 h1:rg5rLMjNzMS1RkNLzCG38eapWhnYLFYXDXj2gOlr8j4= golang.org/x/time v0.3.0/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= @@ -174,7 +184,7 @@ golang.org/x/tools v0.0.0-20191108193012-7d206e10da11/go.mod h1:b+2E5dAYhXwXZwtn golang.org/x/tools v0.0.0-20191119224855-298f0cb1881e/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= golang.org/x/tools v0.0.0-20200619180055-7c47624df98f/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= golang.org/x/tools v0.0.0-20210106214847-113979e3529a/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= -golang.org/x/tools v0.8.0 h1:vSDcovVPld282ceKgDimkRSC8kpaH1dgyc9UMzlt84Y= +golang.org/x/tools v0.10.0 h1:tvDr/iQoUqNdohiYm0LmmKcBk+q86lb9EprIUFhHHGg= golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= @@ -208,6 +218,8 @@ gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA= gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= gorm.io/driver/mysql v1.5.2 h1:QC2HRskSE75wBuOxe0+iCkyJZ+RqpudsQtqkp+IMuXs= gorm.io/driver/mysql v1.5.2/go.mod h1:pQLhh1Ut/WUAySdTHwBpBv6+JKcj+ua4ZFx1QQTBzb8= +gorm.io/driver/postgres v1.5.2 h1:ytTDxxEv+MplXOfFe3Lzm7SjG09fcdb3Z/c056DTBx0= +gorm.io/driver/postgres v1.5.2/go.mod h1:fmpX0m2I1PKuR7mKZiEluwrP3hbs+ps7JIGMUBpCgl8= gorm.io/driver/sqlite v1.5.4 h1:IqXwXi8M/ZlPzH/947tn5uik3aYQslP9BVveoax0nV0= gorm.io/driver/sqlite v1.5.4/go.mod h1:qxAuCol+2r6PannQDpOP1FP6ag3mKi4esLnB/jHed+4= gorm.io/gorm v1.25.2-0.20230530020048-26663ab9bf55/go.mod h1:L4uxeKpfBml98NYqVqwAdmV1a2nBtAec/cf3fpucW/k= diff --git a/go/coordinator/internal/metastore/db/dbmodel/collection.go b/go/coordinator/internal/metastore/db/dbmodel/collection.go index c43e5ed5e8f..46f00474d4e 100644 --- a/go/coordinator/internal/metastore/db/dbmodel/collection.go +++ b/go/coordinator/internal/metastore/db/dbmodel/collection.go @@ -8,14 +8,14 @@ import ( type Collection struct { ID string `gorm:"id;primaryKey"` - Name *string `gorm:"name"` + Name *string `gorm:"name;unique"` Topic *string `gorm:"topic"` Dimension *int32 `gorm:"dimension"` DatabaseID string `gorm:"database_id"` - Ts types.Timestamp `gorm:"ts"` - IsDeleted bool `gorm:"is_deleted"` - CreatedAt time.Time `gorm:"created_at, default:CURRENT_TIMESTAMP"` - UpdatedAt time.Time `gorm:"updated_at, default:CURRENT_TIMESTAMP"` + Ts types.Timestamp `gorm:"ts;type:bigint;default:0"` + IsDeleted bool `gorm:"is_deleted;type:bool;default:false"` + CreatedAt time.Time `gorm:"created_at;type:timestamp;not null;default:current_timestamp"` + UpdatedAt time.Time `gorm:"updated_at;type:timestamp;not null;default:current_timestamp"` } func (v Collection) TableName() string { diff --git a/go/coordinator/internal/metastore/db/dbmodel/collection_metadata.go b/go/coordinator/internal/metastore/db/dbmodel/collection_metadata.go index 4a2b00edd79..29303453c5d 100644 --- a/go/coordinator/internal/metastore/db/dbmodel/collection_metadata.go +++ b/go/coordinator/internal/metastore/db/dbmodel/collection_metadata.go @@ -12,9 +12,9 @@ type CollectionMetadata struct { StrValue *string `gorm:"str_value"` IntValue *int64 `gorm:"int_value"` FloatValue *float64 `gorm:"float_value"` - Ts types.Timestamp `gorm:"ts"` - CreatedAt time.Time `gorm:"created_at"` - UpdatedAt time.Time `gorm:"updated_at"` + Ts types.Timestamp `gorm:"ts;type:bigint;default:0"` + CreatedAt time.Time `gorm:"created_at;type:timestamp;not null;default:current_timestamp"` + UpdatedAt time.Time `gorm:"updated_at;type:timestamp;not null;default:current_timestamp"` } func (v CollectionMetadata) TableName() string { diff --git a/go/coordinator/internal/metastore/db/dbmodel/common.go b/go/coordinator/internal/metastore/db/dbmodel/common.go index 799ff383d99..3ad50e2933c 100644 --- a/go/coordinator/internal/metastore/db/dbmodel/common.go +++ b/go/coordinator/internal/metastore/db/dbmodel/common.go @@ -1,6 +1,10 @@ package dbmodel -import "context" +import ( + "context" + + _ "ariga.io/atlas-provider-gorm/gormschema" +) //go:generate mockery --name=IMetaDomain type IMetaDomain interface { diff --git a/go/coordinator/internal/metastore/db/dbmodel/database.go b/go/coordinator/internal/metastore/db/dbmodel/database.go index 719addf1f3f..6cac848b423 100644 --- a/go/coordinator/internal/metastore/db/dbmodel/database.go +++ b/go/coordinator/internal/metastore/db/dbmodel/database.go @@ -7,13 +7,13 @@ import ( ) type Database struct { - ID string `db:"id;primaryKey;unique"` - Name string `db:"name;not null"` - TenantID string `db:"tenant_id"` - Ts types.Timestamp `gorm:"ts"` - IsDeleted bool `gorm:"default:false"` - CreatedAt time.Time `gorm:"created_at;default:CURRENT_TIMESTAMP"` - UpdatedAt time.Time `gorm:"created_at;default:CURRENT_TIMESTAMP"` + ID string `gorm:"id;primaryKey;unique"` + Name string `gorm:"name;type:varchar(128);not_null;uniqueIndex:idx_tenantid_name"` + TenantID string `gorm:"tenant_id;type:varchar(128);not_null;uniqueIndex:idx_tenantid_name"` + Ts types.Timestamp `gorm:"ts;type:bigint;default:0"` + IsDeleted bool `gorm:"is_deleted;type:bool;default:false"` + CreatedAt time.Time `gorm:"created_at;type:timestamp;not null;default:current_timestamp"` + UpdatedAt time.Time `gorm:"updated_at;type:timestamp;not null;default:current_timestamp"` } func (v Database) TableName() string { diff --git a/go/coordinator/internal/metastore/db/dbmodel/segment.go b/go/coordinator/internal/metastore/db/dbmodel/segment.go index 84c51f7481b..0967436e11e 100644 --- a/go/coordinator/internal/metastore/db/dbmodel/segment.go +++ b/go/coordinator/internal/metastore/db/dbmodel/segment.go @@ -8,13 +8,13 @@ import ( type Segment struct { ID string `gorm:"id;primaryKey"` - Type string `gorm:"type"` + Type string `gorm:"type;type:string;not null"` Scope string `gorm:"scope"` Topic *string `gorm:"topic"` - Ts types.Timestamp `gorm:"ts"` - IsDeleted bool `gorm:"default:false"` - CreatedAt time.Time `gorm:"created_at;default:CURRENT_TIMESTAMP"` - UpdatedAt time.Time `gorm:"created_at;default:CURRENT_TIMESTAMP"` + Ts types.Timestamp `gorm:"ts;type:bigint;default:0"` + IsDeleted bool `gorm:"is_deleted;type:bool;default:false"` + CreatedAt time.Time `gorm:"created_at;type:timestamp;not null;default:current_timestamp"` + UpdatedAt time.Time `gorm:"updated_at;type:timestamp;not null;default:current_timestamp"` CollectionID *string `gorm:"collection_id"` } diff --git a/go/coordinator/internal/metastore/db/dbmodel/segment_metadata.go b/go/coordinator/internal/metastore/db/dbmodel/segment_metadata.go index a1054b496cf..bbd11eaa39b 100644 --- a/go/coordinator/internal/metastore/db/dbmodel/segment_metadata.go +++ b/go/coordinator/internal/metastore/db/dbmodel/segment_metadata.go @@ -12,9 +12,9 @@ type SegmentMetadata struct { StrValue *string `gorm:"str_value"` IntValue *int64 `gorm:"int_value"` FloatValue *float64 `gorm:"float_value"` - Ts types.Timestamp `gorm:"ts"` - CreatedAt time.Time `gorm:"created_at"` - UpdatedAt time.Time `gorm:"updated_at"` + Ts types.Timestamp `gorm:"ts;type:bigint;default:0"` + CreatedAt time.Time `gorm:"created_at;type:timestamp;not null;default:current_timestamp"` + UpdatedAt time.Time `gorm:"updated_at;type:timestamp;not null;default:current_timestamp"` } func (SegmentMetadata) TableName() string { diff --git a/go/coordinator/internal/metastore/db/dbmodel/tenant.go b/go/coordinator/internal/metastore/db/dbmodel/tenant.go index 4d7e56de7ed..bb15ed5153e 100644 --- a/go/coordinator/internal/metastore/db/dbmodel/tenant.go +++ b/go/coordinator/internal/metastore/db/dbmodel/tenant.go @@ -7,11 +7,11 @@ import ( ) type Tenant struct { - ID string `db:"id;primaryKey"` - Ts types.Timestamp `gorm:"ts"` - IsDeleted bool `gorm:"default:false"` - CreatedAt time.Time `gorm:"created_at;default:CURRENT_TIMESTAMP"` - UpdatedAt time.Time `gorm:"created_at;default:CURRENT_TIMESTAMP"` + ID string `gorm:"id;primaryKey;unique"` + Ts types.Timestamp `gorm:"ts;type:bigint;default:0"` + IsDeleted bool `gorm:"is_deleted;type:bool;default:false"` + CreatedAt time.Time `gorm:"created_at;type:timestamp;not null;default:current_timestamp"` + UpdatedAt time.Time `gorm:"updated_at;type:timestamp;not null;default:current_timestamp"` } func (v Tenant) TableName() string { diff --git a/go/coordinator/migrations/20231116210409.sql b/go/coordinator/migrations/20231116210409.sql new file mode 100644 index 00000000000..bb9c8d8a00c --- /dev/null +++ b/go/coordinator/migrations/20231116210409.sql @@ -0,0 +1,74 @@ +-- Create "collection_metadata" table +CREATE TABLE "public"."collection_metadata" ( + "collection_id" text NOT NULL, + "key" text NOT NULL, + "str_value" text NULL, + "int_value" bigint NULL, + "float_value" numeric NULL, + "ts" bigint NULL DEFAULT 0, + "created_at" timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, + "updated_at" timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, + PRIMARY KEY ("collection_id", "key") +); +-- Create "collections" table +CREATE TABLE "public"."collections" ( + "id" text NOT NULL, + "name" text NULL, + "topic" text NULL, + "dimension" integer NULL, + "database_id" text NULL, + "ts" bigint NULL DEFAULT 0, + "is_deleted" boolean NULL DEFAULT false, + "created_at" timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, + "updated_at" timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, + PRIMARY KEY ("id") +); +-- Create index "collections_name_key" to table: "collections" +CREATE UNIQUE INDEX "collections_name_key" ON "public"."collections" ("name"); +-- Create "databases" table +CREATE TABLE "public"."databases" ( + "id" text NOT NULL, + "name" character varying(128) NULL, + "tenant_id" character varying(128) NULL, + "ts" bigint NULL DEFAULT 0, + "is_deleted" boolean NULL DEFAULT false, + "created_at" timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, + "updated_at" timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, + PRIMARY KEY ("id") +); +-- Create index "idx_tenantid_name" to table: "databases" +CREATE UNIQUE INDEX "idx_tenantid_name" ON "public"."databases" ("name", "tenant_id"); +-- Create "segment_metadata" table +CREATE TABLE "public"."segment_metadata" ( + "segment_id" text NOT NULL, + "key" text NOT NULL, + "str_value" text NULL, + "int_value" bigint NULL, + "float_value" numeric NULL, + "ts" bigint NULL DEFAULT 0, + "created_at" timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, + "updated_at" timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, + PRIMARY KEY ("segment_id", "key") +); +-- Create "segments" table +CREATE TABLE "public"."segments" ( + "id" text NOT NULL, + "type" text NOT NULL, + "scope" text NULL, + "topic" text NULL, + "ts" bigint NULL DEFAULT 0, + "is_deleted" boolean NULL DEFAULT false, + "created_at" timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, + "updated_at" timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, + "collection_id" text NULL, + PRIMARY KEY ("id") +); +-- Create "tenants" table +CREATE TABLE "public"."tenants" ( + "id" text NOT NULL, + "ts" bigint NULL DEFAULT 0, + "is_deleted" boolean NULL DEFAULT false, + "created_at" timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, + "updated_at" timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, + PRIMARY KEY ("id") +); diff --git a/go/coordinator/migrations/atlas.sum b/go/coordinator/migrations/atlas.sum new file mode 100644 index 00000000000..6c8c5c29896 --- /dev/null +++ b/go/coordinator/migrations/atlas.sum @@ -0,0 +1,2 @@ +h1:MHcyjvtflWV645hivDfK4SbWtl1cuzvEoVJgejaa2bM= +20231116210409.sql h1:vwZRvrXrUMOuDykEaheyEzsnNCpmH73x0QEefzUtf8o=