MySQL除了CS运行模式, 还有embedded模式. 相关文档介绍比较少,也比较散乱, 最近项目中正好用到, 现通过本文对其基本用法做个介绍,给出可以运行的基本例子.本文基于mysql5.5.
环境配置
要使用embedded模式的MySQL, 有两种方法, 一种是从源码编译, 一种是下载libmysqld库. 本文首先采用下载库的方法, 在ubuntu16.04上, 有如下的命令.
sudo apt install libmysqld-dev
下载完成以后, 在相应的接口代码中, 使用如下的选项进行编译和链接即可.
`mysql_config --include --libmysqld-libs`
libmysqld中开放的接口有限, 如果选择从源码编译, 除了可以用基本的embedded的功能外, 还能用到其他有意思的功能, 比如调用MySQL解析器, 这个将在后续的文章中介绍.
运行基本程序
为了验证是否安装成功, 写一个如下的小程序, 并且编译运行. 在运行前, 先在当前目录创建一个新的文件夹shadow
#include<stdio.h>
#include<mysql.h>
#include<my_global.h>
static bool lib_initialized = false;
int main(){
if (!__sync_bool_compare_and_swap(&lib_initialized, false, true)) {
return 0;
}
char dir_arg[1024];
snprintf(dir_arg, sizeof(dir_arg), "--datadir=%s", "./shadow");
char *mysql_av[5]=
{ "progname",
"--skip-grant-tables",
dir_arg,
"--character-set-server=utf8",
"--language=/home/casualet/Desktop/cryptdb/mysql-src/build/sql/share/"
};
assert(0 == mysql_library_init(sizeof(mysql_av)/sizeof(mysql_av[0]),(char**) mysql_av, 0));
assert(0 == mysql_thread_init());
MYSQL* mysql = mysql_init(NULL);
if(mysql==NULL){
printf("error