MySQL数据的管理(增、删、改)

在项目开发时,对数据的操作是必不可少的。
例如,插入数据、查询数据、更新数据以及删除数据。
接下来就开始讲解如何对存储在数据库中的数据进行管理。
插入记录
在对数据库进行管理时,若想要操作数据,需要先保证数据表中存在数据。MySQL 使用 INSERT 语句向数据表中添加数据,其基本语法格式如下:
在这里插入图片描述
在上述语法格式中,“字段名1,字段名2,……”表示数据表中的字段名称,此处既可以是表中所有字段的名称也可以是表中指定字段的名称;“值1,值2,……”表示每个字段的值,每个值的顺序与类型必须与其对应的字段相互匹配。其中,若一次插入多条记录,各个记录值列表之间以逗号“,”分隔即可。
为了便于掌握,下面以操作内容管理系统的栏目表 cms_category 为例,演示插入记录的各种使用方法。
插入记录——为所有字段插入记录
在MySQL中,为所有字段插入记录时,有两种写法,一是在插入时带上字段列表,另一种是省略字段列表,具体SQL语句如下。
① 带字段列表
在这里插入图片描述
在上述字段列表中字段名称的书写顺序可以随意更改,只要保证值列表中的数据与其相对应即可。例如,上述SQL语句也可以改成如下形式。
在这里插入图片描述
② 省略字段列表
在这里插入图片描述
当省略字段列表执行插入操作时,则必须严格按照数据表定义字段时的顺序,在值列表中为字段指定相应的数据。
执行以上两种SQL语句,运行结果如图所示。
在这里插入图片描述
插入记录——为指定字段插入记录
在数据表 cms_category 中,id 字段是一个自动增加的整数,因此在执行时可以不对其进行插入操作,具体 SQL 语句如下:
在这里插入图片描述
为了查看已添加的数据,以及 id 字段值的变化,可以使用 SELECT 语句查看数据表中的所有记录,具体 SQL 语句如下:
在这里插入图片描述
在上述SQL语句中,“*”表示查询数据表中的所有字段,关于 SELECT 查询语句的相关知识将会在后面的任务中进行讲解,这里简单了解即可。SQL 语句执行后,结果如图所示。
在这里插入图片描述
除了上述的方式外,在 MySQL 中,INSERT 语句还有一种语法格式,可以为表中指定的字段或者全部字段添加数据,其语法格式如下:
在这里插入图片描述
在上述的语法格式中,“字段名1”、“字段名2”表示待添加数据的字段名称,“值1”、“值2”表示添加的数据。若在 SET 关键字后,为表中多个字段指定数据,每对“字段名=值”之间使用逗号(,)分隔。具体示例如下:
在这里插入图片描述
插入记录——同时添加多条记录
对于需要同时添加多条记录而言,按照以上两种方式逐条添加数据非常麻烦。因此,可以使用一条INSERT语句添加多行记录,具体 SQL 语句如下:
在这里插入图片描述
在上述语句中,由于省略了字段列表,因此添加数据时,需要按照表的定义顺序插入。其中,id 字段是自动增长的字段,如果使用 NULL 值,MySQL 会自动为其填入一个值。执行 SQL 语句后,使用 SELECT 查询的结果如图所示。
在这里插入图片描述
修改记录
修改记录是数据库中常见的操作。例如,栏目表中的分类变更名称,就需要对其记录中的 name 字段值进行修改。MySQL 中使用 UPDATE 语句来更新表中的记录,其语法格式如下所示:
在这里插入图片描述
上述语法格式中,“字段名1”,“字段名2”用于指定待更新的字段名称,“值1”,“值2”用于设置字段更新后的新值;“WHERE条件表达式”是可选的,用于指定哪些记录需要被更新。否则,数据表中的所有记录都将被更新。
下面以操作内容管理系统的栏目数据表 cms_category 为例,演示有条件更新记录和无条件更新记录的使用。
修改记录——有条件更新数据
有条件更新记录,就是利用 WHERE 子句来指定更新表中的某一条或者某几条记录。例如,修改表 cms_category 中 id=7 的记录,将其 name 字段的值更改为“生活”,具体 SQL 语句如下:
在这里插入图片描述
从 SELECT 查询结果可以看出,利用 UPDATE 修改记录成功,如图所示。需要注意的是,如果表中有多条记录满足WHERE子句中的条件表达式,则满足条件的记录都会发生更新。
在这里插入图片描述
修改记录——无条件更新数据
在执行 UPDATE 语句时,若没有使用 WHERE 子句,则会更新表中所有记录的指定字段。例如,修改表 cms_category 的排序字段 sort,将表中所有记录的字段值都更新为 50,具体 SQL 语句如下:
在这里插入图片描述
从 SELECT 查询结果可以看出,利用 UPDATE 修改所有记录成功,如图所示。
在这里插入图片描述
删除记录
在数据库中,若有些数据已经失去意义或者错误时,就需要将它们删除。此时,可以使用 MySQL 中提供的 DELETE 语句来删除表中的记录,其语法格式如下所示:
在这里插入图片描述
在上面的语法格式中,“表名”指的是待执行删除操作的表,WHERE 子句为可选参数,用于指定删除的条件,满足条件的记录才会被删除。
下面以操作内容管理系统的栏目数据表 cms_category 为例,演示删除部分数据和删除全部数据的使用。
删除记录——删除部分数据
删除部分数据是指根据 WHERE 子句指定的判断条件,删除表中符合要求的一条或者某几条记录。例如,删除 cms_category 表中 pid=1 的记录,具体 SQL 语句如下:
在这里插入图片描述
从执行结果可以看出,成功的删除了 5 条记录,利用 SELECT 语句查看执行后的结果如图所示。
在这里插入图片描述
删除记录——删除全部数据
删除全部数据就是在 MySQL 数据库中执行 DELETE 操作时,不设置WHERE 子句判断条件。例如,删除 cms_category 表中所有的记录,具体SQL 语句如下:
在这里插入图片描述
从SELECT 查询结果可以看到记录为空,说明表中所有的记录都被成功删除,如图所示。需要注意的是,在实际开发中要慎重执行删除全部数据的操作,因为数据一旦被删除,就不可被恢复。
在这里插入图片描述
除此之外,在 MySQL 数据库中,还有一种方式可以用来删除表中所有的记录,这种方式需要用到一个关键字 TRUNCATE,其语法格式如下:
在这里插入图片描述
示例:通过“表名”指定要清空的表,具体如下。
在这里插入图片描述
对于同样用于删除数据表的操作,TRUNCATE 关键字与 DELETE 语句也有一定的区别,具体如下:
1.DELETE语句是DML语句,TRUNCATE语句通常被认为是DDL语句。
2.DELETE语句后面可以跟WHERE子句,通过指定WHERE子句中的条件表达式只删除满足条件的部分记录,而TRUNCATE语句只能用于清空表中的所有记录。
3.使用TRUNCATE语句删除表中的数据后,再次向表中添加记录时,自动增加字段的默认初始值重新由1开始,而使用DELETE语句删除表中的记录时,不影响自动增长值。

#include <stdio.h> #include "string.h" int N,i; FILE *fp; struct student {char num[10]; char name[8]; char sex[5]; int age; char addr[15]; int score; }stu[100]; void input() /*输入学生数据的资料*/ {printf("Input the student data %d:\n",i+1); /*输入一个学生的数据*/ printf("NO.:"); scanf("%s",stu[i].num); /*输入号数*/ printf("name:"); scanf("%s",stu[i].name); /*姓名*/ printf("sex:"); scanf("%s",stu[i].sex); /*性别*/ printf("age:"); scanf("%d",&stu[i].age); /*年龄*/ printf("address:"); scanf("%s",stu[i].addr); /*家庭地址*/ printf("score:"); scanf("%d",&stu[i].score); /*分数*/ printf("\n"); } void add() /*在ouru的文件后添加学生数据*/ { if((fp=fopen("ouru","ab"))==NULL) /*以读写的二进制形式打开ouru文件*/ {printf("Cann't open the file\n"); return;} printf("How many data do you want:"); /*输入需要添加几个学生的数据和具体的资料*/ scanf("%d",&N); for(i=0;i<N;i++) /*向ouru文件中加入添加学生的数据的个数*/ input(); for(i=0;i<N;i++) if(fwrite(&stu[i],sizeof(struct student),1,fp)!=1) printf("File error\n"); fclose(fp); } void save() /*保存学生的数据到ouru文件中*/ { int i; if((fp=fopen("ouru","wb"))==NULL) /*打开ouru文件*/ {printf("Cann't open the file\n"); return;} for(i=0;i<N;i++) /*把学生的数据写入到ouru 文件中*/ if(fwrite(&stu[i],sizeof(struct student),1,fp)!=1) printf("File write error\n"); fclose(fp); } void insert() /*在ouru文件中插入学生的数据*/ {char positions[10]; int a,b; if((fp=fopen("ouru","r+"))==NULL) /*以读写打开ouru文件*/ {printf("Can not open file!"); return;} for(i=0;(fread(&stu[i],sizeof(struct student),1,fp))!=0;i++); /*读取文件并计算文件中有多少个学生的数据*/ printf("Which position do you want to insert:"); scanf("%s",positions); for(a=0;a<i;a++) /*确定插入的位置*/ if(strcmp(positions,stu[a].num)==0)break; a=a+1; fseek(fp,sizeof(struct student)*(a+1),0); /*将指针指向要插入位置的后一位*/ for(b=a;b<i;b++) fwrite(&stu[b],sizeof(struct student),1,fp); /*将插入后的学生数据向后移动一位*/ i=a; input(); fseek(fp,sizeof(struct student)*a,0); /*将指针指向要插入的位置*/ fwrite(&stu[a],sizeof(struct student),1,fp); /*将插入的数据保存到ouru文件里*/ fclose(fp);} void change() /*修ouru文件中的某个学生的数据*/ { char positions[10]; if((fp=fopen("ouru","rb+"))==NULL) /*以读写打开二进制ouru文件*/ {printf("Can not open the file\n"); return;} printf("What data do you want to modify:"); /*输入要修学生的号码*/ scanf("%s",positions); for(i=0;(fread(&stu[i],sizeof(struct student),1,fp))!=0;i++) /*找出要修数据*/ if(strcmp(stu[i].num,positions)==0) {fseek(fp,sizeof(struct student)*i,0); /*将指针指向要修的资料*/ input(); fwrite(&stu[i],sizeof(struct student),1,fp); /*将修数据保存*/ break;} fclose(fp); } void del() /*除ouru中的某个学生的数据*/ {int a,b,f; char positions[10]; if((fp=fopen("ouru","rb+"))==NULL) /*以读写打开ouru文件*/ {printf("Can not open file!"); return;} printf("Input the deleted number:"); /*输入要除的学生号码*/ scanf("%s",positions); for(i=0;fread(&stu[i],sizeof(struct student),1,fp)!=0;i++); /*查找文件中有多少个学生的数据*/ f=i; for(a=0;a<i;a++) /*找出要除的学生的数据并把后面的数据全都向前移一位*/ {if(strcmp(positions,stu[a].num)==0) { for(b=a;b<i;b++) {strcpy(stu[b].num,stu[b+1].num); strcpy(stu[b].name,stu[b+1].name); strcpy(stu[b].sex,stu[b+1].sex); stu[b].age=stu[b+1].age; strcpy(stu[b].addr,stu[b+1].addr); stu[b].score=stu[b+1].score;} f=f-1; break;} } fclose(fp); fopen("ouru","w"); /*将除后的结果保存到ouru文件里*/ for(a=0;a<f;a++) fwrite(&stu[a],sizeof(struct student),1,fp); fclose(fp);} void examine() /*查看ouru文件中的资料*/ {int i; if((fp=fopen("ouru","r"))==NULL) /*以只读的方式打开ouru文件*/ {printf("Cannot open the file\n"); return;} printf("\n"); printf("num name sex age addr score\n"); /*读取各个学生数据的同时把它们显示出来*/ for(i=0;(fread(&stu[i],sizeof(struct student),1,fp))!=0;i++) {printf("%-10s%-10s%-8s%-9d%-17s%d\n",stu[i].num,stu[i].name,stu[i].sex,stu[i].age,stu[i].addr,stu[i].score);} printf("\n"); fclose(fp); } main() {int choose; /*显示主界面*/ printf("********************************************************************************\n"); printf("--------------------------------------------------------------------------------\n\n"); printf(" Welcome to the student system\n"); printf(" Producer:ouru\tRegistration number:03011123\n"); printf("\n\n--------------------------------------------------------------------------------\n"); printf("********************************************************************************\n"); printf("Please the choice:\n"); printf("\t\t\t1. Input the student data\n"); printf("\t\t\t2. Add the new studetn data\n"); printf("\t\t\t3. Change a data\n"); printf("\t\t\t4. Insert a new data\n"); printf("\t\t\t5. Delete the student data\n"); printf("\t\t\t6. Manifestation student data\n"); printf("\t\t\t7. Main menu\n"); printf("\t\t\t8. exit\n\n\n"); scanf("%d",&choose); /*选择想要操作的选项*/ while(choose!=8) /*当选择8的时候不再循环并退出*/ { switch(choose) {case 1:printf("Please input the student total:"); /*当choose为下面的数时执行相应的功能*/ scanf("%d",&N); for(i=0;i<N;i++) input(); save();break; case 2:add();break; case 3:change();break; case 4:insert();break; case 5:del();break; case 6:examine();break; case 7:printf("\n\n\nPlease the choice:\n"); printf("\t\t\t1. Input the student data\n"); printf("\t\t\t2. Add the new studetn data\n"); printf("\t\t\t3. Change a data\n"); printf("\t\t\t4. Insert a new data\n"); printf("\t\t\t5. Delete the student data\n"); printf("\t\t\t6. Manifestation student data\n"); printf("\t\t\t7. Main menu\n"); printf("\t\t\t8. exit\n\n\n");break; default :printf("error\n");} scanf("%d",&choose); } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值