分享
一个更快,数据类型支持更精准的 golang PostgreSQL 驱动
jf_wang · · 3246 次点击 · · 开始浏览这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。
用于golang database/sql 的PostgreSQL驱动
Go Version Support
Go version
PostgreSQL Version Support
PostgreSQL version
PostgreSQL version
安装
go get github.com/blusewang/pg
使用
db, err := sql.Open("pg", "postgresql://user:password@host_name/database_name?application_name=app_name")
if err != nil {
return err
}
defer db.Close()
rows, err := db.Query("select * from bluse where id>1ドル", 0)
if err != nil {
return err
}
...
文档
更多的细节及使用示例,参见: https://godoc.org/github.com/....
特性
-
在
Scan()时,对null值宽容。不推荐使用sql.Null系列类型,接受null值!- 以字符串字段的
null值为例:向Scan()中传string型的变量,得到"",传*string型的变量,得到nil。
- 以字符串字段的
- 常见
Array类型直接兼容golang的数组类型。如PG的:integer[],对应golang的:[]int64 -
数据源格式,既支持键值对,又支持URI。书写格式遵守:PG官方规范。
- URI格式,支持
pg://前缀。 - 其中用户名、端口、主机名,在数据源中未指定时,有默认值。用户名默认为操作系统当前用户的用户名
- URI格式,支持
-
积极标记并缓存所有预备语句[包括
db.Query、db.Exec、db.Prepare()等的语句],遇到相同的语句请求时,自动复用。这能提高1倍的执行速度!!!- 为了发挥好此功能,需要最大可能地允许数据库连接空闲。
- 配置上推荐将
sql.SetMaxIdleConns(x)、sql.SetMaxOpenConns(x)两处的x设置为相同的值!
协议实现
- 此驱动更适合服务于Web
| 状态 | 功能 | 备注 |
|---|---|---|
| <ul><li>- [x] </li></ul> | 启动 | 必备,实现:无密码,明文密码和md5密码三种认证 |
| <ul><li>- [x] </li></ul> | 简单查询 | 必备 |
| <ul><li>- [x] </li></ul> | 扩展查询 | 必备 |
| <ul><li>- [x] </li></ul> | 取消正在处理的请求 | 必备 |
| <ul><li>- [x] </li></ul> | 终止 | 必备 |
| <ul><li>- [ ] </li></ul> | 函数调用 | PG官方推荐使用查询去调用函数 |
| <ul><li>- [ ] </li></ul> | SASL 认证 | 不常用 |
| <ul><li>- [ ] </li></ul> | 异步操作 | 不常用 |
| <ul><li>- [ ] </li></ul> | COPY操作 | 不常用 |
| <ul><li>- [ ] </li></ul> | SSL会话加密 | 低效 |
有疑问加站长微信联系(非本文作者)
入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889
关注微信3246 次点击
添加一条新回复
(您需要 后才能回复 没有账号 ?)
- 请尽量让自己的回复能够对别人有帮助
- 支持 Markdown 格式, **粗体**、~~删除线~~、
`单行代码` - 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
- 图片支持拖拽、截图粘贴等方式上传
收入到我管理的专栏 新建专栏
用于golang database/sql 的PostgreSQL驱动
Go Version Support
Go version
PostgreSQL Version Support
PostgreSQL version
PostgreSQL version
安装
go get github.com/blusewang/pg
使用
db, err := sql.Open("pg", "postgresql://user:password@host_name/database_name?application_name=app_name")
if err != nil {
return err
}
defer db.Close()
rows, err := db.Query("select * from bluse where id>1ドル", 0)
if err != nil {
return err
}
...
文档
更多的细节及使用示例,参见: https://godoc.org/github.com/....
特性
-
在
Scan()时,对null值宽容。不推荐使用sql.Null系列类型,接受null值!- 以字符串字段的
null值为例:向Scan()中传string型的变量,得到"",传*string型的变量,得到nil。
- 以字符串字段的
- 常见
Array类型直接兼容golang的数组类型。如PG的:integer[],对应golang的:[]int64 -
数据源格式,既支持键值对,又支持URI。书写格式遵守:PG官方规范。
- URI格式,支持
pg://前缀。 - 其中用户名、端口、主机名,在数据源中未指定时,有默认值。用户名默认为操作系统当前用户的用户名
- URI格式,支持
-
积极标记并缓存所有预备语句[包括
db.Query、db.Exec、db.Prepare()等的语句],遇到相同的语句请求时,自动复用。这能提高1倍的执行速度!!!- 为了发挥好此功能,需要最大可能地允许数据库连接空闲。
- 配置上推荐将
sql.SetMaxIdleConns(x)、sql.SetMaxOpenConns(x)两处的x设置为相同的值!
协议实现
- 此驱动更适合服务于Web
| 状态 | 功能 | 备注 |
|---|---|---|
| <ul><li>- [x] </li></ul> | 启动 | 必备,实现:无密码,明文密码和md5密码三种认证 |
| <ul><li>- [x] </li></ul> | 简单查询 | 必备 |
| <ul><li>- [x] </li></ul> | 扩展查询 | 必备 |
| <ul><li>- [x] </li></ul> | 取消正在处理的请求 | 必备 |
| <ul><li>- [x] </li></ul> | 终止 | 必备 |
| <ul><li>- [ ] </li></ul> | 函数调用 | PG官方推荐使用查询去调用函数 |
| <ul><li>- [ ] </li></ul> | SASL 认证 | 不常用 |
| <ul><li>- [ ] </li></ul> | 异步操作 | 不常用 |
| <ul><li>- [ ] </li></ul> | COPY操作 | 不常用 |
| <ul><li>- [ ] </li></ul> | SSL会话加密 | 低效 |