libzdb c语言的数据库连接池支持库 源码分析

libzdb c语言的数据库连接池支持库 源码分析

Standard

整个程序可以支持各种数据库,是通过“接口实现的”。

而C语言并没有接口的概念,它是如何实现的呢?

在ConnectionDelegate.h文件里定义了一个结构体,这个结构体是保存一个数据库连接的所有信息和操作方法,这里的方法都是使用函数指针来定义的。

而在每种数据库实现时,使用这种结构体定义时,分别赋予了每种数据库对应的函数操作方法,这样就实现了接口的定义。

结构体中虽然存储的是数据,但是这个数据如果是指针类型,那么他的作用就不仅仅能够赋值了。这里的“接口”,实质就是对函数指针的灵活运用。

使用方法

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
//首先初始化数据库连接池
URL_T url = URL_new ( "mysql://localhost/test?user=root&password=swordfish" ) ;    //设置连接url
ConnectionPool_T pool = ConnectionPool_new ( url ) ;    //新建一个连接池结构体,并分配内存
ConnectionPool_start ( pool ) ;    //初始化连接池(建立连接),调用fillpool
//...
Connection_T con = ConnectionPool_getConnection ( pool ) ;    //从连接池获取一个连接
ResultSet_T result = Connection_executeQuery ( con , "select id, name, image from employee where salary>%d" , anumber ) ;    //使用此连接执行查询数据操作
while ( ResultSet_next ( result ) )
{
       int id = ResultSet_getInt ( result , 1 ) ;
       const char * name = ResultSet_getString ( result , 2 ) ;
       int blobSize ;
       const void * image = ResultSet_getBlob ( result , 3 , & blobSize ) ;
       //...
}
Connection_close ( con ) ;    //连接使用完关闭连接
//...
ConnectionPool_free ( & pool ) ;    //关闭连接池
URL_free ( & url ) ;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值