MySQL数据表的数据操作

一、 插入数据

1.插入单个记录 语句格式

INSERT INTO <表名> (\<属性列1\>\[,\<属性列2 \>...) VALUES (<常量1> ,\<常量2\> ... )

注意:

(1)INTO子句属性列的顺序可与表定义中的顺序不一致

(2)VALUES子句提供的值必须与INTO子句匹配

例:插入单个记录 -- 向student表中插入一条记录,所有字段都有值

INSERT INTO student VALUES('001242','张青','计算机','女','04-01-22',50,'三好生');

-- 向student表中插入一条记录,部分字段有值

INSERT INTO student(sno,sname,dept) VALUES('001243','李四','计算机');

  1. 插入多个记录

INSERT INTO <表名> (字段名,...)AS 子查询

-- 向stu表中一次插入多条记录

INSERT INTO stu SELECT sno,sname,sex,dept FROM student;

二、修改数据

UPDATE <表名> SET列名={表达式 | (子查询) },... WHERE \<条件表达式\> ;

注意:

(1)如果不选WHERE子句,则表中所有的行全被更新;

(2)如果选择了WHERE子句,则使WHERE 中条件表达式为真的行被更新。

例:把student表中的总学分加10。

UPDATE student SET totalcredit=totalcredit+10;

--把student表中姓名为"罗林琳"的学生的专业改为"计算机",备注改为"三好学生"。

UPDATE student SET dept='计算机',remarks='三好学生' WHERE sname='罗林琳';

三、删除数据

DELETE FROM <表名> WHERE \<条件表达式\> ;

WHERE子句 指定要删除的元组 缺省表示要删除表中的全部元组,表的定义仍在字典中。

例:删除student表中计算机系全体学生的记录。

DELETE FROM student WHERE dept='计算机';

--删除student表中的所有记录。

DELETE FROM student;

TRUNCATE TABLE语句

截断基本表,从表中删除所有的行,并且释放该表所使用的存储空间。 在使用TRUNCATE TABLE语句时,不能回退已删除的行。

例: 将表STUDENT删除,并释放其存储空间。

TRUNCATE TABLE STUDENT ;

补充:自增字段

AUTO_INCREMENT类型定义的字段默认值和步长均为1,每插入一条记录,该字段的值自动加1。 插入操作中,被AUTO_INCREMENT修饰的字段可以给空值或具体值。

CREATE TABLE stu (stu_id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY , sname VARCHAR(10) );

-- 自增型字段值的插入数据的方式 INSERT INTO stu VALUES(NULL,'张三'),(NULL,'李四'),(10,'王五');

相关推荐
唐青枫1 小时前
MySQL JSON 实战详解:从存储、查询、更新到 JSON_TABLE 与索引
sql·mysql
小满8782 小时前
5.Mysql事务隔离级别与锁机制
mysql
元Y亨H20 小时前
技术笔记:MySQL 字符集排序规则与大小写敏感性问题解决方案
mysql
这个DBA有点耶2 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构
掉头发的王富贵2 天前
【StarRocks】极限十分钟入门StarRocks
数据库·sql·mysql
SamDeepThinking2 天前
一条UPDATE语句在MySQL 8.0中到底加了几把锁?
后端·mysql·程序员
李白客4 天前
KES新版MySQL兼容能力再升级意味着什么?
mysql·国产数据库
Jim6006 天前
【吃透 MySQL InnoDB连载】第 1 章・解密线上数据库高频故障
mysql
GreatSQL6 天前
gt-checksum v4.0.0 新功能解读系列文章(4):SSL 加密连接——数据校验传输安全再升级
mysql