用于golang database/sql 的PostgreSQL驱动html
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/....git
在Scan()
时,对null
值宽容。不推荐使用sql.Null
系列类型,接受null
值!github
null
值为例:向Scan()
中传 string
型的变量,获得 ""
,传 *string
型的变量,获得 nil
。Array
类型直接兼容golang的数组类型。如PG的:integer[]
,对应golang的:[]int64
数据源格式,既支持键值对,又支持URI。书写格式遵照:PG官方规范。golang
pg://
前缀。积极标记并缓存全部预备语句[包括db.Query
、db.Exec
、db.Prepare()
等的语句],遇到相同的语句请求时,自动复用。这能提升1倍的执行速度!!!sql
sql.SetMaxIdleConns(x)
、sql.SetMaxOpenConns(x)
两处的x设置为相同的值!状态 | 功能 | 备注 |
---|---|---|
<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会话加密 | 低效 |