草庐IT

实时数据库

全部标签

go - 处理模型特定操作与数据库操作

我在模型设计方面遇到了一些问题,特别是处理模型特定操作与数据库操作。我的用户模型就是一个很好的例子。在我的数据库中创建用户时,我想:验证密码是否符合标准(模型操作)创建摘要(模型操作)设置时间戳(模型操作)将电子邮件、摘要和时间戳保存到数据库(数据库操作)在测试时,我显然希望对所有4个进行一组单元测试,但是#4调用了其他3个,我不想重新测试,否则如果其中任何一个测试失败,#4可能会失败3做。我想出了为ModelActions和StoreActions创建一个单独的接口(interface),并在需要时将UserAction接口(interface)发送到存储操作,但是当我写出来时,我已

javascript - 在 HTML 页面上使用 Golang 进行实时搜索

我想运行一个search并在的文本后立即显示其结果变化。程序如何从中获取值?什么时候改变? 最佳答案 使用ajax将您的值发布到Golang。$("input").keyup(function(){txt=$("input").val();$.post("url",{suggest:txt},function(result){$("#results").html(result);});}); 关于javascript-在HTML页面上使用Golang进行实时搜索,我们在StackOver

sql-server - 如何使用 Golang 从 sql 数据库中的反馈部分保存星级

我正在尝试使用golang将网页反馈部分的星级评分存储到数据库中。在Home.html中,我有为星级评分编写的html代码。 在main.go中我编写了函数varCDSIDstringvarRatingintvarCreateDatestringvarrateintfunccreateUser(whttp.ResponseWriter,r*http.Request){//stmt,err:=db.Query("INSERTtbl_fdbackSETCDSID='DDUTTA3',CreateDate=getdate(),Rating=?")stmt:="INSERTINTOtbl_fd

unit-testing - 数据库单元测试

我希望就我正在编写的用于测试某些数据库条目的单元测试获得一些建议。如果没有找到记录,我正在测试的函数会为数据库播种。funcSeed(db*gorm.DB){vardata[]Datadb.Find(&data)iflen(data)==0{//doseeddefaultdata}}我似乎不太了解的是对iflen测试的测试。我正在使用一个测试数据库,所以我可以随时核对它,所以如果我只需要在函数上强制一个空数据库,这不是问题。该功能本身有效,我只是想确保我能做到这一点。任何建议都会很棒。谢谢! 最佳答案 这真的取决于,有很多方法可以根

mysql - 如何将值插入 decimal(65,0) 并使用 Golang 从数据库中检索它们?

我对Go比较陌生。我正在使用github.com/go-sql-driver/mysql作为我的驱动程序我有一个包含许多数据类型为decimal(65,0)的列的表。我正在尝试使用big.Int来处理我的应用程序中的这些值,这对我来说似乎是合理的。但是我找不到使用Stmt.Exec将值插入数据库的方法。它说"sql:convertingargument$2type:unsupportedtypebig.Int,astruct"此外,我也找不到将它从mysql序列化回我的Go结构的方法。 最佳答案 对SQL语句使用字符串值。转换为*b

sql-server - 如何使用 golang 导入 csv 并保存在 MSSQL 数据库中?

这是我的代码。目前,我只是阅读了CSV文件的内容。我需要使用Go语言应用程序将此CSV文件迁移到MSSQLpackagemainimport("encoding/csv""log""os")funcmain(){rows:=readOrders("Ec2Instances.csv")}funcreadOrders(namestring)[][]string{f,err:=os.Open(name)iferr!=nil{log.Fatalf("Cannotopen'%s':%s\n",name,err.Error())}deferf.Close()r:=csv.NewReader(f)r

mysql - 尝试通过 API 上传图像并将其存储在 MySQL 数据库中

所以我尝试通过API上传图像并将其存储在MySQL数据库中。我不确定如何将imageFile转换为我可以存储在我的数据库中的内容。我试图将此图像存储到此表的image列上的blob字段中:CREATETABLErunkdb.uploaded_challenge(idintNOTNULLAUTO_INCREMENT,challenge_idintNOTNULL,user_idintNOTNULL,created_atDATETIMENOTNULL,image_captionTEXT,image_pathvarchar(255),imageBLOB,scoreintDEFAULT0,pri

go - 如何安全地将我的数据库结果缓存在内存缓存中

我有返回用户的函数。我正在为我的数据库ORM使用gorm:func(dbs*DbService)GetUser(userIdstring)User{varuser=&User{}dbs.db..Find(&user)returnuser}如果我缓存结果,即用户,这是否会导致内存分配问题,因为我将用户放在引用类型的缓存中,所以它会导致变量user超出此函数的范围?更新鉴于上述功能,我想使用memcache将其更新为缓存(下面不是存储我的用户的实际代码,只是一个例子):mc.Set(&memcache.Item{Key:"foo",Value:[]byte("myvalue")})这是进程

go - 填充作为参数给出的接口(interface)类型的一部分(例如,为数据库/sql 实现 ScanAll)

我们如何实现一个函数,该函数将返回SQL查询产生的所有行并将它们转换为dest这是一个接口(interface)数组(可能无法像Scan一样工作)?我假设目标数组必须作为函数的参数给出。但是,我仍然不知道我应该如何完成实现:funcGetAll(querystring,destinterface{})error{rows,err:=s.db.Query(query)iferr!=nil{returnerr}deferrows.Close()forrows.Next(){vardestRow???/*donothaveatype.usingreflect.TypeOf(dest).Ele

mysql - 当 Golang 程序在进行数据库事务时终止,它可以回滚吗?

假设MariaDB兼容数据库(AWSAuroraRDS)具有默认设置,其中包括启用自动提交,如果Lambda函数在三秒后终止,则执行一个需要花费的事务超过五秒,例如tx,err:=h.db.Begin()iferr!=nil{log.WithError(err).Error("failedtostarttransaction")}res,execErr:=tx.Exec(fmt.Sprintf("UPDATEtesttableSETval=%dWHEREid=1;SELECTSLEEP(5.5);",time.Now().Unix()))ifexecErr!=nil{log.WithE