/*
============================================================================
Name : mysql1.c
Author : suys
Version :
Copyright : Your copyright notice
Description : Link to mysql in C, Ansi-style
============================================================================
*/ #include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <errno.h>
#include <termios.h>
#include <mysql/mysql.h> #define BUFSIZE 1024 MYSQL mysql, *conn;
//删除函数
void deletename(char *SQL)
{
memset(SQL, , BUFSIZE);
sprintf(SQL, "%s", "请输入要干掉的名字>:");
write(STDOUT_FILENO, SQL, strlen(SQL)); //这句话替代printf函数,这样写就不需要\n也能相输出屏幕输出
char name[];
memset(name, , sizeof(name));
read(STDIN_FILENO, name, sizeof(name)); //等待用户输入要删除的名字
name[strlen(name) - ] = ; //将字符串最后一位\n替换为0,最后放的整数0而不是字符串'0' memset(SQL, , BUFSIZE);
sprintf(SQL, "DELETE FROM table1 WHERE name = '%s'", name);
printf("%s\n", SQL);
} //插入数据函数
void insertname(char *SQL)
{
memset(SQL, , BUFSIZE);
sprintf(SQL, "%s", "请输入要插入的名字>:");
write(STDOUT_FILENO, SQL, strlen(SQL)); //这句话替代printf函数,这样写就不需要\n也能相输出屏幕输出
char name[];
memset(name, , sizeof(name));
read(STDIN_FILENO, name, sizeof(name)); //等待用户输入要删除的名字
name[strlen(name) - ] = ; //将字符串最后一位\n替换为0,最后放的整数0而不是字符串'0' memset(SQL, , BUFSIZE);
sprintf(SQL, "%s", "请输入要插入的性别>:");
write(STDOUT_FILENO, SQL, strlen(SQL)); //这句话替代printf函数,这样写就不需要\n也能相输出屏幕输出
char sex[];
memset(sex, , sizeof(sex));
read(STDIN_FILENO, sex, sizeof(sex)); //等待用户输入要删除的名字
sex[strlen(sex) - ] = ; //将字符串最后一位\n替换为0,最后放的整数0而不是字符串'0' memset(SQL, , BUFSIZE);
sprintf(SQL, "%s", "请输入要插入的年龄>:");
write(STDOUT_FILENO, SQL, strlen(SQL)); //这句话替代printf函数,这样写就不需要\n也能相输出屏幕输出
char age[];
memset(age, , sizeof(age));
read(STDIN_FILENO, age, sizeof(age)); //等待用户输入要删除的名字
age[strlen(age) - ] = ; //将字符串最后一位\n替换为0,最后放的整数0而不是字符串'0' memset(SQL, , BUFSIZE);
sprintf(SQL, "%s", "请输入要插入的班级>:");
write(STDOUT_FILENO, SQL, strlen(SQL)); //这句话替代printf函数,这样写就不需要\n也能相输出屏幕输出
char classes[];
memset(classes, , sizeof(classes));
read(STDIN_FILENO, classes, sizeof(classes)); //等待用户输入要删除的名字
classes[strlen(classes) - ] = ; //将字符串最后一位\n替换为0,最后放的整数0而不是字符串'0' memset(SQL, , BUFSIZE);
sprintf(SQL, "INSERT INTO table1 (name, sex, age, class) VALUES ('%s', '%s', %s, %s)", name, sex, age, classes);
printf("%s\n", SQL);
} //更新数据函数
void updatename(char *SQL)
{
memset(SQL, , BUFSIZE);
sprintf(SQL, "%s", "请输入要修改的名字>:");
write(STDOUT_FILENO, SQL, strlen(SQL)); //这句话替代printf函数,这样写就不需要\n也能相输出屏幕输出
char name[];
memset(name, , sizeof(name));
read(STDIN_FILENO, name, sizeof(name)); //等待用户输入要删除的名字
name[strlen(name) - ] = ; //将字符串最后一位\n替换为0,最后放的整数0而不是字符串'0' memset(SQL, , BUFSIZE);
sprintf(SQL, "%s", "请输入修改后的性别>:");
write(STDOUT_FILENO, SQL, strlen(SQL)); //这句话替代printf函数,这样写就不需要\n也能相输出屏幕输出
char sex[];
memset(sex, , sizeof(sex));
read(STDIN_FILENO, sex, sizeof(sex)); //等待用户输入要删除的名字
sex[strlen(sex) - ] = ; //将字符串最后一位\n替换为0,最后放的整数0而不是字符串'0' memset(SQL, , BUFSIZE);
sprintf(SQL, "%s", "请输入修改后的年龄>:");
write(STDOUT_FILENO, SQL, strlen(SQL)); //这句话替代printf函数,这样写就不需要\n也能相输出屏幕输出
char age[];
memset(age, , sizeof(age));
read(STDIN_FILENO, age, sizeof(age)); //等待用户输入要删除的名字
age[strlen(age) - ] = ; //将字符串最后一位\n替换为0,最后放的整数0而不是字符串'0' memset(SQL, , BUFSIZE);
sprintf(SQL, "%s", "请输入修改后的班级>:");
write(STDOUT_FILENO, SQL, strlen(SQL)); //这句话替代printf函数,这样写就不需要\n也能相输出屏幕输出
char classes[];
memset(classes, , sizeof(classes));
read(STDIN_FILENO, classes, sizeof(classes)); //等待用户输入要删除的名字
classes[strlen(classes) - ] = ; //将字符串最后一位\n替换为0,最后放的整数0而不是字符串'0' memset(SQL, , BUFSIZE);
sprintf(SQL, "UPDATE table1 SET sex = '%s', age = '%s', class = '%s' WHERE name = '%s'", sex, age, classes, name);
printf("%s\n", SQL);
} //查询
void selectname(const char *SQL)
{
if(mysql_query(conn, SQL) != )
{
printf("query error, %s\n", mysql_error(&mysql));
}
//调用mysql_store_result得到查询结果,结果放到MYSQL_RES 结构中
MYSQL_RES *result = mysql_store_result(conn);
//要知道返回数据集有多少列才能自由的使用SELECT语句
MYSQL_FIELD *field;
int iFieldCount = ; while()
{
field = mysql_fetch_field(result); //循环得到列名,如果循环到列的最后,函数返回NULL
if(field == NULL)
break;
printf("%s\t", field->name);
iFieldCount++;
}
printf("\n");
//循环遍历每一行
MYSQL_ROW row;
while()
{
row = mysql_fetch_row(result);
if(row == NULL)
break;
int i = ;
for(; i < iFieldCount; i++)
printf("%s\t", (const char *)row[i]);
printf("\n");
}
mysql_free_result(result);
} int main(int arg, char *args[])
{
if(arg < )
return -;
mysql_init(&mysql); //相当于SQL内部初始化了一个TCP的socket,同时初始化了SQL必须的内存 //连接到mysql server
conn = mysql_real_connect(&mysql, args[], args[], args[], args[], , , );
if(conn == NULL)
{
printf("connect error, %s\n", mysql_error(&mysql));
return -;
} if(mysql_query(conn, "SET NAMES utf8") != )
{
printf("设置字符集错误,%s\n", mysql_error(&mysql));
} char buf[BUFSIZE];
memset(buf, , sizeof(buf));
strcpy(buf, "请选择\n1:插入\n2:删除\n3:修改\n4:查询\n");
write(STDOUT_FILENO, buf, strlen(buf));
memset(buf, , sizeof(buf));
read(STDIN_FILENO, buf, sizeof(buf));
if(strncmp(buf, "", ) == ) //用户输入的4
{
memset(buf, , sizeof(buf));
strcpy(buf, "请输入任意的SELECT语句");
write(STDOUT_FILENO, buf, strlen(buf));
memset(buf, , sizeof(buf));
read(STDIN_FILENO, buf, sizeof(buf));
selectname(buf);
}
else
{
if(strncmp(buf, "", ) == ) //用户输入的1
{
insertname(buf);
}
if(strncmp(buf, "", ) == ) //用户输入的2
{
deletename(buf);
}
if(strncmp(buf, "", ) == ) //用户输入的3
{
updatename(buf);
} if(mysql_query(conn, buf) != )
{
printf("设置字符集错误,%s\n", mysql_error(&mysql));
} }
mysql_close(conn);
puts("Hello World\n");
return EXIT_SUCCESS;
}

linux c下mysql编程样例的更多相关文章

  1. 解决Linux系统下Mysql数据库中文显示成问号的问题

    当我们将开发好的javaWEB项目部署到linux系统上,操作数据库的时候,会出现中文乱码问题,比如做插入操作,发现添加到数据库的数据中文出现论码,下面就将解决linux下mysql中文乱码问题! 打 ...

  2. linux系统下MySQL表名区分大小写问题

    linux系统下MySQL表名区分大小写问题 https://www.cnblogs.com/jun1019/p/7073227.html [mysqld] lower_case_table_name ...

  3. LINUX系统下MySQL 压力测试工具super smack

    摘要:1.源文件下载地址:http://vegan.net/tony/supersmack/2.安装:注意在编译时,可以先把对应的libmysqlclient.so.*拷贝到/usr/lib3.测试: ...

  4. Linux系统下 MYSQL数据库中的数据库文件在本机内迁移 (需暂停服务的方式)

    Linux系统下 MYSQL数据库中的数据库文件在本机内迁移 本机采用Ubuntu16.04系统,tar方式安装MySQL5.7.21 数据库安装文件夹为    /home/devil/mysql 现 ...

  5. Linux - centos7 下 MySQL(mariadb) 和 主从复制

    目录 Linux - centos7 下 MySQL(mariadb) 和 主从复制 MySQL(mariadb) 安装MySQL(mariadb) 配置数据库的中文支持 在远程用 mysql客户端去 ...

  6. Linux系统环境下MySQL数据库源代码的安装

    Linux系统环境下MySQL数据库源代码的安装 基本环境:CentOS Linux release 7.8.2003 (Core).MySQL5.6 一.      安装环境准备 若要在Linux系 ...

  7. Kafka在Linux上安装部署及样例测试

    Kafka是一个分布式的.可分区的.可复制的消息系统.它提供了普通消息系统的功能,但具有自己独特的设计.这个独特的设计是什么样的呢 介绍 Kafka是一个分布式的.可分区的.可复制的消息系统.它提供了 ...

  8. linux centos7下 c++编程

    在Linux下与在windos下编程没啥区别,可以在windos上实现后,然后更改一些,移植到linux中 yum install gcc yum install gcc-c++ vi main.cp ...

  9. Linux(Ubuntu)下MySQL的安装与配置

    转自:http://www.2cto.com/database/201401/273423.html 在Linux下MySQL的安装,我一直觉得挺麻烦的,因为之前安装时就是由于复杂的配置导致有点晕.今 ...

随机推荐

  1. C# 字符串计算表达式

     C#  字符串计算表达式 string str="4+4+2.1"; 要的效果: double sum=4+4+2.1: 方案一: 动态计算表达式: 1 public class ...

  2. linux下svn的常用代码【转】

    转自:http://www.2cto.com/os/201205/130192.html 1.将文件checkout到本地目录 svn checkout path(path是服务器上的目录)    例 ...

  3. 【分享】Maven插件的源码下载(SVN)

    偶然的情况下找到了Maven插件源码的网址,现分享下 http://svn.apache.org/repos/asf/maven/plugins/ 可以使用SVN下载,在添加新的资源路径时,把上面的网 ...

  4. 寻找最小的k个数

    1. 能想到的最直接的办法,就是对数组进行排序,最好的排序算法的时间复杂性为O(n*logn),这一个方法请参照各种排序算法. 2. 另外申请一个k空间数组,依次更改里面的最大值,每做一次最多要扫描一 ...

  5. ACdream 1726 A Math game (dfs+二分)

    http://acdream.info/problem?pid=1726 官方题解:http://acdream.info/topic?tid=4246 求n个数里面能不能选一些数出来让它们的和等于k ...

  6. 部署新浪SAE web.py Session及图片上传等问题注意事项

    1.以下几条代码解决编码问题 import sysreload(sys)sys.setdefaultencoding('utf-8') 2.图片上传问题 需要开通sina的Storage服务,随便建个 ...

  7. HDU 1244 Max Sum Plus Plus Plus

    虽然这道题看起来和 HDU 1024  Max Sum Plus Plus 看起来很像,可是感觉这道题比1024要简单一些 前面WA了几次,因为我开始把dp[22][maxn]写成dp[maxn][2 ...

  8. 浅谈 Scala 中下划线的用途

    Scala 作为一门函数式编程语言,对习惯了指令式编程语言的同学来说,会不大习惯,这里除了思维方式之外,还有语法层面的,比如 underscore(下划线)就会出现在多种场合,令初学者相当疑惑,今天就 ...

  9. C实现类封装、继承、多态

    1.  概述 C语言是一种面向过程的程序设计语言,而C++是在C语言基础上衍生来了的面向对象的语言,实际上,很多C++实现的底层是用C语言实现的,如在Visual C++中的Interface其实就是 ...

  10. spring、springmvc、mybatis整合笔记

    这段时间上一个项目刚做完,下一个项目还没开始,趁这个时候来认真总结一下上个项目使用的ssm开发框架.由于,项目中关于使用ssm这部分的代码和配置是我们项目的整体架构师一个独立完成的,我们只负责业务部分 ...