草庐IT

azure-sql-database

全部标签

database - Golang 代码的运行速度真的比 PHP 中的相同代码慢

Golang新手,昨天我开始使用Golang并编写了一些实际用PHP编写的代码。我只是想看看性能上的差异。我在PHP中做完全相同的事情,响应在http请求中完全相同,但Golang的执行速度非常慢,即使在编译之后也是如此。我试图了解我在Golang中使用的哪些东西不应该使用,以及我如何才能提高这段代码的性能。我知道遍历映射很慢,但是PHP使用散列映射来实现多维数组。我可以保证我使用的sql查询是从PHP粘贴的完全相同的副本,机器相同,并且两个代码中的循环数相同。packagemainimport("database/sql""encoding/json""fmt"_"github.co

sql - PostgreSQL "?"参数占位符不适用于 "WITH"

这个问题在这里已经有了答案:SyntaxerroratendofinputinPostgreSQL(4个答案)关闭2年前。我正在尝试按以下方式使用?(我在Golang中使用它来生成查询,但它似乎不依赖于Go):WITHTmp(name,enabled)AS(VALUES(?,?),(?,?))UPDATEtable_groupsSETenabled=(SELECTenabledFROMTmpWHEREtable_groups.name=Tmp.name)WHEREtable_groups.nameIN(SELECTnameFROMTmp)获得:syntaxerroratornear",

database - 如何将数据库置于 git(版本控制)之下?

我正在做一个web应用程序,我需要为一些重大更改创建一个分支,问题是,这些更改需要更改数据库架构,所以我想将整个数据库也放在git下.我该怎么做?是否有一个特定的文件夹可以保存在git存储库下?我怎么知道是哪一个?我如何确定我放置的是正确的文件夹?我需要确定,因为这些更改不向后兼容;我不能搞砸。我的数据库是PostgreSQL编辑:有人建议进行备份并将备份文件而不是数据库置于版本控制之下。老实说,我觉得这很难下咽。必须有更好的方法。更新:好的,所以没有更好的方法,但我仍然不太相信,所以我会稍微改变一下问题:我想将整个数据库置于版本控制之下,我可以使用什么数据库引擎来将实际数据库置于版本

sqlite - Beego raw sql - 类型转换问题

这是BeegoMVC架构中使用的代码。varmaps[]orm.Params//PalletsCompletedalready.o.Raw("SelectSUM(Things)asAllTheThingsFROMSomeTable").Values(&maps)numThings:=strconv.Atoi(maps[0]["AllTheThings"].(string))c.Data["Stuff"]=maps[0]["AllTheThings"]错误:单值上下文中的多值strconv.Atoi()试图找出如何使用我们的ORM获取数据并对其进行类型转换,以便对其进行算术运算。任何更多

mysql - SQL结构和日历?

我在将日历结构从sql解包到golang结构时遇到问题,这就是我所拥有的。typeyearstruct{yearintmonths[]month}typemonthstruct{monthintdays[]day}typedaystruct{dayinthoursmap[int]bool}我正在计划一个约会日历,每天可能有10:00、11:00、12:00、13:00等,一次最多读出3个月。我不知道如何解压以下架构:CREATETABLEappointments(idINT,yearINT,monthINT,dayINT,hourINT,teacherINT,(idofteacher)

sql - 使用 sqlx 在 Postgres 中取回新插入的行

我使用https://github.com/jmoiron/sqlx向Postgres查询。是否可以在插入新行时取回整行数据?这是我运行的查询:result,err:=Db.Exec("INSERTINTOusers(name)VALUES($1)",user.Name)或者我应该只使用我现有的user结构作为数据库中新条目的真实来源? 最佳答案 这里是关于sqlx事务的文档:Theresulthastwopossiblepiecesofdata:LastInsertId()orRowsAffected(),theavailabil

database - golang 数据库更新一个不存在的条目

我有一个更新数据库条目的函数,如下所示。逻辑是更新不存在的条目会返回错误。不知何故,我发现代码在错误处理方面有点冗长。有一个更好的方法吗?谢谢。func(adb*AppDB)UpdateTicket(tTicket)error{result,err:=adb.db.NamedExec(`UPDATEticketSETdetail=:detail,start_time=:start_time,end_time=:end_time,priority=:priorityWHEREid=:id;`,&t)iferr!=nil{returnerr}nRows,err:=result.RowsAf

sql - 模式交换支持 Go GORM

我正在编写一个RESTAPI,我需要在其中动态部署到多个模式的连接。示例:我有两个模式,我需要根据哪个用户尝试使用数据来更改它们。想法是有许多其他方案,每个用户一个。我看到了这个问题,但使用的示例是static需要找到一种动态变化的方法。我会将用户模式放入JWTtoken中。我的项目:Panda-API有什么建议吗? 最佳答案 选项1您可以更改database.GetConnection()方法以接收用户名并直接连接到数据库,而无需更改所有服务和模型。您将用户存储在security_middleware.go上的gin.Contex

database - 使用 Golang 检索 SQLite Pragma user_version

这是我使用SQLite的第一个项目,在尝试进行半自动模式迁移时,我想使用stackoverflow上许多其他答案所建议的user_versionpragma。我正尝试在Golang中执行此操作,但不确定我是否应该使用Exec、Query或类似的东西来获得此结果,然后如何将其呈现为可用的东西。在sqlite3中我可以运行'PRAGMAuser_version;'它将返回3或我设置的任何值。 最佳答案 当您使用PRAGMAuser_version读取值时,此语句的行为与查询完全相同,即SELECTuser_versionFROMsome

sql - Golang,postgresql rows.next() panic

在golang中使用postgresql使用rows.next()对行进行交互时出现错误。这只发生在几台机器上,而且时间相当不可预测,这使得调试变得困难。panic:runtimeerror:indexoutofrange[recovered]panic:runtimeerror:indexoutofrangegoroutine28078[running]:panic(0xa63ae0,0xc420014090)/usr/local/go/src/runtime/panic.go:500+0x1a1github.com/lib/pq.(*conn).errRecover(0xc4207