草庐IT

SQL之插入

全部标签

go - 使用 go sql 时,在每种类型中重写 Scan 和 Value 方法时避免重复代码

GolanSQL和Gorp期望所有类型都包含附加到该类型的Scan和Value方法,以便将行读取到结构中。这会在我的项目中添加大量样板代码,即使这些方法可以通用化也是如此,因为我正在将JSON写入此列。typeType1struct{Type2Type2Type3Type3Type4Type4}typeType2struct{someprimitives...}typeType3struct{someprimitives...}typeType4struct{someprimitives...}func(qType2)Value()(driver.Value,error){return

unit-testing - 如何在 golang 中编写关于插入、获取、删除和更新数据的测试用例

我必须编写插入、获取、删除和更新数据的测试用例。在互联网上搜索时,我找到了一个代码并且它可以工作,但我不知道它是如何工作的。我的代码在下面给出,任何人都可以用简单的方式告诉我我将如何理解代码。packagemodelsimport("testing""gopkg.in/mgo.v2/bson""fmt")funcTestAddBlog(t*testing.T){typeargsstruct{queryinterface{}}tests:=[]struct{namestringargsargswantbool}{{"first",args{bson.M{"_id":4,"title":"

sql - 如何翻译 SQL 语句以在 sqlx API 调用中使用?

我一直在尝试查询PostgreSQLltree.在表tree中,path的类型为ltree。我可以用psql写:SELECTid,pathFROMtreeWHEREpath@'12345'没问题。当我在sqlx中执行时:db.Get(&path,"SELECTid,pathFROMtreeWHEREpath@'$1'",entryID)它一直告诉pq:operantsyntaxerror。不确定是否有办法正确转义查询字符串中的单引号。我试过了,但还是不行:db.Get(&path,`SELECTid,pathFROMtreeWHEREpath@''$1''`,entryID)

go - 将超过 7 天的数据插入分区的 BigQuery 表

documentation证明可以将超过7天(且不超过1年)的数据插入分区表。但每当我尝试使用GoBigQueryClient流式传输一个月前的数据时,它都会返回错误:“您只能流式传输到相对于当前日期过去7天和future3天的日期范围。”如何使用Go客户端流式传输超过7天的数据?编辑1:这是表架构:bigquery.TableMetadata{Schema:bigquery.Schema{{Name:"page_id",Required:true,Type:bigquery.IntegerFieldType},{Name:"user_id",Required:false,Type:b

go - 如何为 Go 中的行插入重用单个 Postgres DB 连接?

我正在尝试使用Go为从rabbitmq接收到的每条新消息将一行数据插入到Postgres表中,使用与在下面代码的init函数中打开的数据库的单个连接。代码不是只打开一个连接,而是打开497并达到最大值,这导致行插入停止...我已经尝试使用这些问题中的信息openingandclosingDBconnectioninGoapp和opendatabaseconnectioninsideafunction它说我应该打开一个连接并使用全局数据库以允许主函数将sql语句传递给在init函数中打开的连接。我以为我已经这样做了,但是每个新行都会打开一个新连接,因此一旦达到postgres连接限制,代

mysql - 原子更新和备份 ON DUPLICATE KEY insert else - golang sql 语句

在golang中组合两个语句(INSERT或(BACKUP和UPDATE))并自动执行它们的最佳方式是什么?我发现了这个类似的问题:https://codereview.stackexchange.com/questions/186909/query-select-and-insert-if-not-exists?newreg=067063956a834327883542c3171a22d4但是解决方案没有满足以下要求中的2个:对DUPLICATEKEY的值进行备份,使用标准SQL不使用存储过程但是保持原子性。 最佳答案 这更像是一

mysql - golang sql.open() 期望 0 个参数得到 1

我正在尝试使用golang连接到我在本地拥有的mysql数据库,它构建得很好,但运行它时出现以下错误:panic:sql:expected0arguments,got1我的连接是这样的:packagemainimport("database/sql""fmt"_"github.com/go-sql-driver/mysql")funcDBConn(){team:="software"db,err:=sql.Open("mysql","root:12345678@tcp(localhost:3306)/flexlocal")iferr!=nil{fmt.Println("thisiswh

mysql - 如何在 golang 中编写一个通用方法以在任何 mysql 表中插入记录

我正在golang中创建一个restapi,并向表中发出一个POST请求。为此,我创建了一个结构。基本上,struct中的变量与名为users的表中的列相同。并编写了一个函数来发出POST请求。代码运行良好,发出POST请求时的参数已成功插入表中。typeUserstruct{IDintNamestringLnamestringCountrystring}funcinsertUser(responsehttp.ResponseWriter,request*http.Request){varuserDetailsUserdecoder:=json.NewDecoder(request.B

mongodb 获取最后 30 分钟前插入的项目

我想检查在过去30分钟内是否使用mongodb在golang中添加了项目。这是我的类型模型:typePayCoinstruct{IDbson.ObjectId`json:"id"bson:"_id"`OwnerIDbson.ObjectId`json:"owner_id"bson:"owner_id"`PublicKeystring`json:"public_key"bson:"public_key"`PrivateKeystring`json:"-"bson:"private_key"`QrCodestring`json:"qrcode"bson:"-"`ExchangeRateui

postgresql - 如果我们将数据库/sql 行对象重新分配给 new Query() 的结果会怎样?它会自动关闭吗?还是我们应该自己关闭它?

我正在使用Golang处理postgresql,我处于必须执行多个查询的情况。如果我将每个查询的结果存储在同一个变量中,我们称之为“行”,每次将该变量重新分配给新的查询结果,它会自动关闭以前的行吗?还是我应该每次都手动关闭它们?如果我应该手动关闭它们,如果我每次都推迟rows.Close()会发生什么?有那么必要吗? 最佳答案 如何调用Rows.Close()*在您再次分配给rows`之前?不,Rows.Close()不会被重新分配自动调用。如果您执行多个不同查询,请使用不同变量来保存每个查询返回的行。分配后为每个调用deferro