基于Mysql C Api编写mysql客户端程序

在编写mysql客户端程序时,最常见的就是连接mysql,和关闭mysql,在这里需要注意,如果使用不当将会造成内存泄漏。


单线程环境:一般使用 -lmysqlclient链接mysql客户库,mysql_init函数会自动调用my_library_init初始化mysql库,所以不需要,需要注意的是这两个函数都是非线程安全的。

示例代码如下:

/* mysql连接 */
void pa_mysql_connect(MYSQL *mysql_conn) {
	my_init();
	if (NULL == mysql_init(mysql_conn)) {
		write_log("Colud not init mysql.");
	}

	if (!mysql_real_connect(mysql_conn, g_mysql->host, g_mysql->username, g_mysql->passwd, g_mysql->dbname, g_mysql->port, NULL, 0)) {
		write_log("Mysql connect error : .", mysql_error(mysql_conn));
	}
}

/* 关闭mysql连接 */
void pa_mysql_close(MYSQL *mysql_conn) {
	mysql_close(mysql_conn);
	mysql_conn = NULL;
}

多线程环境:一般调用-lmysqlclient_r调用mysql安全类库,需要在各个线程中调用mysql_library_init、mysql_library_end来分配和释放mysql资源,或者增加线程锁保护资源,否则会造成内存泄漏。

示例代码如下:

/* mysql连接 */
void pa_mysql_connect(MYSQL *mysql_conn) {
	my_init();
	if (NULL == mysql_init(mysql_conn)) {
		write_log("Colud not init mysql.");
	}
	if (mysql_library_init(0, NULL, NULL)) {
		write_log("Could not initialize mysql library.");
	}
	if (!mysql_real_connect(mysql_conn, g_mysql->host, g_mysql->username, g_mysql->passwd, g_mysql->dbname, g_mysql->port, NULL, 0)) {
		write_log("Mysql connect error : .", mysql_error(mysql_conn));
	}
}


/* 关闭mysql连接 */
void pa_mysql_close(MYSQL *mysql_conn) {
	mysql_close(mysql_conn);
	mysql_conn = NULL;
	mysql_library_end();
}



参考资料:
http://www.souzz.net/online/MySQL/manual_Clients.html

http://dev.mysql.com/doc/refman/5.0/en/

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值