c与mysql连接和一个简单查询的例子

转载 2006年05月23日 08:24:00

今天给新来的同事做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)


[b:f09d522785]本文目的查找执行select id from username这个语句并打印结果[/b:f09d522785]
[code:1:f09d522785]
#include <unistd.h>
#include <arpa/inet.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <mysql/mysql.h>
#include <signal.h>
#include <errno.h>
#include <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;
}
[/code:1:f09d522785]
编译命令
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参数

一个实现C/C++连接MYSQL数据库的很好的例子

一个实现C/C++连接MYSQL数据库的很好的例子 标签: 代码片段(1) [代码] [C/C++]代码 001 //下面的代码是一个实现C++连接MYSQL数据...

VB.net数据库编程(03):一个SQLserver连接查询的简单例子

这个例子,由于在ADO.net入门已经专门学了,再次进行复习 一下。 主要掌握连接字串的情况。 过程就是: 1、引用System.Data.SqlClient。而Ac...

VB.net数据库编程(03):一个SQLserver连接查询的简单例子

这个例子,由于在ADO.net入门已经专门学了,再次进行复习 一下。 主要掌握连接字串的情况。 过程就是: 1、引用System.Data.SqlClient。而Access中引用 的是...

也发一个TWI多机通讯的简单例子.并经过抗干扰测试 IIC I2C

这个简单例子是这样的: 总线上只设一个主机,主机使用查询读写 总线上允许有多个从机,从机使用硬件中断功能。 ***************** 我开始是把主机和从机都使用中断功能的,但是,我发...

一个简单的UDP广播例子(含C/S)

一个简单的UDP广播通讯的例子程序,含有服务端和客户端的代码。 // 服务端 // BoardCast_Server.cpp : Defines the entry point ...

一个简单的UDP广播例子(含C/S)

一个简单的UDP广播通讯的例子程序,含有服务端和客户端的代码。// 服务端 // BoardCast_Server.cpp : Defines the entry point for the con...

Linux C编程的一个小例子——实现一个简单的who命令(第一版)

在贴代码之前,有一些东西是需要讲清楚的。 1)Linux C编程用到了一些只有Linux下才有的函数。而将这些放到Windows下的话,会报错。 也就是说,讲一下代码在windows下运行是会报错...

JDBC 连接到 Mysql 数据库简单例子

  • 2014年06月27日 11:21
  • 895KB
  • 下载

JAVA获得Mysql连接的简单例子

  • 2008年03月21日 10:13
  • 3KB
  • 下载

C/C++连接MySQL数据库“经典”例子!

废话不多说,直接撸代码!!! //下面的代码是一个实现C++连接MYSQL数据库的很好的例子 //这里用了建表,插入,检索,删表等常用功能 //我用VC++6.0生成,已经成功连接了。 //在VC...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:c与mysql连接和一个简单查询的例子
举报原因:
原因补充:

(最多只允许输入30个字)