草庐IT

MySQL非主外键

全部标签

sql - 如何推迟 Postgres 中的外键约束

我试图设置一个可延迟的外键约束,这样当我插入查找/数据透视表时直到事务结束时才检查它。但是,它在psqlshell中工作,但它在代码中不起作用。与在psqlshell中一样,我也在代码中使用begin开始事务。这是sql:createtablecampaign_r_company(campaign_iduuidnotnullreferencescampaign(id)ondeletecascadedeferrableinitiallydeferred,company_idvarchar(32)notnull,primarykey(campaign_id,company_id));代码如

mysql - Golang 连接到 docker 连接到我的 sql docker getsockopt : connection refused

我在尝试设置我的golang和docker环境时失去了理智。我正在使用dockercompose,它似乎可以很好地预订两个图像,但是当我尝试运行和执行lang操作时,我收到了一个错误。 最佳答案 yaml文件中的间距很重要,您的mysql行应与您的应用程序行对齐。你必须添加一个links:-mysql在您的app:部分下插入一行,以便它知道将两者连接起来。看这里https://github.com/gpuenteallott/golang-mysql-docker-setup/blob/master/docker-compose.y

mysql - Docker mysql 数据不反射(reflect)变化

我在尝试使用docker运行mysql时遇到了一些问题。我用这个例子https://github.com/gpuenteallott/golang-mysql-docker-setup/blob/master/docker-compose.yml这就像一个魅力。所以我可以登录续集专业主机127.0.0.1:3306。用户名,密码=gotest。工作完美。然后我想更改数据库名称并详细登录,我将docker-compose.yaml文件更改为如下所示app_database:build:context:.dockerfile:docker/db/Dockerfileports:-"3306

mysql - 去+MySql : how easy is to migrate to GKE (Google Cloud Container Engine)?

我的项目目前由独立的云提供商托管。我正在使用2个虚拟机,以及Linux:一个托管Go应用程序一个托管MySql数据库我现在想迁移到GoogleCloudPlatform。您认为迁移到GoogleCointainerEngine(GKE)而不是GoogleComputeEngine(它与我在当前提供商处使用的虚拟机模型(IaaS)相同)是否有意义?我从未使用过Kubernetes和Docker。进行迁移有多容易?我会让我的生活变得毫无意义吗?我的简单模型的配置有多难? 最佳答案 IhaveneverusedKubernetesandD

mysql - 如何测试使用数据库(mysql)的 Go 代码?

我有一个使用MySQL的gRPC服务,需要在每个测试用例后清除记录。我尝试用事务来包装每个测试用例。如果我的rpc代码中没有事务,它就可以工作,但如果有,它就会失败。并且会出现如下错误:can'tstarttransaction...sql:Transactionhasalreadybeencommittedorrolledback然后我尝试使用truncate来清除记录,但一些测试用例随机失败。我的代码是这样的(我使用gorm):funcfoo(db*gorm.DB){tx:=db.Begin()//queryandinserttx.Commit()}//Usetransaction

mysql - 使用 gorm 向 MySQL 插入既是 PrimaryKey 又是 DEFAULT 的字段

我想要一个表,其主键是一个自动生成的时间戳(我知道这通常不是最好的主意,但在我的情况下没问题)并且它有另一个字符串字段。这是我使用的数据结构:typeGlobalDefaultstruct{Timestamptime.Time`gorm:"primary_key"sql:"DEFAULT:current_timestamp"`Versionstring`sql:"notnull"`}当我将此数据结构与AutoMigrate一起使用时,我确实得到了一个以时间戳作为主键的表,我什至可以运行insertintoglobal_defaults(version)VALUES('1.5.3');并

go - 带有两个外键的中间模型 : file structure?

目标是创建一个中间模型(user_product),它有两个外键:user和product。我们能否通过外部文件(以某种方式)中的用户和产品结构来实现这一点,或者我们必须将它们与UserProduct放在同一个文件中,就像在文档中一样?此时,将它们放在外部并在UserProduct中导入它们,当然会抛出导入循环错误。结构:app/models/product.gouser.gouser_product.go问题是,如果我使用import"github.com/somehow/somehow/models"在user_product中导入product.go,显然它还导入了user_pr

go - 源结构上的外键?

我从Gorm开始并尝试对以下内容进行建模:typeMyLinkstruct{gorm.ModelTitlestringUrlstring}//groupoflinksunderasingletitletypeMyLinkSectionstruct{gorm.ModelTitlestringLinks[]MyLink}typeMyPagestruct{gorm.ModelPageUrlMyLinkArtists[]MyLinkSection}如您所见,我希望能够引用相同的结构MyLink作为来自MyPage的外键对象,但也作为一对一许多来自MyLinkSection。看来我必须在MyLi

mysql - Golang 映射多结果

varnewR[]struct{idstringeventidstringexcel_idstringuseridstringhallidstring}i:=0forrows.Next(){varid,eventid,excel_id,userid,hallidstringerr=rows.Scan(&id,&eventid,&excel_id,&userid,&hallid)//HereiswhatIwanttodonewR[i].id=idnewR[i].eventid=eventidnewR[i].excel_id=excel_idnewR[i].userid=useridnew

MySQL UPDATE 外键约束失败

对于初学者,我看过其他答案,他们解决了其他类似问题的问题,但我不明白失败的原因或如何解决,因为其他答案说“检查是否记录存在于另一个表中插入它们的正确关系,否则会出现此错误”。这与我正在尝试做的事情无关(我认为);我只想更新表中特定项目的数据,我不想更新任何关系,只更新外键ID。这是我的错误:Error1452:Cannotaddorupdateachildrow:aforeignkeyconstraintfails(app.item,CONSTRAINTitem_tax_fkFOREIGNKEY(tax_id)REFERENCEStax(id))这是我的查询(问号将被转换为值):UPD