草庐IT

MySQL 双连接

全部标签

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');并

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

mysql - Go&Beego 如何从数据库中获取数据?

我尝试在Go&Beego上创建一个简单的REST服务。看不懂Beego的逻辑所有示例都包含有关如何在我需要获取所有项目时仅检索一个项目的信息。如果是API。Controller:packagecontrollersimport("api/models""github.com/astaxie/beego")typeUserControllerstruct{beego.Controller}func(u*UserController)GetAll(){users:=models.GetAllUsers()u.Data["json"]=usersu.ServeJSON()}型号:packag

mysql - Golang Mysql connectex 套接字 block

我使用“go-sql-driver/mysql”驱动程序。我有一个具有一些依赖项的产品表。所以我选择产品并获取将在子查询中创建笛卡尔产品的依赖项。通常有200个产品限制以获得更好的性能,但在极少数情况下,该限制将被删除或提高到比方说3000-5000然后我会收到以下错误:dialtcp127.0.0.1:3306:connectex:NormalerweisedarfjedeSocketadresse(Protokoll,NetzwerkadresseoderAnschluss)nurjeweilseinmalverwendetwerden.这基本上意味着:connectex:Usee

mysql - golang mysql DESCRIBE表导致driver.Value type nil错误

我第一次尝试使用golang查询MySQL数据库,但是当我运行命令gorunmain.go时出现以下错误。2017/10/2221:06:58sql:Scanerroroncolumnindex4:unsupportedScan,storingdriver.Valuetypeintotype*stringexitstatus1这是我的main.go主.gopackagemainimport("log""database/sql")import_"github.com/go-sql-driver/mysql"vardb*sql.DBvarerrerror//mainfunctiontob

mysql - Golang mysql 客户端 DB.Query 方法不重新编码 utf-8 编码的字符

我有一个mysql表,它的某些列中存储了UTF-8字符。该表是使用DEFAULTCHARSET=utf8创建的;如果我手动运行select语句,我可以看到UTF-8字符,但如果我使用golang客户端并使用DB.Query方法然后我看到字符都是乱码!此外,插入也是从golang客户端完成的。为什么插入内容很好,而读取却出现乱码?在进行查询时,我看不到任何用于设置字符集的参数。我错过了什么? 最佳答案 所以当行被插入数据库时​​,客户端字符集是latin1。默认情况下,golang客户端使用的是utf8。使用utf8再次插入所有行,现

mysql - ory/ladon 管理器与 golang - 未创建表

github.com/ory/ladon是一个用于管理基于角色的访问的库,用golang编写。它包含一个管理器,该管理器应该在数据库中保留策略并使用数据库。经理在内存中的情况下工作得很好。当我使用管理器与sql交互时,没有创建所需的表。db,err:=sqlx.Open("mysql","tx81:@tcp(127.0.0.1:3306)/policies")......err=db.Ping()iferr==nil{fmt.Printf("Databaseisup")}warden:=ladon.Ladon{Manager:manager.NewSQLManager(db,nil),

Golang Sql-MySQL - 日期/日期时间 0001 年

我正在使用go-sql-driver/mysql库从MySQL实例中提取数据,但遇到了一个问题,即任何DATE/DATETIME都没有正确扫描字段,尤其是月份和日期是正确的,但YEARYEAR和TIME始终为0001,时间始终为00:00:00。所有其他字段都被正确拉取。有问题的2个字段是date_added(DATE)和date_timestamp(DATETIME)如果有任何帮助,我将不胜感激示例:0001-01-0100:00:00+0000UTC我添加了parseTime=true连接参数也没有成功。连接字符串:mysql,err:=sql.Open("mysql","user