pg

安装postgres数据库

linux安装:

  1. sudo dnf install postgresql-server postgresql-contrib
  2. sudo systemctl enable postgresql
  3. sudo systemctl start postgresql

mac安装:

  1. brew install postgresql
  2. brew services start postgresql

C客户端库

使用的是postgres官方发布的C版本postgres客户端库

如果没有安装postgresql数据库,则import pg时会报错:缺失

具体API可以参考C头文件:

使用

vlib/pg.v:

  1. pub struct Config { //数据库连接配置结构体
  2. pub:
  3. host string
  4. user string
  5. password string
  6. dbname string
  7. }
  8. pub struct DB { //DB对象
  9. mut:
  10. conn &C.PGconn
  11. }
  12. pub struct Row { //查询结果集的行
  13. pub mut:
  14. vals []string
  15. }
  16. pub fn connect(config pg.Config) ?DB //连接数据库函数,返回DB对象
  17. //然后就是DB的各种方法:
  18. pub fn (db DB) exec(query string) []pg.Row //执行SQL语句
  19. pub fn (db DB) exec_one(query string) ?pg.Row //执行SQL语句,返回结果的第一行
  20. pub fn (db DB) exec_param(query string, param string) []pg.Row //带1个参数
  21. pub fn (db DB) exec_param2(query string, param, param2 string) []pg.Row //带2个参数
  22. pub fn (db DB) exec_param_many(query string, params []string) []pg.Row //带多个参数

测试代码:

  1. module main
  2. import pg
  3. struct User {
  4. id int
  5. name string
  6. age int
  7. }
  8. fn main(){
  9. db_config := pg.Config { //数据库连接配置
  10. host:'localhost'
  11. user:'postgres'
  12. password:''
  13. dbname:'pg_test'
  14. }
  15. db := pg.connect(db_config) or { //连接数据库,如果连接失败,抛出错误
  16. panic("连接错误:err")
  17. }
  18. rows:=db.exec('select * from users') //方式1:执行SQL语句字符串
  19. for row in rows {
  20. println(row)
  21. }
  22. users:=db.select from User where id==22 //方式2:编译器内实现了这样的语法
  23. for u in users {
  24. println(u)
  25. }
  26. }

这种db.的语法,目前还是比较原型阶段的,编译器内置实现了这几个SQL语句,都是解析器解析到pg.DB类型的变量才可以进行的语法,只针对pg有效

  1. db.select
  2. db.insert
  3. db.update

目前的pg库还是太简单,只能进行进行简单的查询,很多地方还需要完善

但是pg库是基于postgres官方的C客户端库,可以把里面的C函数和结构体直接拿来使用,或者进行进一步的封装,开发起来还是比较快的

目前需要注意的2个坑:

  1. 使用db.select from User时,会转为小写复数的users表名,如果没有建好对应的表名,会报错
  2. 定义模型结构体时,如果结构体的字段多于对应数据库表的字段,执行db.exec()的时候不会返回结果,也没有提示

libpg客户端库使用参考

官方中文参考:http://www.postgres.cn/docs/11/libpq.html

教程:https://geek-docs.com/postgresql/postgresql-postgresql/postgresqlc.html