Linux下编写C++程序连接mysql数据库编译时指定头、库

时间:2022-02-16 09:14:11

Linux下编写C++程序连接mysql数据库

编译时需要指定头文件路径、mysql库,有两种方式:

1. g++ main.cpp mysql_deal.cpp -I/usr/include/mysql -L/usr/bin/mysql -lmysqlclient
2. g++  $(mysql_config --cflags) main.cpp    mysql_deal.cpp  $(mysql_config --libs)

其中:

方法1,-I 指定include头文件所在的查找目录,-L指定包含的mysql库路径。

方法2, MySQL中有一个特殊的脚本,叫做mysql_config. 它会为你编译MySQL客户端,并连接到MySQL服务器提供有用的信息.你需要使用下面两个选项.

  1. –libs 选项 - 连接MySQL客户端函数库所需要的库和选项.

  $ mysql_config –libs

  输出:(echo $(mysql_config --libs))

  -L/usr/lib64/mysql -lmysqlclient -lz -lcrypt -lnsl -lm -L/usr/lib64 -lssl -lcrypto

  2. –cflags 选项 - 使用必要的include文件的选项等等.

  $ mysql_config –cflags

  输出:($ echo  $(mysql_config --cflags

  -I/usr/include/mysql -g -pipe -m64 -D_GNU_SOURCE -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -fno-strict-aliasing

  你需要将上面两个选项加入到对源文件的编译命令中. 所以,要编译上面的程序,要使用下面的命令: