react 前端框架如何驱动企业数字化转型与创新发展
909
2022-11-15
Linux环境下Mysql++安装及操作深入详解
题记:
之前项目中使用OTL连接操作Oracle数据库,对于Mysql有用,但没有总结。目前常用的两种连接方式:
方式一:mysql conncetor (mysql官网提供。
方式二:mysql++。 由于mysql connector我没有用过,不做评价。把mysql ++ 的优点列一下,对比mysql connector: 1)mysql++历史更悠久; 2)mysql++是第三方库; 3)mysql++编程风格:使用 使用原生的C++标准库和STL。而mysql conncetor更像JAVA风格。 4)mysql++更成熟。 原作者给出的比较: Linux(确切是Centos)下msyql++的安装、增、删、改、查源码封装接口实现。
1、Mysql++作用
Mysql++是官方发布的、为MySQL设计的C++语言的API,这个API的作用是使工作更加简单且容易。 Mysql++为Mysql的C-Api的再次封装,它用STL开发并编写,并为C++开发程序员提供象操作STL容器一样方便的操作数据库的一套机制。 经常使用STL、OTL的朋友,使用起来会非常方便。
-:release 6.8 (Final))
第1步:安装 libmysqlclient
install
libmysqlclient.so安装位置查看:
@laoyang testMysqlConn]# rpm -ql mysql-devel********/usr/lib64/mysql/libmysqlclient.so
如上,从结果中可以看到libmysqlclient.so在/usr/lib64/mysql/目录下
第2步: 安装mysql3.2.2
1)解压:
mysql3.2.2 .tar.gz ,默认目录为:mysql++-3.2.2
2)配置
./configure –prefix=/usr/local –enable-thread-check –with-mysql-lib=/usr/lib64/mysql
3)编译
make
4)安装
make install
5)修改/etc/ld.so.conf文件,
添加如下内容:
local/lib/sbin/ldconfig/bin/ln -s /usr/local/lib/libmysqlpp.so /usr/lib/libmysqlpp.so
至此,mysql++安装配置ok。
3、Mysql++操作
3.1 核心功能点:
1)通过Mysql++类库,连接Mysql。 2)实现对Mysql的增、删、改、查操作。
3.2 用户手册
API的详细介绍及使用Demo 核心接口
MySql++支持三种查询: Query::execute(), Query::store(), Query::use()
1)execute( )接口
用于不返回数据的查询,该函数返回一个SimpleResult对象。
2)exec( )接口
它返回一个bool值,标示执行成功与否;如果只要成功与否的标识,可以使用该接口。
3)store() 接口
用于用服务器获取数据,该函数返回一个StoreQueryResult对象。对象包含了整个查询结果,使用stl::map方式从里面取数据即可。
4)use()接口
同样用于从服务器获取数据,不过该函数返回UseQueryResult对象。相比store()而言更节省内存,该对象类似StoreQueryResult,但是不提供随机访问的特性。use查询会让服务器一次返回结果集的一行。 Query对象的errnum()返回上次执行对应的错误代码,error()返回错误信息,affected_rows()返回受影响的行数。
3.4 实战源码实现:
1)test.cpp内容如下:
#include
2)makefile文件:
# cat MakefileCXX := g++CXXFLAGS := -I/usr/include/mysql -I/usr/local/include/mysql++LDFLAGS := -L/usr/lib64/mysql -lmysqlpp -lmysqlclient -lnsl -lz -lmEXECUTABLE := mainall: testclean:
3)执行结果如下:
# ./testInserting testszInsert = insert into cc(id, name, status) values(66, "Miss Zhangx", "OK");Inserted into cc table, ID =66deleting testszDelete = delete from cc where id = 44;deleted success!updating testszUpdate = update cc set name = "new line 2 revise" where id = 2;updated success!selecting test:ares.num_rows() = 11id: 1 - Name: laoyang360 - Status: ok - Modified_at0000-00-00 00:00:00id: 2 - Name: new line 2 revise - Status: ok - Modified_at2016-06-23 06:16:42id: 11 - Name: test11 - Status: ok - Modified_at2016-06-24 02:09:15id: 5 - Name: jdbc_test_update08 - Status: ok - Modified_at0000-00-00 00:00:00id: 7 - Name: test7 - Status: ok - Modified_at0000-00-00 00:00:00id: 8 - Name: test008 - Status: ok - Modified_at0000-00-00 00:00:00id: 9 - Name: test009 - Status: ok - Modified_at0000-00-00 00:00:00id: 10 - Name: test10 - Status: ok - Modified_at2016-06-24 02:08:14id: 22 - Name: laoyang - Status: ok - Modified_at2016-08-27 06:24:05id: 55 - Name: Miss Zhang - Status: OK - Modified_at2016-08-27 07:40:38id: 66 - Name: Miss Zhangx - Status: OK - Modified_at2016-08-27 08:41:51
4、易出错点
1) /usr/bin/ld: cannot find -lmysqlclient
修正方法:Makefile文件中包含mysqlclient.so的路径:/usr/lib64/mysql。
2)程序初始编译出“segment fault” 调试方法
第1步:让core显示出来
编辑/root/.bash_profile文件,在其中加入 ulimit -S -c unlimited , 如下:
@laoyang testMysqlConn]# tail -f /root/.bash_profileulimit -S
第2步:调试
gdb 可执行文件 core文件 gdb test core.10968
5、下一步工作
对mysql++如果可能的化,封装成自己常用的类。目前已经基本相对清晰。
2016年8月27日 16:19 思于家中床前
作者:铭毅天下
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~