c连接mysql数据库实例

本文提供了一个使用C语言连接MySQL数据库的示例代码,并展示了如何执行简单的查询语句来获取数据。

c连接mysql数据库实例

连接数据库test 用户名root密码abc
在里面有一个username的表,describe username结果如下
mysql>; describe username;
+---------------+-----------------+--------+-------+---------+----------+
| Field           | Type              | Null    | Key   | Default | Extra   |
+---------------+-----------------+--------+-------+---------+----------+
| id                | int(10)           | YES   |          | NULL    |             |
| username   | varchar(32)   |           | PRI    |             |             |
+---------------+-----------------+--------+-------+---------+----------+

mysql>; select * from username;
+------+--------------+
| id     | username |
+------+--------------+
|     1   | sfs             |
+------+--------------+
1 row in set (0.00 sec)


本文目的查找执行select id from username这个语句并打印结果

CODE:#i nclude <unistd.h>;
#i nclude <arpa/inet.h>;
#i nclude <stdio.h>;
#i nclude <stdlib.h>;
#i nclude <string.h>;
#i nclude <sys/types.h>;
#i nclude <sys/socket.h>;
#i nclude <netinet/in.h>;
#i nclude <mysql/mysql.h>;
#i nclude <signal.h>;
#i nclude <errno.h>;
#i nclude <syslog.h>;
MYSQL mysql;
main()
{
         char host[32]="localhost";
         char user[32]="root";
         char passwd[32]="abc";
         char dbname[32]="test";        
        
         if( mysql_init(&mysql) == NULL )
         {
                 syslog(LOG_USER|LOG_INFO,"inital mysql handle error\n");
                 return 1;
         }
         if (mysql_real_connect(&mysql,host,user,passwd,dbname,0,NULL,0) == NULL)
         {
                 syslog(LOG_USER|LOG_INFO, "Failed to connect to database: Error: %s\n",mysql_error(&mysql));
                 return 1;
         }
         else syslog(LOG_USER|LOG_INFO, "connect to database: \n");
         find_ps();        
         db_close();
         return 0;
}
int db_close()
{
         mysql_close(&mysql);
          return 0;
}


int   find_ps ()
{
         MYSQL_ROW m_row;
         MYSQL_RES *m_res;
         char sql[1024],username[32];
         int res=1;
         int *id;
         sprintf(sql,"select id from username");
         if(mysql_query(&mysql,sql) != 0)
         {
                 syslog(LOG_USER|LOG_INFO, "select ps_info Error: %s\n",mysql_error(&mysql));
                 return res;
         }
         m_res = mysql_store_result(&mysql);
         if(m_res==NULL)
         {
                 syslog(LOG_USER|LOG_INFO, "select username Error: %s\n",mysql_error(&mysql));
                 res = 3;
                 return res;
         }
         if(m_row = mysql_fetch_row(m_res))
         {
                 printf("m_row=%d\n",atoi(m_row[0]));
                 res = 0;                
         }
         mysql_free_result(m_res);
         return res;
}

编译命令
gcc -g connect_db.c -L/usr/lib/mysql -lmysqlclient -lz
注意:
如果/tmp/ccTGmMS21.o: In function `main':
/tmp/ccTGmMS21.o(.text+0x11): undefined reference to `mysql_init'
那么参数增加-L/usr/lib/mysql -lmysqlclient 
如果
usr/lib/mysql/libmysqlclient.a(my_compress.o): In function `my_uncompress':
my_compress.o(.text+0xaa): undefined reference to `uncompress'
那么增加-lz参数

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值