当前位置:  技术问答>linux和unix

linux下用c如何连接mysql

    来源: 互联网  发布时间:2016-04-08

    本文导语:  我在linux下连接mysql但是编译不过去。 代码如下: #include  #include  #include  #include    MYSQL mysql;  void doQuery()  {     MYSQL_ROW m_row;     MYSQL_RES *m_res;     char sql[1024];         sprintf(sql,"select count(*) from my_ta...

我在linux下连接mysql但是编译不过去。
代码如下:
#include 
#include 
#include 
#include 
 
MYSQL mysql; 

void doQuery() 

   MYSQL_ROW m_row; 
   MYSQL_RES *m_res; 
   char sql[1024]; 
   
   sprintf(sql,"select count(*) from my_table"); 
   if(mysql_query(&mysql,sql) != 0) 
   { 
      fprintf(stderr, "mysql_query err: %s",mysql_error(&mysql)); 
   } 
   m_res = mysql_store_result(&mysql); 
   if(m_res==NULL) 
   { 
      fprintf(stderr, "get result err: %s",mysql_error(&mysql)); 
   } 
   if(m_row = mysql_fetch_row(m_res)) 
   { 
      printf("count(*) is %d!n",atoi(m_row[0])); 
   } 
   mysql_free_result(m_res); 
}

int main() 

   char host[32] = "127.0.0.1"; 
   char user[32] = "2008"; 
   char passwd[32] = "2008"; 
   char db[32] = "tra"; 
    
   if( mysql_init(&mysql) == NULL ) 
   { 
      fprintf(stderr,"Init mysql err!"); 
      return -1; 
   } 
   if (mysql_real_connect(&mysql,host,user,passwd,db,0,NULL,0) == NULL) 
   { 
      fprintf(stderr,"Connect to mysql Error:%s!",mysql_error(&mysql)); 
      return -1; 
   } 
   else
   {
      puts("Connect to mysql success!"); 
   }
       
   doQuery(); 
   mysql_close(&mysql); 
   return 0; 
}


但是我用命令 gcc -o test test.c 编译时有如下错误:
test.c:4:25: error: mysql/mysql.h: No such file or directory
test.c:7: error: expected '=', ',', ';', 'asm' or '__attribute__' before 'mysql'
test.c: In function 'doQuery':
test.c:11: error: 'MYSQL_ROW' undeclared (first use in this function)
test.c:11: error: (Each undeclared identifier is reported only once
test.c:11: error: for each function it appears in.)
test.c:11: error: expected ';' before 'm_row'
test.c:12: error: 'MYSQL_RES' undeclared (first use in this function)
test.c:12: error: 'm_res' undeclared (first use in this function)
test.c:16: error: 'mysql' undeclared (first use in this function)
test.c:25: error: 'm_row' undeclared (first use in this function)
test.c: In function 'main':
test.c:39: error: 'mysql' undeclared (first use in this function)
test.c:39: warning: comparison between pointer and integer
test.c:44: warning: comparison between pointer and integer
test.c:57:2: warning: no newline at end of file

这个是说找不到mysql.h引起的错误吧?
为什么会有这个错误?如何解决?
刚刚接触到Linux,请大家多帮忙,谢谢了!

|
添加mysql链接库
gcc -o test test.c -L/usr/include/mysql -lmysqlclient
如果没记错的话应该是这样写的。

|
最好写个Makefile来维护,参考如下:

C= gcc
CFLAGS= -c -g -pthread -D_REENTRANT -D`uname -s` -Wall
LDFLAGS= -g -lpthread
CDBFLAGS= `mysql_config --cflags`
LDDBFLAGS = `mysql_config --libs_r`
target = ex_8_6
all: $(target)
target_objects=$(target).o
$(target) :$(target_objects)
$(CC) $(LDFLAGS) $(LDDBFLAGS) -o $@ $^
@echo  $@ Build OK.
.SUFFIXES:.cpp .o
.c.o :
$(CC) $(CFLAGS) $(CDBFLAGS) -o $@ $<

clean:
@rm -rf $(target)  $(target_objects)


把target 换成你要生成的文件。

要在多线程的环境下安全使用mysql C 客户端,动态SQL,可以关注我的书.

班门弄斧之作已经发行,各大书店有售(http://www.khp.com.cn/books/detail.asp?bookid=1707)

    
 
 

您可能感兴趣的文章:

  • 在XP下使用VMWare安装了Linux AS 5.6之后,使用FTP工具可以远程连接Linux,而在cmd命令行中却连接不上,什么原因 ?
  • linux 有线连接了却显示有线连接断开是怎么回事
  • 请问unix/linux下动态连接库和静态连接库有什么区别?
  • LINUX中连接C++的库怎么连接.库在什么位置,还有什么特殊命令吗?
  • 在linux下可以使用dao方式连接数据库吗?可以连接musql吗?回答就给分!急
  • 在线请教:linux下用MySQL C API 连接MySQL 4.1.12出现的连接问题,提示升级客户端!!!!!!
  • ftp连接问题,就是linux连接windows ftp的问题,高手请进(在线等待)!!!!!
  • Linux下的C++程序怎么连接WIN2000下的SQL Server 2000?或者如何连接MySQL?
  • linux 下连接创建连接数据库程序,什么都可以 。谁知道300分
  • [疑问] [linux网络连接]Linuxmint网络连接
  • LINUX C 进行TCP网络连接,怎样设置连接超时时间?
  • 我在telnet到linux上的时候报不能打开到主机的连接, 在端口23: 连接失败 请问是什么原因
  • linux vsftpd连接问题
  • Linux 下的C语言实现数据库连接池操作。
  • Linux 代理 一个客户端来就创建一个连接
  • SecureCRT连接linux。为什么我在linux的/etc/sysconfig/下找不到iptables?
  • linux问题 secureCRT连接的问题 在线等急!~~
  • 我想用Linux的串口和S3c2410x连接,请问在Linux里面怎么找到那个超级终端?
  • 高分求教,linux下的GPRS连接!!!
  • 用xmanager远程连接不上linux桌面
  • Mysql服务器登陆,启动,停止等基本操作命令介绍(Linux/Centos环境)
  • 在 linux下输入"mysql"命令,进入mysql命令行,但出现“Can't connetc to local MySQL server thuough socket /var/lib/mysql/mysql.sock
  • Linux和windows下用mysql c++ library操作Mysql数据库
  • 为什么用linux安装盘安装了mysql后,启动mysql,提示找不到mysql.sock文件?
  • 請教,在redhat linux7.2+mysql 中,系統提示mysql已啟動,網頁卻不能訪問mysql?
  • 在Linux内安装了Mysql,无法进入Mysql.
  • 怎样在linux终端输入mysql直接进入mysql?
  • php for linux安装既不支持mysql.如何配置支持mysql
  • linux mysql登陆出错 mysql升级方法
  • linux 下mysql 以root和普通用户进入mysql的问题
  • 请问红旗Linux下,安装Mysql时,应该下载mysql 的哪一种rpm包?谢谢
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • linux c/c++ IP字符串转换成可比较大小的数字
  • 在win分区上安装linux和独立分区安装linux有什么区别?可以同时安装吗?(两个linux系统)
  • linux哪个版本好?linux操作系统版本详细介绍及选择方案推荐
  • 在虚拟机上安装的linux上,能像真的linux系统一样开发linux程序么?
  • secureCRT下Linux终端汉字乱码解决方法
  • 我重装window后,把linux的引导区覆盖了,进不了linux怎么办?急啊,望热心的人帮助 (现在有linux的盘)
  • Linux c字符串中不可打印字符转换成16进制
  • 安装vmware软件,不用再安装linux系统,就可以模拟linux系统了,然后可以在其上学习一下LINUX下的基本操作 了?
  • Linux常用命令介绍:更改所属用户群组或档案属性
  • 红旗Linux主机可以通过127.0.0.1访问,但如何是连网的Win2000机器通过Linux的IP去访问Linux
  • linux命令大全详细分类介绍及常用linux命令文档手册下载
  • 我重装window后,把linux的引导区覆盖了,进不了linux怎么办?急啊,望热心的人帮助 (现在没有linux的盘,只有DOS启动盘)
  • Linux Kernel 'sctp_v6_xmit()'函数信息泄露漏洞
  • 如何让win2000和linux共存。我装好WIN2000,再装LINUX7.0,但LILO只能找到LINUX,不能引导WIN2000
  • linux c下利用srand和rand函数生成随机字符串
  • 在windows中的VMware装了个linux,主板有两个串口,能做windows和linux的串口通信测试么,怎么测试这两个串口在linux是有效
  • Linux c++虚函数(virtual function)简单用法示例代码
  • 我们网站的服务器从windows2000迁往linux,ASP程序继续使用,可是我连LINUX的皮毛都不了解,大家告诉我LINUX下怎么建网站??
  • Docker官方镜像将会使用Alpine Linux替换Ubuntu
  • 中文Linux与西文Linus分别哪一个版是权威?I认为是:中科软的白旗Linux与西文的绿帽子Linux!大家的看法呢?
  • Linux下chmod命令详细介绍及用法举例
  • 我重装了winme,却进不了Linux了,而我现在又没有Linux光盘,也没有Linux启动盘,还有没有办法?


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3