在MySQL中可以使用INSERTINTO语句向数据库已有的表中插入一行或者多行元组数据。
语法格式:
表名:指定被操作的表名。
列名:指定需要插入数据的列名。若向表中的所有列插入数据,则全部的列名均可以省略,直接采用INSERTVALUES(…)即可。
VALUE子句:该子句包含要插入的数据清单。数据清单中数据的顺序要和列的顺序相对应。
示例:在tb_courses表中插入一条新记录,course_id值为1,course_name值为“Network”,course_grade值为3,info值为“ComputerNetwork”。
在执行插入操作之前,查看tb_courses表
说明:
INSERT语句后面的列名称顺序可以不是tb_courses表定义时的顺序,即插入数据时,不需要按照表定义的顺序插入,只要保证值的顺序与列字段的顺序相同就可以。
使用INSERT插入数据时,允许列名称列表column_list为空,此时值列表中需要为表的每一个字段指定值,并且值的顺序必须和数据表中字段定义时的顺序相同。
注意:虽然使用INSERT插入数据时可以忽略插入数据的列名称,若值不包含列名称,则VALUES关键字后面的值不仅要求完整,而且顺序必须和表定义时列的顺序相同。如果表的结构被修改,对列进行增加、删除或者位置改变操作,这些操作将使得用这种方式插入数据时的顺序也同时改变。如果指定列名称,就不会受到表结构改变的影响。
数据库删除数据
在MySQL中,可以使用DELETE语句来删除表的一行或者多行数据。
语法格式为:
表名:指定要删除数据的表名。
ORDERBY子句:可选项。表示删除时,表中各行将按照子句中指定的顺序进行删除。
WHERE子句:可选项。表示为删除操作限定删除条件,若省略该子句,则代表删除该表中的所有行。
LIMIT子句:可选项。用于告知服务器在控制命令被返回到客户端前被删除行的最大值。
注意:在不使用WHERE条件的时候,将删除所有数据。
示例1:删除表中的全部数据
删除tb_courses_new表中的全部数据,输入的SQL语句和执行结果如下所示。
在tb_courses_new表中,删除course_id为4的记录,输入的SQL语句和执行结果如下所示。
数据库修改数据
在MySQL中,可以使用UPDATE语句来修改、更新一个或多个表的数据。
表名:用于指定要更新的表名称。
SET子句:用于指定表中要修改的列名及其列值。其中,每个指定的列值可以是表达式,也可以是该列对应的默认值。如果指定的是默认值,可用关键字DEFAULT表示列值。
WHERE子句:可选项。用于限定表中要修改的行。若不指定,则修改表中所有的行。
ORDERBY子句:可选项。用于限定表中的行被修改的次序。
LIMIT子句:可选项。用于限定被修改的行数。
注意:修改一行数据的多个列值时,SET子句的每个值用逗号分开即可。
示例1:修改表中的数据
在tb_courses_new表中,更新所有行的course_grade字段值为4,输入的SQL语句和执行结果如下所示。
在tb_courses表中,更新course_id值为2的记录,将course_grade字段值改为3.5,将course_name字段值改为“DB”,输入的SQL语句和执行结果如下所示。
数据库查询数据
在MySQL中,可以使用SELECT语句来查询数据。查询数据是指从数据库中根据需求,使用不同的查询方式来获取不同的数据,是使用频率最高、最重要的操作。
SELECT的语法格式如下:
{*|}包含星号通配符的字段列表,表示所要查询字段的名称。
WHERE是可选项,如果选择该项,将限定查询数据必须满足该查询条件。
GROUPBY,该子句告诉MySQL如何显示查询出来的数据,并按照指定的字段分组。
[ORDERBY],该子句告诉MySQL按什么样的顺序显示查询出来的数据,可以进行的排序有升序(ASC)和降序(DESC),默认情况下是升序。
[LIMIT[,]],该子句告诉MySQL每次显示查询出来的数据条数。
下面先介绍一些简单的SELECT语句,关于WHERE、GROUPBY、ORDERBY和LIMIT等限制条件就不细说了。
1、查询表中所有字段
查询所有字段是指查询表中所有字段的数据。MySQL提供了以下2种方式查询表中的所有字段。
SELECT可以使用“*”查找表中所有字段的数据,语法格式如下:
示例:从tb_students_info表中查询所有字段的数据,SQL语句和运行结果如下所示。
2、查询表中指定的字段
查询表中的某一个字段的语法格式为:
查询tb_students_info表中name列所有学生的姓名,SQL语句和运行结果如下所示。
从tb_students_info表中获取id、name和height三列,SQL语句和运行结果如下所示。