mysql 编程实例_mysql api---从一个小例子开始mysql编程入门(3)

首先完善一下上一节的程序及遗留的问题

#include

#include

#include

#include

unsigned int mysql_errno(MYSQL *mysql)

/*

int mysql_init(MYSQL *handle)

{

MYSQLtmphandle = (MYSQL )malloc(sizeof(MYSQL));

// .....

//...handle = tmphandle;

}

int main()

{

int ret = 0, i = 0;

MYSQL mysql;

MYSQL *connect = NULL;

connect = mysql_init(&mysql) ;

if (connect == NULL)

{

ret = mysql_errno(&mysql) ;

printf("func mysql_init() err \n");

return ret;

}

printf("func mysql_init() ok \n");

connect = mysql_real_connect(connect, "localhost", "root", "mysql", "pos", 0, NULL, 0);

if (connect == NULL)

{

ret = mysql_errno(&mysql) ;

printf("func mysql_init() err \n");

return ret;

}

printf("func mysql_real_connect() ok \n");

//查询

const char *query = "select *from emp";

ret = mysql_query(&mysql, query);

if (ret != 0)

{

ret = mysql_errno(&mysql) ;

printf("func mysql_query() err \n");

return ret;

}

//typedef char **MYSQL_ROW; /* return data as array of strings */

//typedef unsigned int MYSQL_FIELD_OFFSET; /* offset to current field */

//获取结果集合

//结果集合中 可以含有10行数据

MYSQL_RES *result = mysql_store_result(&mysql);

if(result==NULL)

{

ret = mysql_errno(&mysql) ;

printf("func mysql_query() err \n");

return ret;

}

unsigned int num = mysql_field_count(&mysql) ;//从mysql句柄中获取列

MYSQL_FIELD *fields = mysql_fetch_fields(result);//获取表头地址结构体

for (i = 0; i

{

printf("%s\t", fields[i].name);//表的名字

}

printf("\n");

MYSQL_ROW row = NULL;

while (row = mysql_fetch_row(result) )

{

for (i=0; i

{

printf("%s\t", row[i]);

}

printf("\n");

mysql_free_result(result);

mysql_close(&mysql);

printf("hello...\n");

return ret;

}

这个程序一个很大的问题就是一个入口多个出口,怎么改呢?

即错误处理都让他只有一个出口即可,提示goto语句,后面再详细说

有了上面的知识,实践一下

实现一个小小的mysql工具

#include

#include

#include

#include

int main(int argc,char* argv)

{

int ret = 0, i = 0;

MYSQL mysql;

MYSQL *connect = NULL;

char sqlbuf[2048];

connect = mysql_init(&mysql) ;

if (connect == NULL)

{

ret = mysql_errno(&mysql) ;

printf("func mysql_init() err \n");

return ret;

}

printf("func mysql_init() ok \n");

connect = mysql_real_connect(connect, "localhost", "root", "123456", "mydb2", 0, NULL, 0);

if (connect == NULL)

{

ret = mysql_errno(&mysql) ;

printf("func mysql_init() err \n");

return ret;

}

printf("func mysql_real_connect() ok \n");

for (;;)

{

memset(sqlbuf, 0, sizeof(sqlbuf));

printf("\nplease enter you sql: ");

fgets(sqlbuf,sizeof(sqlbuf),stdin);

buf[strlen(sqlbuf)-1]=0;

/* EXIT(exit):退出 */

if ( 0 == strncmp(sqlbuf , "exit" , 4) || 0 == strncmp(sqlbuf , "EXIT" , 4) ||

0 == strncmp(sqlbuf , "quit" , 4) || 0 == strncmp(sqlbuf , "QUIT" , 4) )

{

break;

}

ret = mysql_query(&mysql, "set names utf8");//避免中文乱码

if (ret != 0)

{

ret = mysql_errno(&mysql) ;

printf("func mysql_query() err \n");

return ret;

}

ret = mysql_query(&mysql, sqlbuf);

if (ret != 0)

{

ret = mysql_errno(&mysql) ;

printf("func mysql_query() err \n");

return ret;

}

if (strncmp("select", sqlbuf, 6)==0 || strncmp("SELECT", sqlbuf, 6)==0)

{

//获取结果集合

//结果集合中 可以含有10行数据

MYSQL_RES *result = mysql_store_result(&mysql);

//使用的过程中在获取 结果

//MYSQL_RES *result = mysql_use_result(&mysql);

//

unsigned int num = mysql_field_count(&mysql) ;

//获取表头

MYSQL_FIELD *fields = mysql_fetch_fields(result);

for (i = 0; i

{

printf("%s\t", fields[i].name);

}

printf("\n");

//获取内容

MYSQL_ROW row = NULL;

while (row = mysql_fetch_row(result) )

{

for (i=0; i

{

printf("%s\t", row[i]);

}

printf("\n");

}

mysql_free_result(result);

}

}

mysql_close(&mysql);

printf("hello...\n");

return ret;

}

这样一个小工具就完成了,用没有问题呢?如果你输入backspace键和delete和上下键呢?问题出现了,如何解决呢?

请看下面代码

#include

struct termios oldterm;

void setstty2()//设置输入退格键,不回显

{

//system("stty erase ^H");//执行shell命令,也可以 用来设置读取用户键盘输入的时候,退格键不回显

struct termios term;

if(tcgetattr(STDIN_FILENO, &term) == -1)//得到系统termion的设置

{

printf("tcgetattr error is %s\n", strerror(errno));

return;

}

oldterm = term;//保留当前termios设置,以便程序退出的时候可以恢复termios //tty

/*

term.c_lflag &= ~ICANON;//取消ICANON选项(不规范输入)

term.c_lflag |= ICANON;//设置ICANON选项(规范输入)

term.c_cc字段为要设置的具体特殊输入字符,如c_cc[VERASE]代表退格键,

term.c_cc[VERASE] = '\b';意思为把退格键修改为'\b'

VERASE代表向前擦出一个字符,VINTR代表发送ctrl + C中断信号,ctrl + c的ASCII码为3

例如:term.c_cc[VINTR] = '\t';意思为将tab键设置为终端信号

tcsetattr中,第二个参数说明,TCSAFLUSH:发送了所有输出后更改才生效,在更改发生时,未读取的所有输入数据都被删除

TCSANOW:更改立即生效

TCSADRAIN:发送了所有输出后更改才发生,如果更改输出参数则应该使用该选项

*/

term.c_cc[VERASE] = '\b';//'\b'为退格键的ASCII码

if (tcsetattr(STDIN_FILENO, TCSANOW, &term) == -1)//设置系统termion

{

printf("tcsetattr error is %s\n", strerror(errno));

}

return;

}

void setstty()//设置输入退格键,不回显

{

system("stty erase ^H");//执行shell命令,也可以 用来设置读取用户键盘输入的时候,退格键不回显

}

void returnstty()//恢复系统的termios设置

{

if (tcsetattr(STDIN_FILENO, TCSAFLUSH, &oldterm) == -1)//设置系统termion

{

printf("tcsetattr error is %s\n", strerror(errno));

}

return;

}

接着我们来看看预处理api 请看

mysql api---从一个小例子开始mysql编程入门(4)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值