数据库 --> MySQL使用
MySQL使用
代码:
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h> //write头文件
#include <mysql/mysql.h>//包含MySQL头文件
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
void connect_mysql(MYSQL * mysql ,char * str[],MYSQL **connect);
void insert_mysql(MYSQL * mysql);
void delete_mysql(MYSQL * mysql);
void update_mysql(MYSQL * mysql);
void select_mysql(MYSQL * mysql,MYSQL **connect);
void show_table(MYSQL * mysql,MYSQL **connect);
void set_char(MYSQL * mysql);
void menu();
void quit(MYSQL **connect);
int main(int argc,char *argv[])
{
MYSQL mysql, *connect = NULL; char *str[] = {argv[],argv[],argv[]};
connect_mysql(&mysql,str,&connect);
menu();
quit(&connect);
return ;
}
void set_char(MYSQL *mysql)//设置数据库的字符集 要先做
{
int i = mysql_query(mysql,"set names utf8");//向mysql服务器端发送指令
//成功则返回0,失败则返回非0数据
if(i != )
{
printf("set char fail!!\n");
return;
} }
void select_mysql(MYSQL *mysql,MYSQL **connect)
{
if(!mysql)
return;
else{
write(,"Input select SQL:\n",strlen("Input select SQL:\n"));
char select_sql[];
int n=;
memset(select_sql,,sizeof(select_sql));
for(n;;n++)//读取标准输入直到;在去除;
{
select_sql[n]=getchar();
if(select_sql[n] == ';')
{
select_sql[n]=;
break;
}
}
char * SQL = select_sql;
int i = mysql_query(mysql,SQL);
if(i != )
{
printf("Update SQL fail %s \n",mysql_error(mysql));
return;
}else
printf("Update SQL success\n");
}
MYSQL_RES *res = mysql_store_result(mysql);//返回结果集放入MYSQL_RES中
int num_fields = mysql_num_fields(res);//查看结果集中行数 MYSQL_ROW row;
while((row = mysql_fetch_row(res)))//检索一个结果集合的下一行。当在mysql_store_result()之后使用时,
//没有更多的行可检索时,mysql_etch_row()返回NULL
{
int i;
for(i=;i<num_fields;i++)
{
printf("%s\n",row[i]); } }
mysql_free_result(res);//必须清空结果集########
} void show_table(MYSQL *mysql,MYSQL **connect)
{
int i = mysql_query(mysql,"show tables");
if(i != )
return;
else{
MYSQL_RES * result = mysql_store_result(*connect);
int num_fields = mysql_num_fields(result);
MYSQL_ROW row;
while((row = mysql_fetch_row(result)))
{
int i;
for(i=;i<num_fields;i++)
{
char *SQL;
sprintf(SQL,"desc %s",row[i]);
int n = mysql_query(mysql,SQL);
MYSQL_RES * res= mysql_store_result(*connect);
//可以调用mysql_fetch_row()来获取结果集中的行,或调用mysql_row_seek()
//和mysql_row_tell()来获取或设置结果集中的当前行位置。
//一旦完成了对结果集的操作,必须调用mysql_free_result()。
int table_num = mysql_num_fields(res);
MYSQL_ROW row1;
while((row1 = mysql_fetch_row(res)))
{
int j;
for(j=;j<table_num;j++)
{
printf("%s\n",row1[j]); }
}
mysql_free_result(res); } }
mysql_free_result(result);
} } void update_mysql(MYSQL *mysql)
{
if(!mysql)
return;
else{
write(,"Input update SQL:\n",strlen("Input update SQL:\n"));
char update_sql[];
int n=;
memset(update_sql,,sizeof(update_sql));
for(n;;n++)
{
update_sql[n]=getchar();
if(update_sql[n] == ';')
{
update_sql[n]=;
break;
}
}
char * SQL = update_sql;
int i = mysql_query(mysql,SQL);
if(i != )
{
printf("Update SQL fail %s \n",mysql_error(mysql));
return;
}else
printf("Update SQL success\n");
}
} void delete_mysql(MYSQL *mysql)
{
if(!mysql)
return;
else{
write(,"Input delete SQL:\n",strlen("Input delete SQL:\n"));
char delete_sql[];
int n=;
memset(delete_sql,,sizeof(delete_sql));
for(n;;n++)
{
delete_sql[n]=getchar();
if(delete_sql[n] == ';')
{
delete_sql[n]=;
break;
}
}
char * SQL = delete_sql;
int i = mysql_query(mysql,SQL);
if(i != )
{
printf("Delete SQL fail %s \n",mysql_error(mysql));
return;
}else
printf("Delete SQL success\n");
}
} void insert_mysql(MYSQL *mysql)
{
if(!mysql)
return;
else{
write(,"Input insert SQL:\n",strlen("Input insert SQL:\n"));
char insert_sql[];
int n=;
memset(insert_sql,,sizeof(insert_sql));
for(n;;n++)
{
insert_sql[n]=getchar();
if(insert_sql[n] == ';')
{
insert_sql[n]=;
break;
}
}
char * SQL = insert_sql;
int i = mysql_query(mysql,SQL);
if(i != )
{
printf("Insert SQL fail %s \n",mysql_error(mysql));
return;
}else
printf("Insert SQL success\n");
}
}
void connect_mysql(MYSQL *mysql,char *str[],MYSQL **connect)
{
char passwd[];
memset(passwd,,sizeof(passwd));
write(,"passwd:",strlen("passwd:"));
scanf("%s",passwd);
passwd[strlen(passwd)]=;
mysql_init(mysql);
*connect = mysql_real_connect(mysql,str[],str[],passwd,str[],,,);
if(*connect == NULL)
{
printf("Connect database fail! %s\n",mysql_error(mysql));
return;
}else{
printf("Connect success!\n");
} }
void quit(MYSQL **connect)
{
mysql_close(*connect);
*connect = NULL;
printf("Bye\n");
exit();
}
void menu()
{
printf("###########################\n");
printf(" A -> SELECT:\n");
printf(" B -> UPDATE:\n");
printf(" C -> DELETE:\n");
printf(" D -> INSERT:\n");
printf(" E -> DESC TABLE:\n");
printf(" Q -> QUIT:\n");
printf("###########################\n");
write(,"Input: ",strlen("Input: "));
}
1、找不到mysql.h,请安装
sudo apt-get install libmysqlclient-dev
2、编译不过,加 -lmysqlclient
参考:http://www.oschina.net/code/snippet_2325404_47438
数据库 --> MySQL使用的更多相关文章
- MYSQL添加新用户 MYSQL为用户创建数据库 MYSQL为新用户分配权限
1.新建用户 //登录MYSQL @>mysql -u root -p @>密码 //创建用户 mysql> insert into mysql.user(Host,User,Pas ...
- Robot Framework-DatabaseLibrary数据库(MySql)
Robot Framework-Mac版本安装 Robot Framework-Windows版本安装 Robot Framework-工具简介及入门使用 Robot Framework-Databa ...
- paip.导入数据英文音标到数据库mysql为空的问题之道解决原理
paip.导入数据英文音标到数据库mysql为空的问题之道解决原理 #---原因:mysql 导入工具的bug #---解决:使用双引号不个音标括起来. 作者 老哇的爪子 Attilax 艾龙, E ...
- paip.解决 数据库mysql增加列 字段很慢添加字段很慢
paip.解决 数据库mysql增加列 字段很慢添加字段很慢 #环境如下: mysql5.6 数据仅仅3w alter table xxx add column yyy int default ...
- Sqoop是一款开源的工具,主要用于在HADOOP(Hive)与传统的数据库(mysql、oracle...)间进行数据的传递
http://niuzhenxin.iteye.com/blog/1706203 Sqoop是一款开源的工具,主要用于在HADOOP(Hive)与传统的数据库(mysql.postgresql.. ...
- 数据库MySQL多个数据库服务冲突
一.目标名称 MySQL 二.目标版本 mysql-5.6.24-win32.1432006610.zip 三.环境信息 系统:windows 7 旗舰版 防火墙:关闭 —— 注意:如果防火墙不关闭 ...
- paip.将数据导入到在英语语音数据库mysql道路解决空原则问题
paip.将数据导入到在英语语音数据库mysql道路解决空原则问题 #---原因:mysql 导入工具bug #---解决:不要使用双引号括注音. 笔者 老哇爪 Attilax 艾龙. EMAIL: ...
- Yii Framework2.0开发教程(5)数据库mysql性能
继续<Yii Framework2.0开发教程(3)数据库mysql入门> 首先给予一定的尊重yii2数据库支持引进 Yii 基于 PHP's PDO一个成熟的数据库访问层的建立.它提供了 ...
- cpanel导入大数据库(mysql)的方法
phpmyadmin是一件很方便的在线管理MySQL数据库的工具,但对于较大的数据库的导出和导入却很容易出错.特别是导入工作,通常5M已经是它的极限了.这里,主要介绍一下如何通过cPanel导入大型的 ...
- 前端学习数据库MYSQL
这篇文章主要写了 1.数据库MYSQL 2.基本上会遇到的所有SQL语句 数据库可视化软件------Navicat 数据库里边存放的是表,表与表之间是有关联的,而且可以对表进行相关操作(增,删,改, ...
随机推荐
- FusionCharts封装-单系列图
ColumnChart.java: /** * @Title:ColumnChart.java * @Package:com.fusionchart.model * @Description:柱形图 ...
- ios学习笔记(一)Windows7上使用VMWare搭建iPhone开发环境
我们都知道开发iPhone等ios平台的移动应用时需要使用Mac本,但是Mac本都比较昂贵,所以我们可以采用Windows7上利用VMWare安装Mac操作系统的方法来模拟ios开发环境,达到降低成本 ...
- strcpy函数
不调用C/C++库函数,编写strcpy()函数. char * my_strcpy(char *strDest,const char *strSrc) { char *p=strDest; whil ...
- Error Code: 1318. Incorrect number of arguments for PROCEDURE student.new_procedure; expected 0, got
1.错误描述 13:58:20 call new_procedure('2000','zhangsan') Error Code: 1318. Incorrect number of argument ...
- jquery Dialog弹框插件
function Dialog(options) { var defaults = { // 默认值. title: '', // 标题文本,若不想显示title请通过CSS设置其display为no ...
- Struts2(三) 配置struts.xml的提示(在不联网的情况下)
开发过程中如果可以上网,struts.xml 会自动缓存dtd,提供提示功能.如果不能联网需要我们配置本地dtd,这样才能让struts2 产生提示 1.首先,在EClipse中依次点击工具栏中的wi ...
- 芝麻HTTP:Appium的安装
Appium是移动端的自动化测试工具,类似于前面所说的Selenium,利用它可以驱动Android.iOS等设备完成自动化测试,比如模拟点击.滑动.输入等操作,其官方网站为:http://appiu ...
- EF Core下利用Mysql进行数据存储在并发访问下的数据同步问题
小故事 在开始讲这篇文章之前,我们来说一个小故事,纯素虚构(真实的存钱逻辑并非如此) 小刘发工资后,赶忙拿着现金去银行,准备把钱存起来,而与此同时,小刘的老婆刘嫂知道小刘的品性,知道他发工资的日子,也 ...
- STM32f4 ARM Bootloader
参考资料: 基于ARM 的嵌入式系统Bootloader 启动流程分析 Bootloader 详解 ( 代码环境 | ARM 启动流程 | uboot 工作流程 | 架构设计) Android系统启动 ...
- WPF基础篇之连接数据库
WPF连接DB2数据库 public void ConnectionBD2Func() { //连接数据库字符串,DB2 9.5以下版本使用Data Source=Test,否则查询找不到数据库.DB ...