执行SQL语句---SELECT
1、通常从MySQL数据库中检索数据有4个步骤:
(1)发出查询: 用mysql_query发出查询。
(2)检索数据: 用mysql_store_result/mysql_use_result
(3)处理数据:用mysql_fetch_row, mysql_fetch_field
(4)整理所需要的数据:用mysql_free_result允许MySQL进行必要的整理工作。
2、例子:结构化的数据库查询输出
/*
* MysqlQuery2.c
*
* Created on: Sep 8, 2013
* Author: root
*/
#include <stdlib.h>
#include <stdio.h>
#include <mysql/mysql.h>
MYSQL my_connection;
MYSQL_RES * res_ptr;
MYSQL_ROW sqlrow;
void display_header();
void display_row(MYSQL * ptr); int main(){
int res;
int first_row = ;
mysql_init(&my_connection);
if(mysql_real_connect(&my_connection, "localhost", "root", "ROOT123456", "icmp", , NULL, )){
printf("Connection success.\n");
res = mysql_query(&my_connection, "select childno, fname, age from children where age > 5");
if(res){
printf("Select error:%s \n", mysql_error(&my_connection));
return -;
}else{
res_ptr = mysql_use_result(&my_connection);
if(res_ptr){
display_header();
while((sqlrow = mysql_fetch_row(res_ptr))){
if(first_row){
display_header();
first_row = ;
}
display_row(&my_connection);
}
if(mysql_errno(&my_connection)){
fprintf(stderr, "Retrieve error:%s\n", mysql_error(&my_connection));
return -;
}
}
mysql_free_result(res_ptr);
}
mysql_close(&my_connection);
printf("Connection closed.\n");
}else{
fprintf(stderr, "Connection failed.\n");
if(mysql_errno(&my_connection)){
fprintf(stderr, "Connection error %d %s\n", mysql_errno(&my_connection), mysql_error(&my_connection));
return -;
}
}
return ;
} void display_header(){
MYSQL_FIELD * field_ptr;
printf("Column details:\n");
while((field_ptr = mysql_fetch_field(res_ptr)) != NULL){
printf("\tName: %s\n", field_ptr->name);
printf("\tType:");
if(IS_NUM(field_ptr->type)){
printf("Numeric field\n");
}else{
switch(field_ptr->type){
case FIELD_TYPE_VAR_STRING:
printf("VARCHAR\n");break;
case FIELD_TYPE_LONG:
printf("LONG\n");break;
default:
printf("Type is %d, check in mysql_com.h\n", field_ptr->type);
}
} printf("\tMax width %d\n", field_ptr->length);
if(field_ptr->flags & AUTO_INCREMENT_FLAG){
printf("\t Auto increments\n");
}
printf("\n");
}
} void display_row(MYSQL * ptr){
unsigned int field_count;
field_count = ;
while(field_count < mysql_field_count(ptr)){
printf("%s ", sqlrow[field_count]);
field_count++;
}
printf("\n");
}
运行结果:
Connection success.
Column details:
    Name: childno
    Type:Numeric field
    Max width 11
     Auto increments
Name: fname
    Type:VARCHAR
    Max width 30
Name: age
    Type:Numeric field
    Max width 11
Column details:
1 wangle 28 
2 xuyehui 29 
Connection closed.
执行SQL语句---SELECT的更多相关文章
- java执行sql语句使用别名时显示Column '***' not found
		java执行sql语句使用别名时显示Column '*' not found 在做一个小项目时遇到个问题,执行sql语句使用别名时总是报sql异常 Column '*' not found,折腾半天终 ... 
- mysql5.7执行sql语句报错:In aggregated query without GROUP BY, expression #1 of SELECT list contains nonagg
		mysql5.7执行sql语句报错:In aggregated query without GROUP BY, expression #1 of SELECT list contains nonagg ... 
- 4.5 .net core下直接执行SQL语句并生成DataTable
		.net core可以执行SQL语句,但是只能生成强类型的返回结果.例如var blogs = context.Blogs.FromSql("SELECT * FROM dbo.Blogs& ... 
- 三种执行SQL语句的的JAVA代码
		问题描述: 连接数据库,执行SQL语句是必不可少的,下面给出了三种执行不通SQL语句的方法. 1.简单的Statement执行SQL语句.有SQL注入,一般不使用. public static voi ... 
- Entity Framework Code First执行SQL语句、视图及存储过程
		1.Entity Framework Code First查询视图 Entity Framework Code First目前还没有特别针对View操作的方法,但对于可更新的视图,可以采用与Table ... 
- EFCore执行Sql语句的方法:FromSql与ExecuteSqlCommand
		前言 在EFCore中执行Sql语句的方法为:FromSql与ExecuteSqlCommand:在EF6中的为SqlQuery与ExecuteSqlCommand,而FromSql和SqlQuery ... 
- sp_executesql得到执行sql语句的返回值
		执行 sql语句,得到 变量的值 ' declare @Partition int; ); ); SET @SQLString = N'SELECT @RangeKeyOUT = $PARTITION ... 
- EF中执行sql语句,以及事务
		EF to sql string sql = "select T_Task.BSID,T_Task.CloseDate,T_Task.CompleteDate,T_Task.CloseUse ... 
- C#参数化执行SQL语句,防止漏洞攻击本文以MySql为例【20151108非查询操作】
		为什么要参数化执行SQL语句呢? 一个作用就是可以防止用户注入漏洞. 简单举个列子吧. 比如账号密码登入,如果不用参数, 写的简单点吧,就写从数据库查找到id和pw与用户输入一样的数据吧 sql:se ... 
随机推荐
- spring约束
			<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.sp ... 
- 【JNDI】Java Naming and Directory Interface
			一.数据源的由来 在Java开发中,使用JDBC操作数据库的四个步骤如下: ①加载数据库驱动程序(Class.forName("数据库驱动类");) ②连接数据库(Conn ... 
- Shell基础(一):Shell基础应用、简单Shell脚本的设计、使用Shell变量、变量的扩展应用
			一.Shell基础应用 目标: 本案例要求熟悉Linux Shell环境的特点,主要练习以下操作: 1> 切换用户的Shell环境 2> 练习命令历史.命令别名 3 ... 
- badboy设置参数化
			概述 1.将录制的检查点设置参数化 2.然后回放看结果 ps.设置检查点教程请看上一篇badboy教程 第一:添加变量 第二:将循环次数.请求参数.检查点设置参数化 第三:设置完毕后,点击回放按钮进行 ... 
- NX二次开发-Block UI  C++界面(表达式)控件的获取(持续补充)
			Expression(表达式)控件的获取 NX9+VS2012 #include <uf.h> #include <uf_modl.h> UF_initialize(); // ... 
- JVM 源码分析之 javaagent 原理完全解读
			转载:https://infoq.cn/article/javaagent-illustrated 本文重点讲述 javaagent 的具体实现,因为它面向的是我们 Java 程序员,而且 agent ... 
- C++——指针与引用
			1.指针本身为对象,引用只是对象的别名.故有指针的引用,没有引用的引用,没有引用的指针.指针必须指向一个实际的对象.引用也必须是实际对象的别名. 2.允许指针赋值和拷贝,指针可指向不同的对象 3.指针 ... 
- DLL 调用 对话框    以及    如何获取调用dll 应用程序(窗口程序)的窗口句柄
			1.一般创建需要的窗口,转换成相应的窗口类: 声明一个导出函数,来处理窗口的显示,如: CTest test; extern "C" __declspec(dllexport) v ... 
- pta作业1
			7-1 打印沙漏 (20 分) 本题要求你写个程序把给定的符号打印成沙漏的形状.例如给定17个“*”,要求按下列格式打印 ***** *** * *** ***** 所谓“沙漏形状”,是指每行输出奇数 ... 
- docker 详细安装及问题排查
			一.安装docker 1.Docker 要求 CentOS 系统的内核版本高于 3.10 ,查看本页面的前提条件来验证你的CentOS 版本是否支持 Docker . 通过 uname -r 命令查看 ... 
