1、安装好mysql
 
 
2、要实现C连接数据库,需要安装数据库连接器(即MySQL Connector/C)
   MySQL Connector/C是一个C语言的client库,这个库是为了实现client/server通信的。
   MySQL Connector/C是一个独立的替换为装有mysql server的mysql client库
 
 
3、要安装MySQL Connector/C,需要安装cmake。
 
     下载包:cmake-2.6.4.tar.gz
     mysql-connector-c-6.0.2-linux-glibc2.3-x86-32bit.tar.gz
 可能是因为我的英文比较烂吧,没看懂是怎么个编译过程,我就采用了一种比较笨的方法,如下。
  #3.1 解压两个压缩包:
   [root@localhost ...]#tar zxvf cmake-2.6.4.tar.gz
   [root@localhost ...]#tar zxvf mysql-connector-c-6.0.2-linux-glibc2.3-x86-
 
32bit.tar.gz
  #3.2 将解压后的cmake-2.6.4中的所有内容拷贝到mysql-connector-c-6.0.2-linux-
 
glibc2.3-x86-32bit中
  #3.3 进入mysql-connector-c-6.0.2-linux-glibc2.3-x86-32bit下,编译:
   [root@localhost ...]#./bootstrap (编译cmake)
   [root@localhost ...]#make
   [root@localhost ...]#make install
   [root@localhost ...]#cmake -G "Unix Makefiles"
   [root@localhost ...]#make
   [root@localhost ...]#make install
 
 
 
4、到mysql-connector-c-6.0.2-linux-glibc2.3-x86-32bit目录下
 
    将编译好MySQL Connector/C的/bin、/lib和/include拷贝
 
到/usr/bin、/usr/lib、/usr/include(这样在包含头文件时,就可以直接写成#include
 
"mysql.h")

[root@localhost ...]#cp -r /tmp/mysql-connector-c-6.0.2-linux-glibc2.3-x86-

 
32bit/bin/   /usr/bin/
 
 [root@localhost ...]#cp -r /tmp/mysql-connector-c-6.0.2-linux-glibc2.3-x86-
 
32bit/lib/   /usr/lib/
 
 [root@localhost ...]#cp -r /tmp/mysql-connector-c-6.0.2-linux-glibc2.3-x86-
 
32bit/include/   /usr/include/
 
 
 
5、编写*.c连接数据库程序。
 
例如:test.c
#include <stdio.h>
#include <string.h>
#include <errno.h>
#include "mysql.h"
 
int main(void)
{
        MYSQL *conn_ptr;
        MYSQL_RES *res;
        MYSQL_ROW row;
 
        char *host = "127.0.0.1";
        char *user = "root";
        char *password = "";
        char *db = "mysql";
        unsigned int port = 0;
        char *unix_socket = NULL;
        unsigned long client_flag = 0;
 
        conn_ptr = mysql_init(NULL);
        if(!conn_ptr)
        {
                fprintf(stderr, "init mysql failed\n");
                return(-1);
        }
 
        conn_ptr = mysql_real_connect(conn_ptr, host, user, password, db, port, unix_socket, client_flag);
        if(conn_ptr)
        {
                printf("Connection success......\n");
        }
        else
        {
                fprintf(stderr, "Connection failed......%d:%s\n", errno, strerror(errno));
        }
 
 
        if( mysql_query(conn_ptr, "select host,user from user"))
        {
                fprintf(stderr, "call mysql_query failed......%d:%s\n",errno, strerror(errno));
        }
 
        res = mysql_use_result(conn_ptr);
        fprintf(stdout, "select host, user from user talbe in the mysql database:\n");
 
 
        while((row = mysql_fetch_row(res)))
        {
                fprintf(stdout, "%s\t%s\n", row[0], row[1]);
        }
 
 
        mysql_free_result(res);
        mysql_close(conn_ptr);
        return 0;
}
*对连接数据库函数的使用,可以参见http://dev.mysql.com/doc/refman/5.1/en/c-api-functions.html,也可以参见我的博文里的《C连接mysql——常用的函数》*
*对SQL语句的使用,可参见http://www.w3school.com.cn/sql/sql_delete.asp
 
 
 
6、编译连接test.c
 
[root@localhost ...]#gcc test.c -Wall -I/usr/include  -L/usr/lib  -lmysqlclient -o
 
test
在运行程序之前,一定要开启mysql服务
[root@localhost ...]#/etc/init.c/mysqld start
[root@localhost ...]# ./test
Connection success......
select host, user from user talbe in the mysql database:
127.0.0.1       root
localhost
localhost       root
 
 
*好了,大功告成,努力了很长时间才弄明白是怎么回事,如果有帮到你们,我也很开心,嘻嘻……*

我的C语言连接Mysql之路的更多相关文章

  1. C语言连接MySql数据库

    C语言连接MySql数据库(CodeBlocks) 操作系统:Windows7(32位)编译软件:Code::Blocks 10.05数 据 库:mysql-5.1.62-win32 数据库内的数据: ...

  2. Windows下用C语言连接Mysql注意问题

    原文:Windows下用C语言连接Mysql注意问题 环境是:在VS6.0 安装Mysql后,我们需要相应的头文件以及lib文件,所以安装过程必须是完整安装.否则不会生成include文件夹哦~ 具体 ...

  3. Linux centos 7/ubantu下: 用 C 语言连接 MySQL数据库

    前言:最近用IPC.socket做ATM.聊天项目,考虑到需要用到数据库,所以总结一下centos.ubantu环境下怎么用C语言操作数据库,例如常见的增删改查等! 一.Centos环境安装mysql ...

  4. Linux下C语言连接MySQL

    本文出自   http://blog.csdn.net/shuangde800 首先保证安装: 1:安装MySQL:sudo apt-get install mysql-server mysql-cl ...

  5. c语言连接mysql数据库的实现方法

    C语言连接mysql数据库,需要相应的头文件和lib文件,如果你安装Mysql数据库,会在安装目录下找到这些库文件,如果没有安装,也可以在网上找到 我这里也有一份网上找到的:/201205/other ...

  6. R语言-连接MySQL数据库方法

    版权声明:本文为博主原创文章,未经博主允许不得转载.   目录(?)[+]   R语言连接数据库常用的方法有2种: 1.使用R数据库接口 连接MySQL,使用RMySQL包,使用前RMySQL包要先安 ...

  7. C语言连接mysql -insert-update

    C语言连接mysql数据库实现insert语句:数据库:test表:systeminfo CREATE TABLE `systeminfo` (  `id` int(11) NOT NULL AUTO ...

  8. R语言连接MYSQL

    操作系统:centos 6.4 64bit R语言可以使用RMySQL来连接Mysql数据库,直接使用数据库里面的数据生成图像. 这个是RMYSQL的说明: http://cran.r-project ...

  9. Mac上c语言连接mysql遇到的问题

    参照<Beginning Linux Programming>上的例程写了一个连接mysql的c语言小程序connect1.c.但是按照书上的编译命令无法编译.然后经过查阅资料解决了问题. ...

随机推荐

  1. 让 Linux grep 的输出不换行

    在Redhat中亲测. 本来ps -ef的输出是不会换行的,但是 ps -ef | grep java 就换行了. 如果想让grep完的结果不要换行,找到两种方法. 1. 在后面拼接 less -S: ...

  2. OpenERP __sql_constrants doesn't work.

    可能的原因有两个,一个是你没有更新模块列表,第二个可能是你原有的列已经有重复的数据.(unique限制为例.)

  3. Fedora 24 python3.5 安装M2Crypto

    安装M2Crypto#python3 -m pip install M2Crypto 出现错误 gcc: /usr/lib/rpm/redhat/redhat-hardened-cc1:Nosuch ...

  4. js实现私有变量

    一.块级作用域 js中没有块级作用域的概念,可用匿名函数实现,由于匿名函数执行完一遍后,内部没有引用其变量对象的函数,其变量对象被清除,后面则引用不到其中的变量 (function(){ //块级作用 ...

  5. ANR机制

    1.什么是ANR(Application Not Responding) 在Android中,应用程序的响应性是由ActivityManager和WindowManager系统服务监视的.当监测到以下 ...

  6. session_start()导致history.go(-1)返回时无法保存表单数据的解决方法

    问题背景: 在填写完表单提交时,由于某个表单项可能填写的不合法,导致提交失败,返回表单页面.但返回后所有的表单都被清空了,重新填写比较麻烦,度娘解释说,是由于每个页面都调用了session_start ...

  7. [笔记] Python基础---列表

    1.定义列表 列表由数据构成的有限序列,即按照一定的线性顺序排列,排列而成的数据项的集合. 2.创建列表 使用‘[ ]’括起来就已经创建了一个列表,例: my_first_list = [] #空列表 ...

  8. vue2.0读书笔记1-基础

    一.概述 二.模版语法 三.计算属性 四.class与style绑定 五.条件渲染 六.列表渲染 七.事件处理器 八.表单控件绑定 九.组件 一.概述     在底层的实现上, Vue 将模板编译成虚 ...

  9. 十一:image 图片

    属性名 类型 默认值 说明 src String   图片资源地址 mode String 'scaleToFill' 图片裁剪.缩放的模式 binderror HandleEvent   当错误发生 ...

  10. WINFORM如何实现无聚焦框的Button按钮

    当我们将一个button按钮设置如下属性时,总有一个聚焦框来困扰着我们 button1.FlatStyle = FlatStyle.Flat; 我们想要的效果是这样的: 但当使用了Tab切换焦点时 发 ...