一个更快,数据类型支持更精准的 golang PostgreSQL 驱动

栏目: 数据库 · PostgreSQL · 发布时间: 6年前

内容简介:更多的细节及使用示例,参见:

用于golang database/sql 的PostgreSQL驱动

一个更快,数据类型支持更精准的 golang PostgreSQL 驱动

一个更快,数据类型支持更精准的 golang PostgreSQL 驱动

Go Version Support

PostgreSQL Version Support

安装

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官方规范

    pg://
    
  • 积极标记并缓存所有预备语句[包括 db.Querydb.Execdb.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会话加密 低效

以上所述就是小编给大家介绍的《一个更快,数据类型支持更精准的 golang PostgreSQL 驱动》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

微信营销与运营

微信营销与运营

王易 / 机械工业出版社 / 2014-1-1 / CNY 49.00

这是一本深度介绍微信营销的书,也是一本系统讲解微信公众账号运营的书,它基于微信的最新版本,从策略、方法、技巧与实践等多角度详细解析了微信的营销与运营,所有内容都是行业经验的结晶,旨在为企业运用微信提供有价值的参考。 本书首先从商业模式角度全面分析了微信5.0推出的“扫一扫”、表情商店、微信游戏、微信支付等新功能背后的商业机会,以及订阅号折叠给企业带来的影响和应对策略;其次从运营角度系统归纳了......一起来看看 《微信营销与运营》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

SHA 加密
SHA 加密

SHA 加密工具

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换