jjzjj

postgresql-9.1

全部标签

postgresql - 扫描 Postgres 复合类型

我定义了一个复合类型用于表中:CREATETYPEdurationAS(hoursNUMERIC,minutesNUMERIC);CREATETABLEfoo(idSERIALPRIMARYKEY,my_durationduration);INSERTINTOfoo(id,my_duration)VALUES(1,ROW(1,30));如何使用database/sql扫描它?当我用实现扫描仪接口(interface)时func(d*Duration)Scan(valueinterface{})error{log.Println(value)ifvalue==nil{*d=Duratio

postgresql - Postgres : Optimising concurrent same row updates

问题我正在使用PostgreSQLv10+golang,我认为这是一个非常常见的SQL问题:我有一个“计数器”表,它有一个current_value和一个max_value整数列。严格来说,一旦current_value>=max_value,我想放弃请求。我有几个Kubernetespod,每个API调用可能会将“计数器”表中同一行(在最坏情况下)的current_value增加1(可以被认为是分布式主机对同一数据库的并发更新)。在我当前和天真的实现中,对同一行的多个更新自然会相互阻塞(如果重要的话,隔离级别是“已提交读”)。在最坏的情况下,我每秒有大约10多个请求会更新同一行。这会

postgresql - 连接 : connection timed out

我已经使用gosql包成功连接到Postgres数据库:...db,err:=sql.Open("postgres",connStr)然后我使用返回的数据库执行(长时间运行的)查询:rows,err:=db.Query(...)我得到了错误:dialtcpxx.xxx.xxx.xx:5432:connect:connectiontimedout我有几个问题:为什么连接超时?我能做些什么来防止它超时吗? 最佳答案 sql.Open()mayjustvalidateitsargumentswithoutcreatingaconnecti

postgresql - 使用 GORM 和 Postgresql 如何设置搜索路径?

如何从gorm获取当前模式?通常它是“SHOWsearch_path”并且是一个exec。与设置当前search_path通常“将search_path设置为newschema”相同。其中新架构可以是一系列名称中的单个架构名称。我尝试了db.Exec("showsearch_path").Find(&result),其中结果是一个[]string,我得到一个空数组。 最佳答案 通过执行类似setsearch_pathtonewschema的查询来设置search_path是不正确的设置方式,因为这只会对用于执行查询的连接进行更改。要

postgresql - GoLang 服务无法使用 docker compose 访问 Postgres

我有一个用Go编写的HTML服务。它使用Postgres,但是当使用dockercompose将它们组合在一起时,我得到“dialtcp0.0.0.0:5432:connect:connectionrefused”在仅使用docker并引用Postgres的运行图像构建启动服务时工作来自go的调用片段psqlInfo:=fmt.Sprintf("host=%sport=%suser=%spassword=%sdbname=%ssslmode=disable",host,port,user,password,dbname)db,err:=sql.Open("postgres",psqlI

postgresql - 关联表中的 gorm many2many 和附加字段

我有一个many2many关联(它用于返回JSON)。它在模型中声明://models/school.gotypeSchoolstruct{IDint`gorm:"primary_key"`Namestring`gorm:"notnull"`Accreditations[]Accreditation`gorm:"many2many:school_accreditation;"`}效果很好。我在json中返回了关联。问题是我在school_accreditation表中有一个附加字段,但它未包含在响应中。我已经尝试像thisanswer中提议的那样为协会声明一个模型://models/s

postgresql - GORM 数据库中的自动迁移将不需要的字段添加到 SQL 表

当我在gorm数据库中创建表时,它向表中添加了我不需要的列。我不确定它是如何添加这些额外字段的。这导致我遇到一个错误,“pq:列“user_id”中的空值违反了非空约束”。“user_id”是添加的不需要的列。我正在使用gorm和postgreSQL。我的两个表之间存在多对多关系。我的第一个表已正确创建,第二个表stores是使用提供的字段加上两个不需要的字段创建的:“user_id”和“stores_id”。我尝试删除多对多关系以查看是否是问题所在,我尝试删除表并使用不同的字段重新创建它们。无论如何,我都无法摆脱这两个额外的列。第一个(工作)表:typeUserstruct{gorm

postgresql - 如何在 gorm 中为 Association 请求主体属于并拥有一个

IhavePeopleandData,其中People有一个Dataand数据属于人如何在gogin中为该协会发出请求正文JSON?我在这种情况下使用gorm,对于这种情况,我不清楚gorm的文档,我应该像funcCreateTodo(db*gorm.DB)func(c*gin.Context){varpersonPersonvardataDatac.bindJSON(&Person)c.bindJSON(&Data)db.create(&Person)db.create(&Data)c.JSON(200,gin.H{result:[]interface{person,data})}t

postgresql - 通过 pq 连接到 PostgreSQL 数据库返回 "bad connection"错误

我正在使用两台不同的计算机在Go和PostgreSQL中制作一个网络应用程序。两台计算机上的设置相同(Ubuntu与最新版本的Go和PostgreSQL)。问题是我无法让我的应用程序连接到笔记本电脑上的数据库。我使用这段代码:func(db*Database)Dial(userstring,passwordstring,dbnamestring){varerrerrordb.Conn,err=sql.Open("postgres","user="+user+"password="+password+"dbname="+dbname+"sslmode=require")iferr!=ni

json - Go语言和PostgreSQL 9.4

是否有支持PostgreSQL9.4版本的Go语言的PostgreSQL库。PostgreSQL9.4支持JSON数据类型,想知道它是否可以与Go语言一起使用?谢谢。 最佳答案 是的,gopqlibrary应该支持PostgreSQLv9.4并且它基本支持JSON类型作为字符串(这似乎是addedinv9.2)。//CREATETABLEfoo(idSERIALPRIMARYKEY,stuffjson);//INSERTINTOfoo(stuff)VALUES('{"x":123}');typeFoostruct{Idint,Stu