MySQL的Embedded模式C接口

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
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值