😀如果对你有帮助的话😊 🌺为博主点个赞吧 👍 👍点赞是对博主最大的鼓励😋 💓爱心发射~💓
一、增删改操作
SQL1-3 插入记录
SQL链接
插入记录的方式汇总:
- 普通插入(全字段):
INSERT INTO table_name VALUES (value1, value2, ...) - 普通插入(限定字段):
INSERT INTO table_name (column1, column2, ...) VALUES (value1, value2, ...) - 多条一次性插入:
INSERT INTO table_name (column1, column2, ...) VALUES (value1_1, value1_2, ...), (value2_1, value2_2, ...), ... - 从另一个表导入:
INSERT INTO table_name SELECT * FROM table_name2 [WHERE key=value]
1、SQL插入多行数据
考察INSERT INTO tab_name (col_name) VALUES
insert into exam_record values
(null, 1001, 9001,'2021-09-01 22:11:12','2021-09-01 23:01:12',90),
(null, 1002, 9002,'2021-09-04 07:01:02',null,null);
id 是自增主键(PRIMARY KEY)id 不写值的话,要在表后写明其他列名字id 可以为null ,自己会处理
2、备份到新表
考察INSERT INTO table_name SELECT * FROM table_name2 [WHERE key=value]
insert into exam_record_before_2021(uid,exam_id,start_time,submit_time,score)
select uid,exam_id,start_time,submit_time,score
from exam_record
where year(submit_time) < '2021'
id 自增主键不能复制- 用
start_time 查会出现错误 - 未完成的
submit_time 为空
3、插入表中可能存在的数据
方法一:replace into
replace into examination_info
values(null, 9003,'SQL','hard',90,'2021-01-01 00:00:00')
delete from examination_info
where exam_id = 9003;
insert into examination_info
values(null, 9003,'SQL','hard',90,'2021-01-01 00:00:00')
replace into 跟 insert into 功能类似,不同点在于:replace into 首先尝试插入数据到表中,
- 如果发现表中已经有此行数据(根据主键或者唯一索引判断)则先删除此行数据,然后插入新的数据;
- 否则,直接插入新数据。
SQL4-5 更新记录
SQL链接
修改记录的方式汇总:
- 设置为新值:
UPDATE table_name SET column_name=new_value [, column_name2=new_value2] [WHERE column_name3=value3] - 根据已有值替换:
UPDATE table_name SET key1=replace(key1, '查找内容', '替换成内容') [WHERE column_name3=value3]
4、tag为PYTHON的tag字段全部修改为Python
update examination_info
set tag = 'Python'
where tag = 'PYTHON';
update examination_info
set tag = replace(tag, 'PYTHON','Python')
where tag = 'PYTHON';
第二种方式不仅可用于整体替换,还能做子串替换,例如要实现将tag中所有的PYTHON 替换为Python (如CPYTHON=>CPython),可写作:
UPDATE examination_info
SET tag = REPLACE(tag, "PYTHON", "Python")
WHERE tag LIKE "%PYTHON%";
5、将完成时间改为’2099-01-01 00:00:00’,分数改为0
update exam_record
set submit_time = '2099-01-01 00:00:00',score = 0
where start_time < '2021-09-01 00:00:00' and score is null;
SQL6-8 删除记录
SQL链接
删除记录的方式汇总:
- 根据条件删除
:DELETE FROM tb_name [WHERE options] [ [ ORDER BY fields ] LIMIT n ] - 全部删除(表清空,包含自增计数器重置):
TRUNCATE tb_name
6、删除表中作答时间小于5分钟整且分数不及格的记录
delete from exam_record
where timestampdiff(minute,start_time,submit_time )<5
and score < 60
知识点:
时间差: TIMESTAMPDIFF(interval, time_start, time_end) 可计算time_start-time_end 的时间差,单位以指定的interval 为准,常用可选:
SECOND 秒MINUTE 分钟(返回秒数差除以60的整数部分)HOUR 小时(返回秒数差除以3600的整数部分)DAY 天数(返回秒数差除以3600*24的整数部分)MONTH 月数YEAR 年数
7、删除表中未完成作答或作答时间小于5分钟整的记录中,开始作答时间最早的3条记录
delete from exam_record
where submit_time is null
or timestampdiff(minute,start_time,submit_time) < 5
order by start_time
limit 3;
order by 排序,默认升序limit 限制条件
8、删除表中所有记录,并重置自增主键
考察: 全部删除(表清空,包含自增计数器重置):TRUNCATE tb_name
truncate exam_record
二、表与索引操作
2.1、表的创建、修改与删除:
1.1 直接创建表:
CREATE TABLE
[IF NOT EXISTS] tb_name
(column_name1 data_type1
[ PRIMARY KEY
| FOREIGN KEY
| AUTO_INCREMENT
| COMMENT comment
| DEFAULT default_value
| UNIQUE
| NOT NULL
], ...
) [CHARACTER SET charset]
[COLLATE collate_value]
1.2 从另一张表复制表结构创建表: CREATE TABLE tb_name LIKE tb_name_old
1.3 从另一张表的查询结果创建表: CREATE TABLE tb_name AS SELECT * FROM tb_name_old WHERE options
2.1 修改表:ALTER TABLE 表名 修改选项 。选项集合:
{ ADD COLUMN <列名> <类型>
| CHANGE COLUMN <旧列名> <新列名> <新列类型>
| ALTER COLUMN <列名> { SET DEFAULT <默认值> | DROP DEFAULT }
| MODIFY COLUMN <列名> <类型>
| DROP COLUMN <列名>
| RENAME TO <新表名>
| CHARACTER SET <字符集名>
| COLLATE <校对规则名> }
3.1 删除表:DROP TABLE [IF EXISTS] 表名1 [ ,表名2]
SQL9-11 表的创建、修改与删除
SQL链接
9、创建一张新表
create table if not exists user_info_vip(
id int(11) not null primary key auto_increment comment '自增ID',
uid int(11) not null unique key comment '用户ID',
nick_name varchar(64) comment '昵称',
achievement int(11) default 0 comment '成就值',
level int(11) comment '用户等级',
job varchar(32) comment '职业方向',
register_time datetime default CURRENT_TIMESTAMP comment '注册时间'
)charset = utf8 collate utf8_general_ci;
知识点:
- 自增ID:
AUTO_INCREMENT ; - 设置主键:
PRIMARY KEY ; - 唯一性约束:
UNIQUE - 非空约束:
NOT NULL - 设置默认值:
DEFAULT 0 - 当前时间戳:
CURRENT_TIMESTAMP - 评论/注释:
COMMENT - 如果该表已创建过,正常返回:
IF NOT EXISTS
10、修改表
alter table user_info add school varchar(15) after level;
alter table user_info change job profession varchar(10);
alter table user_info modify achievement int(11) default 0;
知识点:
alter table 增加的表格 add 增加列的名称 数据类型 位置(after level 在level 之后)alter table user_info change 原列名 修改列名 修改数据类型alter table 表名 modify 修改列名称 数据类型 默认值等
11、删除表
drop table if exists exam_record_2011,exam_record_2012,exam_record_2013,exam_record_2014
2.2、索引的创建、删除
|