vlang
  • 目录
    • V语言学习笔记
    • 目录
    • 安装
    • 开发工具
    • 快速总览
    • 模块
    • 基本类型
    • 变量
    • 常量
    • 枚举
    • 数组
    • 字典
    • 流程控制
    • 函数
    • 结构体
    • 访问控制
    • 方法
    • 注解
    • 接口
    • 泛型
    • 类型别名
    • 联合类型
    • 联合体
    • 错误处理
    • 运算符重载
    • 内置json支持
    • 内置sql支持
    • 并发
    • 内存管理
    • 代码测试
    • 文档生成
    • 编译时代码
    • 包管理器
    • 单个V文件
    • V shell script
    • 不安全代码
    • 集成C代码库
    • 集成汇编代码
    • 裸机环境
    • 生成wasm
    • GUI开发
    • web开发
    • 数据库开发
  • builtin
  • strings
  • arrays
  • maps
  • datatypes
  • strconv
  • os
  • runtime
  • time
  • math
  • json
  • encoding
  • compress
  • toml
  • flag
  • term
  • log
  • io
  • readline
  • reflection
  • net
  • net.http
  • eventbus
  • regex
  • crypto
  • rand
  • sync
  • x
  • db.pg
  • db.mysql
  • db.mssql
  • db.sqlite
  • orm
  • ui
  • sokol
  • gg
  • gx
  • fontstash
  • stbi
  • clipboard
  • V抽象语法树
  • V语言服务
  • V编译器源代码
  • 生成C代码
  • 生成js代码
  • 生成go代码
  • 生成native代码
  • 解释器直接运行
  • 附录1 关键字
  • 附录2 运算符
  • 附录3 编码风格
  • 附录4 V编译器命令行使用
  • 附录5 V调试及错误定位
  • 附录6 V和Go基本语法参照
  • 附录7 V和Zig基本语法参照
由 GitBook 提供支持
在本页
  • 安装postgres数据库
  • C客户端库
  • 使用pg库
  • libpg客户端库使用参考

这有帮助吗?

db.pg

安装postgres数据库

linux安装:

sudo dnf install postgresql-server postgresql-contrib
sudo systemctl enable postgresql
sudo systemctl start  postgresql

mac安装:

brew install postgresql

C客户端库

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

如果没有安装postgresql数据库,则import db.pg时会报错:缺失<libpq-fe.h>。

具体API可以参考C头文件:<libpg-fe.h>。

brew install libpq

使用pg库

vlib/db/pg.v:

pub struct Config { //数据库连接配置结构体
pub:
	host string 
	user string
	password string
	dbname string
}

pub struct DB { //DB对象
mut:
	conn &C.PGconn
}

pub struct Row { //查询结果集的行
pub mut:
	vals []string
}


pub fn connect(config pg.Config) !DB //连接数据库函数,返回DB对象
//然后就是DB的各种方法:
pub fn (db DB) exec(query string) []pg.Row //执行SQL语句
pub fn (db DB) exec_one(query string) !pg.Row //执行SQL语句,返回结果的第一行
pub fn (db DB) exec_param(query string, param string) []pg.Row //带1个参数
pub fn (db DB) exec_param2(query string, param, param2 string) []pg.Row //带2个参数
pub fn (db DB) exec_param_many(query string, params []string) []pg.Row //带多个参数

测试代码:

module main

import db.pg

struct User {
	id   int
	name string
	age  int
}

pub fn (user User) next() User {
	return user
}

fn main() {
	db_config := pg.Config{ //数据库连接配置
		host: 'localhost'
		user: 'postgres'
		password: ''
		dbname: 'test_db'
	}
	db := pg.connect(db_config) or { //连接数据库,如果连接失败,抛出错误
		panic('连接错误:err')
	}

	rows := db.exec('select * from users') or { panic(err) } //方式1:执行SQL语句字符串
	for row in rows {
		println(row)
	}

	users := sql db {
		select from User where id == 1
	}!
	println(users)
	for u in users {
		println(u)
	}
}

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

db.select
db.insert
db.update 

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

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

libpg客户端库使用参考

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

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

上一页x下一页db.mysql

最后更新于1年前

这有帮助吗?