存储在系统中的数据是数据库管理系统(DBMS)的核心,数据库被设计用来管理数据的存储、访问和维护数据的完整性。MySQL提供了功能丰富的数据库管理语句,包括有效的向数据库插入数据的INSERT语句,更新数据的UPDATE语句以及当数据不再使用时删除数据的DELETE语句。
一、插入数据
在使用数据库之前,数据库中必须要有数据,MySQL中使用INSERT语句向数据库表中插入新的数据记录。可以插入的方式有:插入完整的记录、插入记录的一部分、插入多条记录、插入另一个查询的结果。
1.1 为表的所有字段插入数据
使用基本的INSERT语句插入数据,要求指定表名称和插入到新纪录的值。基本语法格式为:
INSERT INTO 表名(column_list) VALUES(value_list);
注意,使用该语句时字段列和数据值的数量必须相同。
INSERT语句后面的列名称可以不是表定义时的顺序。即插入数据时,不需要按照表定义的顺序插入,只要保证值的顺序与列字段的顺序相同就可以。
虽然使用INSERT插入数据时可以忽略插入数据的列名称,但是值如果不包含列名称,那VALUES关键字后面的值不仅要求完整而且顺序必须和表定义时列的顺序相同。如果表的结构被修改,对列进行增加、删除或者位置该表操作,这些操作将使得用这种方式插入数据时的顺序也同时改变。如果指定列名称,则不会受到表结构改变的影响。
1.2 为表的指定字段插入数据
为表的指定字段插入数据,就是在INSERT语句中只向部分字段插入值,而其它字段的值为表定义时的默认值。
要保证每个插入值的类型和对应列的数据类型匹配,如果类型不同,将无法插入,并且MySQL会产生错误。
1.3 同时插入多条记录
INSERT语句可以同时向数据表中插入多条记录,插入时指定多个值列表,每个值列表之间用逗号分隔开,基本语法格式如下:
INSERT INTO 表名(字段列) VALUES(数值列1),(数值列2),......,(数值列n)
使用INSERT同时插入多条记录时,MySQL会返回一些在执行单行插入时没有的额外信息,这些包含数的字符串的意思分别是:
(1)Recodes:表明插入的记录条数。
(2)Duplicates:表明插入时被忽略的记录,原因可能是这些记录包含了重复的主键值。
(3)Warnings:表明有问题的数据值,例如发生数据类型转换。
一个同时插入多行记录的INSERT语句等同于多个单行插入的INSERT语句,但是多行的INSERT语句在处理过程中,效率更高。因为MySQL执行单条INSERT语句插入多行数据,比使用多条INSERT语句快,所以在插入多条记录时,最好选择使用单条INSERT语句的方式插入。
1.4 将查询结果插入到表中
INSERT语句用来给数据表插入记录时,指定插入记录的列值。INSERT还可以将SELECT语句查询的结果插入到表中,如果想要把表2的数据合并到表1中,不需要把每一条记录的值一个一个输入,只需要使用一条INSERT语句和一条SELECT语句组成的组合语句,即可快速的从一个表或多个表向一个表中插入多个行。基本语法格式如下:
INSERT INTO 表1(字段名列表) SELECT (字段名列表) FROM 表2 WHERE 查询条件;
MySQL不关心SELECT返回的列名,它根据列的位置进行插入,SELECT的第1列对应待插入表的第1列,第2列对应待插入列的第2列等等。即使不同结果的表之间也可以方便的转移数据。
二、更新数据
表中有数据后,接下来可以对数据进行更新操作,MySQL中使用UPDATE语句更新表中的记录,可以更新特定的行或者同时更新所有的行。基本语法结构如下:
UPDATE 表名 SET 字段1=值1,字段2=值2,......,字段n=值n WHERE 条件
保证UPDATE语句以WHERE子句结束,通过WHERE子句指定被更新的记录所需要满足的条件,如果忽略WHERE子句,MySQL将更新表中所有的行。
三、删除数据
从数据表中删除数据使用DELETE语句,DELETE语句允许WHERE子句指定删除条件。DELETE语句基本语法格式如下:
DELETE FROM 表名 [WHERE 条件]
如果想删除表中的所有记录,还可以使用TRUNCATE TABLE语句,TRUNCATE将直接删除原来的表,并重新创建一个表,其语法结构为
TRUNCATE TABLE 表名
TRUNCATE直接删除表而不是删除记录,因此执行速度比DELETE快。