上次我们已经共同学习了在Linux下C连接数据库,下面一起学习用C语言来操作数据库。

1,首先要打开mysql的服务

[root@bogon ~]# service mysqld status
mysqld 已停
[root@bogon ~]# service mysqld start
启动 MySQL:                                               [确定]
[root@bogon ~]#
此时mysql服务已打开

下面我们来读取数据库的内容

mysql> show databases;
+--------------------+
| Database             |
+--------------------+
| information_schema |
| data                    |
| mysql                  |
| test                     |
+--------------------+
4 rows in set (0.00 sec)
mysql> use test;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
mysql> select * from product;
+------+-------+-------+------+
| code | name  | price | num  |
+------+-------+-------+------+
| 1001 | apple |   2.5   |    8   |
| 1003 | cake  |   2.5   |    1   |
| 1002 | pen   |     1    |    5   |
+------+-------+-------+------+
3 rows in set (0.00 sec)
mysql>

好了,下面我们用代码来测试,命名为 readdata.c

 #include<stdio.h>
#include<stdlib.h>
#include "mysql.h" #define N 10
typedef struct Data
{
char code[];
char name[];
float price;
int num;
}Data;
MYSQL *conn_ptr;
int main()
{
void update_data(Data obj);
void conn_data(MYSQL *conn_ptr); printf("Reading database...\n");
read_data();
return ;
} /***********************/
/** Connect Database **/
/***********************/
void conn_data(MYSQL *conn_ptr)
{
conn_ptr=mysql_init(NULL); //连接初始化
if(!conn_ptr)
{
fprintf(stderr, "mysql_init failed\n");
exit ();
//return EXIT_FAILURE;
}
conn_ptr = mysql_real_connect(conn_ptr, "localhost", "root","","test", , NULL, ); //建立实际连接
//参数分别为:初始化的连接句柄指针,主机名(或者IP),用户名,密码,数据库名,0,NULL,0)后面三个参数在默认安装mysql>的情况下不用改
if(conn_ptr)
{
printf("Connection success\n");
}
else
{
printf("Connection failed\n");
}
mysql_close(conn_ptr);
} /*******************/
/** read delete **/
/******************/
int read_data()
{
MYSQL *conn_ptr;
conn_ptr=mysql_init(NULL); //连接初始化
if(!conn_ptr)
{
fprintf(stderr, "mysql_init failed\n");
exit ();
return EXIT_FAILURE;
}
conn_ptr = mysql_real_connect(conn_ptr, "localhost", "root","","test", , NULL, ); //建立实际连接
//参数分别为:初始化的连接句柄指针,主机名(或者IP),用户名,此处密码为空,数据库名,0,NULL,0)后面三个参数在默认安装mysql>的情况下不用改
if(conn_ptr)
{
printf("Connection success\n");
}
else
{
printf("Connection failed\n");
} MYSQL_RES *res_ptr;
MYSQL_ROW sqlrow;
int res = mysql_query(conn_ptr, "select * from product ");
if(res)
{
printf("select error: %s\n", mysql_error(conn_ptr));
}
else {
res_ptr = mysql_store_result(conn_ptr);
if(res_ptr)
{
printf("********************\n");
printf("Retrieved %lu rows\n", (unsigned long)mysql_num_rows (res_ptr));
printf("********************\n");
printf("Code\tName\tPrice\tNumber\n");
while (sqlrow = mysql_fetch_row(res_ptr))
{
unsigned int field_count;
field_count =;
unsigned int field_num=; while(field_count < mysql_field_count(conn_ptr))
{
printf("%s\t", sqlrow[field_count]);
field_count++;
}
printf("\n");
}
if(mysql_errno(conn_ptr))
{
printf("Retrive error : %s\n", mysql_error(conn_ptr));
}
}
mysql_free_result(res_ptr);
mysql_close(conn_ptr); //关闭连接
return EXIT_SUCCESS;
}
}

那就可以运行程序了

[root@bogon ~]# gcc -I/usr/include/mysql readdata.c -lmysqlclient -L/usr/lib/mysql -o read
[root@bogon ~]# ./read
Reading database...
Connection success
********************
Retrieved 3 rows
********************
Code    Name    Price   Number
1001    apple   2.5     8
1003    cake    2.5     1
1002    pen     1        5
[root@bogon ~]#

实验发现和从数据库中读取的完全相同,说明读取数据库已成功。

下面我们可以对其进行典型的“增删查改”了。

linux C读取数据库的更多相关文章

  1. Linux同平台数据库整体物理迁移

    Linux同平台数据库整体物理迁移 需求:A机器不再使用,要将A机器的Oracle迁移到B机器. 之前写过类似需求的文章:http://www.cnblogs.com/jyzhao/p/3968504 ...

  2. 读取数据库数据,并将数据整合成3D饼图在jsp中显示

    首先我将生成饼图的方法独立写成一个PieChar.java类,详细代码如下:(数据库需要自己建,如有需要的话) import java.io.IOException; import java.sql. ...

  3. jdbc读取数据库,表相关信息(含注释)

    读取数据库中的所有的表名 private Set<String> getTableNameByCon(Connection con) { Set<String> set = n ...

  4. 解决虚拟机linux端mysql数据库无法远程访问

    解决虚拟机linux端mysql数据库无法远程访问 1. 在控制台执行 mysql -u root -p mysql,CentOS系统提示输入数据库root用户的密码,输入完成后即进入mysql控制台 ...

  5. Solaris 和linux 之oracle 数据库的安装

    本篇博文前面是一些基础知识介绍,后面才是总结篇. 一.在solaris上面装oracle 10g教程 目前官网已经没有32位的oracle11g了,取而代之的都是64位的oracle11g,为了能在3 ...

  6. PHP 开发 APP 接口 学习笔记与总结 - APP 接口实例 [2] 首页 APP 接口开发方案 ① 读取数据库方式

    方案一:读取数据库方式 从数据库读取信息→封装→生成接口数据 应用场景: 数据时效性比较高的系统 方案二:读取缓存方式 从数据库获取信息(第一次设置缓存或缓存失效时)→封装(第一次设置缓存或缓存失效时 ...

  7. JS使用ActiveXObject读取数据库代码示例(只支持IE)

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  8. 编写SqlHelper使用,在将ExecuteReader方法封装进而读取数据库中的数据时会产生Additional information: 阅读器关闭时尝试调用 Read 无效问题,解决方法与解释

    在自学杨中科老师的视频教学时,拓展编写SqlHelper使用,在将ExecuteReader方法封装进而读取数据库中的数据时 会产生Additional information: 阅读器关闭时尝试调用 ...

  9. C#使用SqlDataReader读取数据库数据时CommandBehavior.CloseConnection参数的作用

    主要用在ExecuteReader(c)中,如果想要返回对象前不关闭数据库连接,须要用CommandBehavior.CloseConnection: CloseConnection解决了流读取数据模 ...

随机推荐

  1. 高性能WEB开发(6) - web性能測试工具推荐

    WEB性能測试工具主要分为三种.一种是測试页面资源载入速度的,一种是測试页面载入完成后页面呈现.JS操作速度的,另一种是整体上对页面进行评价分析,以下分别对这些工具进行介绍,假设谁有更好的工具也请一起 ...

  2. [Hapi.js] Up and running

    hapi is a rock solid server framework for Node.js. Its focus on modularity and configuration-over-co ...

  3. spring aop获取目标对象的方法对象(包括方法上的注解)

    这两天在学习权限控制模块.以前看过传智播客黎活明老师的巴巴运动网视频教程,里面就讲到权限控制的解决方案,当时也只是看看视频,没有动手实践,虽说看过几遍,可是对于系统中的权限控制还是很迷茫,所以借着这次 ...

  4. Javascript进阶篇——浏览器对象—Location、Navigator、userAgent、screen对象

    Location对象location用于获取或设置窗体的URL,并且可以用于解析URL.语法: location.[属性|方法] location对象属性图示: location 对象属性: loca ...

  5. (转)SQL Server 触发器

    SQL Server 触发器 触发器是一种特殊类型的存储过程,它不同于之前的我们介绍的存储过程.触发器主要是通过事件进行触发被自动调用执行的.而存储过程可以通过存储过程的名称被调用. Ø 什么是触发器 ...

  6. C#参数传递、引用类型、值类型等的理解

    本博客不属于技术贴,主要是记录一些自己对不懂得地方的理解和学习的记录,请带着批判的眼光阅读~ 值类型存储在栈上,引用类型存储在堆上.栈是由高到低存储的,遵循先进后出的原则,是内存提前分配好的区域,内存 ...

  7. Python学习笔记6(列表生成式)

    1.生成列表 要生成list [1, 2, 3, 4, 5, 6, 7, 8, 9, 10],我们可以用range(1, 11): >>> range(1, 11) [1, 2, 3 ...

  8. (转)在Eclipse中使用JUnit4进行单元测试

    原地址:http://blog.csdn.net/andycpp/article/details/1327147

  9. n个数的最大公约、最小公倍数

    #include <cstdio> #include <cstring> using namespace std; #define N 1010 //两个数的最大公约数和最小公 ...

  10. linux访问windows共享文件夹的两种方法

    有时需要在linux下需要访问windows的共享文件夹,可以使用mount挂载或者使用samba连接. 1.mount挂载 首先创建被挂载的目录: $ mkdir windows 将共享文件夹挂载到 ...