草庐IT

PostgreSQL主从复制-逻辑复制

全部标签

postgresql - 如何参数化运算符?

我有如下的sql语句:SELECTpk,upFROMmytableWHERE2>1LIMIT10显然,这只是为了简单起见。我能够参数化任何整数:SELECTpk,upFROMmytableWHERE2>$1LIMIT10但是,当我尝试参数化运算符时,例如:SELECTpk,upFROMmytableWHERE2$11LIMIT10我得到:pq:syntaxerroratornear"$1"完整代码:packagemainimport("database/sql"_"github.com/lib/pq""log")funcmain(){log.SetFlags(log.Lshortfil

rest - 如何在现实世界的 Go 项目中分离路由、处理程序、第 3 方接口(interface)和业务逻辑

看完officialguide关于如何构建项目和经历各种(1、2、3仅举几例)示例和项目我不禁想知道我构建REST-API服务器应用程序的方法是否结构化正确地。API的用途是什么?POST/auth/sign-in接受用户名和密码并发出JWT(JSON网络token)。GET/auth/sign-out将JWT添加到黑名单以使身份验证session无效。获取/资源检索所有资源的列表。POST/resources(需要有效的JWT身份验证)接受JSON正文,创建新资源并向所有人发送有关新资源的电子邮件和通知。我的项目是什么样的目前我没有创建任何库。一切都在主包中,带有路由的总体服务器设置

postgresql - Go database/sql 改变表名的大小写

我正在尝试使用database/sql和github.com/lib/pqPostgres驱动程序查询数据库。我遇到的错误是:pq:relation"itemprices_itemsale"doesnotexist但是看看我的查询:rows,err:=db.Query("SELECT*FROM\"itemPrices_itemsale\"LIMIT10")您会注意到表名中的大写“P”。我已经了解到,如果没有引用,Postgres会将名称折叠成小写字母。我引用了我的表名,所以我不太确定为什么会这样。我相当确定这就是问题所在,因为我能够使用类似Python程序中的表名查询表,并且一切都按预

Golang - 将 exec 输出复制到缓冲区

我正在编写一个函数来执行一个程序并返回stdout和stderr。它还可以选择将输出显示到控制台。我显然不是在等待什么,就好像我连续两次运行该函数一样,输出是不同的。这是一个示例程序,将dirvar替换为包含大量文件的目录以填充缓冲区:funcmain(){dir:="SOMEDIRECTORYWITHALOTOFFILES"out,err:=run("ls-l"+dir,true)iferr!=nil{log.Fatalf("runreturned%s",err)}log.Printf("Out:%s",out)out2,err:=run("ls-l"+dir,false)iferr

postgresql - golang postgres 连接错误太多

我是Golang/Postgres的新手,我正在做一些测试并收到一个pq:sorry,toomanyclientsalready错误。我的postgres实例设置为最多100个连接,我在此代码中收到该错误fori:=0;i我通常可以插入大约60到70个插入然后我得到那个错误。所有连接都来自for循环中的那个样本。我做错了什么,这是我的完整代码。据我所知,1个连接可以容纳许多不同的查询,所以我不知道为什么它只给我60到70个插入然后得到错误。funcInsert_Stream(whttp.ResponseWriter,r*http.Request){wg:=sync.WaitGroup{

go - 复制一个html.Response,然后获取字符串

我制作了一个应该包含响应正文的Url类型。typeUrlstruct{AddressstringRefreshstringWatchstringFoundboolBodybytes.Buffer//bytes.Bufferneedsnoinitialization}使用正确的Address创建一个Url对象,然后我做resp,err:=http.Get(url.Address)现在我想做类似下面的事情,但我无法摆脱它:io.Copy(url.Body,b)//CopythattotheUrlbuffer目前,Url.Body字段可以根据需要修改为其他类型。之后,我想从那个Buffer/

postgresql - 如何在 golang 中使用 .Format 将 time.Time 对象转换为格式化字符串?

我目前正在尝试从我的SQL数据库中获取一个time.Time对象,并将检索到的值转换为格式化字符串,如下所示:TIME_FORMAT:="%Y-%m-%dT%H:%M:%S"这是我在Python中用来做同样事情的格式,但我知道它不适合go。我已经从数据库中获取了值,现在只需要对其进行格式化。请注意,我已将ccc.Ia_date定义为interface{}类型,因为数据库中的此值可能为空。这是我的代码片段:fmt.Println(reflect.TypeOf(ccc.Ia_date))//givesmetime.Timet:=ccc.Ia_date//whichprintsas:2016

postgresql - 如何从go app查看postgresql "raise notice"

我正在用go编写小应用程序。现在我需要在应用程序控制台中记录postgres“raisenotice”消息。我没有找到postgresql在*sql.Conn中引发消息的地方(我使用go/sql和lib/pq驱动程序)例子,createfunctionshow_mes()returnsintas$$beginraisenotice'testmessagefrompg';return1;end$$languageplpgsql;我从goapp调用这个函数并可以得到结果。但是我如何从goapp访问消息“来自pg的测试消息”?在用Node编写的当前版本中,我们在控制台中记录消息以进行调试:谢

postgresql - golang/pq pq : operator does not exist: bigint = text

query:="WITHb(ColA,ColB)AS(VALUES($1,$2))UPDATEschema_name.table_nameASaSETColC=b.ColBFROMbWHEREa.ColA=b.ColAANDa.ColB=b.ColB"res,err:=db.Exec(query,1,1)上述代码失败并出现以下错误:pq:operatordoesnotexist:bigint=text“ColC”是BIGINT类型。根据我的调查,驱动程序将值作为文本而不是整数插入。问题:https://github.com/lib/pq/issues/582

postgresql - Golang GORM 中列的自动迁移问题

自动迁移问题(我认为)。我可以通过psql控制台得出该列不存在的结论。我可以通过终端/控制台/SQL手动插入该列,但更喜欢通过自动迁移来解决此问题。感谢您的阅读和/或行动。终端输出:启动Web服务器:“(pq:列“password_hash”包含空值值(value)观)”提交POST:“(pq:关系“accounts”的列“password_hash”不存在)” 最佳答案 来源:JonCalhoun资源:https://www.usegolang.com/"...theshortansweristhatautomigratefail