吃透OceanBase |MySQL C API 的使用说明和配置方法

本文介绍了基于 C/C++ 的 OceanBase 客户端开发组件:OceanBase Connector/C 和 MySQL 官方的客户端开发组件:MySQL C API 的使用说明和配置方法。

建议使用 OceanBase 客户端开发组件:OceanBase Connector/C。

连接 MySQL 租户也可以使用 MySQL 官方的客户端开发组件:MySQL C API。

使用说明

C APIs 包含在 mysqlclient 库文件当中,GCC 编译时使用 -I 选项指定头文件, -L 指定库文件目录, -l 指定库名。示例如下:

  • OceanBase Connector/C

    gcc test.c -I/u01/obclient/include -L/u01/obclient/lib -lobclnt
    
  • MySQL C API

    gcc test.c -I/usr/include/mysql/ -L/usr/lib64/mysql -lmysqlclient
    

注意

把库文件名开头的 lib 和结尾的 .so.xx去掉即为库名。

库名的查看方式如下:

[jayhart.xj@OceanBase008059.gtjsqa /usr] 
$ ls -l /usr/lib64/mysql/ |grep mysqlclient
lrwxrwxrwx 1 root root      17 Dec 13  2015 libmysqlclient_r.so -> libmysqlclient.so
lrwxrwxrwx 1 root root      20 Dec 13  2015 libmysqlclient.so -> libmysqlclient.so.18 
lrwxrwxrwx 1 root root      24 Dec 13  2015 libmysqlclient.so.18 -> libmysqlclient.so.18.0.0
-rwxrwxrwx 1 root root 3133560 Dec 13  2015 libmysqlclient_r.so.18.0.0

代码示例如下所示:

#include <mysql.h>
#include <stdio.h>
#include <string.h>

void main(void) {
    MYSQL conn;
    char server = "xxx.xxx.xxx.xxx";
    char user = "root@test#obtest";                                                //用户名@租户名#集群名称
    char password = "test";                                                        //密码
    char *database = "test";                                                       //数据库名
    char str_sqls;
    int status;
    int result;
    int i;

    conn = mysql_init(NULL); / Connect to database /
    / connect to server with the CLIENT_MULTI_STATEMENTS option /
    if (mysql_real_connect (conn, server, user, password,
            database, 3306, NULL, CLIENT_MULTI_STATEMENTS) == NULL)
    {
        printf("mysql_real_connect() failed\n");
        mysql_close(conn);
        exit(1);
    }
    / execute multiple statements /
    strcat(str_sqls, "DROP TABLE IF EXISTS test_table;");
    strcat(str_sqls, "CREATE TABLE test_table(id BIGINT);");
    strcat(str_sqls, "INSERT INTO test_table VALUES(10);");
    status = mysql_query(conn, str_sqls);
    if (status)
    {
        printf("Could not execute statement(s)");
        mysql_close(conn);
        exit(0);
    }
    mysql_close(conn);
}

更多信息

有关 OceanBase Connector/C 的详细介绍和使用方法,请参见 《 OceanBase Connector/C 》 。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值