jjzjj

Postgres

全部标签

database - 从 PostGres 数据库获取结构

我跟着这里的一个线程想出了这个varbButtonqueryErr:=connection.QueryRow("SELECTid_printer,name,has_childrenFROMbuttonWHEREid_parentISNULL;").Scan(&b.ID,&b.Name,&b.Children)ifqueryErr!=nil{response,err:=json.MarshalIndent(b,"","")fmt.Fprint(w,string(response))iferr!=nil{log.Println("ErroronjsonmarshalindentStarte

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{

sql - 向 postgres 查询添加查询参数时出错

当我写代码时:err:=database.QueryRow("SELECTpage_title,page_content,page_dateFROMpagesWHEREid=1").Scan(&thisPage.Title,&thisPage.Content,&thisPage.Date)一切正常。但我希望它不只是获取带有id=1的页面,而是动态的。所以我写:err:=database.QueryRow("SELECTpage_title,page_content,page_dateFROMpagesWHEREid=?",pageID).Scan(&thisPage.Title,&th

postgresql - go-gorm,postgres : simple inserts return error

由于最近的炒作,我正在尝试做简单的插入,试图评估Postgres的有用性。我是一个mongoDB的人。这就是我想要做的:db,e:=gorm.Open("postgres",fmt.Sprintf("host=%suser=%sdbname=%spassword=%ssslmode=disable",pgHost,pgUser,pgDatabase,pgPass))ife!=nil{log.Fatal(e.Error())}deferdb.Close()db.AutoMigrate(&model.Customer{},&model.Email{},&model.Address{},&m

postgresql - 使用 Postgres 的 Golang UPDATE 专栏

假设我有一个表employments和一个结构EmploymenttypeEmploymentstruct{IDint`json:"id"`Created_atstring`json:"created_at"`Updated_atstring`json:"updated_at"`Educationstring`json:"education"`Jobstring`json:"job"`Positionstring`json:"position"`Business_phonestring`json:"business_phone"`Next_paydaystring`json:"next

postgresql - 使用 Postgres 和 GO 强制执行 "lock"

我是Postgres的新手,所以这可能是显而易见的(或者非常困难,我不确定)。我想强制一个表或行一次至少“锁定”几秒钟。这将导致第二个操作“等待”。我正在使用golang和“github.com/lib/pq”来与数据库交互。我需要这个的原因是因为我正在做一个监控postgresql的项目。谢谢你的帮助。 最佳答案 您还可以使用select...forupdate来锁定一行或多行事务的长度。基本上,它就像:begin;select*fromfoowherequatloos=100forupdate;updatefoosetfeens

postgresql - Golang Postgres 如何将表转储为 JSON

我正在尝试为Go1.9中的多个表(一次一个表)运行此命令:COPY(selectrow_to_json(foo)FROM(SELECT*FROMbar)foo)TO'/tmp/bar.json';这可能吗?似乎与lib/pg一起,但事实并非如此。使用go-pg,我总是会耗尽内存,因为它会先将所有内容缓冲到内存中。从命令提示符执行此操作效果很好。我宁愿使用Go的PG库,也不愿让它在命令提示符下运行。简而言之,我试图将整个表转储到它们自己的文件中的JSON中。有人成功过吗?谢谢!编辑:因为lb/pg根本不支持这个,所以我使用pg-go。这是代码:varbufbytes.Buffer_,er

postgresql - 我如何使这个 Golang 到 Postgres 的查询更快?有什么具体的选择吗?

我正在使用Golang和Postgres来过滤一些财务数据。我有一个Postgres数据库,它有一个包含单个股票市场的表(如果这是正确的术语)。此表包含ID、代码、日期、开盘价、最高价、最低价、收盘价和交易量的列。总行数为6,610,598,不同股票(代码)的数量为2174。现在我要做的是从那个表中过滤数据,然后保存到另一个表中。所以第一个包含原始数据,第二个包含清理后的数据。我们有三个参数,一个日期(EVALDATE)和两个整数(MINCTD&MINDP)。首先,我们必须只选择那些将通过我们的最小日历交易日参数的股票。所以这将被选择(注意:我们为此使用golang)symbols[]

sql - 如何使用 Golang 在 Postgres 中批处理 SQL 语句

使用Golang向Postgres数据库发送批量请求的最快方法是什么?每个请求包含500-200000行。我知道的方法是-1.使用database/sql包的事务Begin,Prepare,Commit.2.一条语句发送所有数据。3.使用sql.Exec()方法发送语句列表。有没有其他方法可以在不在每个语句中建立连接的情况下发送批量请求?如果不是,哪种方法最好?这个问题类似于-GolanghowdoIbatchsqlstatementswithpackagedatabase.sql的问题 最佳答案 depesz有点老blogpost

postgresql - 在 Golang 中使用 postgres 获取事务提交前的最后一个 ID

我有2个insert查询。在第二个insert查询中,我需要第一个insert返回id。我将这些查询作为事务处理,因为它们相互依赖。那么,是否有可能在Golang的postgres中提交事务之前获取最后插入的id。 最佳答案 Postgres支持returning关键字来选择插入的id:INSERTINTOYourTable(col1,col2)VALUES('Value1','Value2')RETURNINGid; 关于postgresql-在Golang中使用postgres获取事