mysql embedded_MySQL的Embedded模式C接口

MySQL除了CS运行模式, 还有embedded模式. 相关文档介绍比较少,也比较散乱, 最近项目中正好用到, 现通过本文对其基本用法做个介绍,给出可以运行的基本例子.本文基于mysql5.5.环境配置要使用embedded模式的MySQL, 有两种方法, 一种是从源码编译, 一种是下载libmysqld库. 本文首先采用下载库的方法, 在ubuntu16.04上, 有如下的命令.sudo ap...
摘要由CSDN通过智能技术生成

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

#include

#include

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 26\n");

}else{

printf("

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值