MySQL 增加、更新、删除

   日期:2020-06-03     浏览:74    评论:0    
核心提示:文章目录1. 增加 INSERT2. 更新 UPDATE3. 删除 DELETE练习 LeetCode 196. 删除重复的电子邮箱学习自 廖雪峰的官方网站1. 增加 INSERT添加一条记录INSERT INTO <表名> (字段1, 字段2, ...) VALUES (值1, 值2, ...);INSERT INTO students (class_id, name, gender, score) VALUES (2, 大牛, M, 80);没有列出id字段

文章目录

    • 1. 增加 INSERT
    • 2. 更新 UPDATe
    • 3. 删除 DELETE
    • 练习 LeetCode 196. 删除重复的电子邮箱

学习自 廖雪峰的官方网站

1. 增加 INSERT

  • 添加一条记录
INSERT INTO <表名> (字段1, 字段2, ...) VALUES (1,2, ...);

INSERT INTO students (class_id, name, gender, score) VALUES (2, '大牛', 'M', 80);

  • 没有列出id字段,因为id字段是一个自增主键,由数据库自己推算

  • 如果一个字段有默认值,那么在INSERT语句中可以不出现

  • 字段顺序随意,前后两个()内一一对应即可,如 INSERT INTO students (score, gender, name, class_id) …,对应的VALUES变成(80, 'M', '大牛', 2)

  • 一次添加多条记录,在VALUES子句中指定多个记录值,每个记录是由(...)包含的一组值

INSERT INTO students (class_id, name, gender, score) VALUES
  (1, '大宝', 'M', 87),
  (2, '二宝', 'M', 81);

2. 更新 UPDATE

  • 更新一条记录
UPDATE <表名> SET 字段1=1, 字段2=2, ... WHERe ...;

UPDATE students SET name='大牛', score=66 WHERe id=1;
把id=1的人的名字和得分改掉
  • 更新多条记录
UPDATE students SET name='小牛', score=77 WHERe id>=5 AND id<=7;
  • 使用表达式更新
UPDATE students SET score=score+10 WHERe score<80;
得分小于80的,都加10
  • 如果where没有匹配到行,不报错,无操作
  • 操作时,如果没有where子句,会对整张表操作,小心

3. 删除 DELETE

DELETE FROM <表名> WHERe ...;

DELETe FROM students WHERe id=1;
删除 id=1 的学生
DELETe FROM students WHERe id>=5 AND id<=7;
删除 多个学生
  • 如果where没有匹配到行,不报错,无操作
  • 操作时,如果没有where子句,会删除整张表,小心

练习 LeetCode 196. 删除重复的电子邮箱

题目:

编写一个 SQL 查询,来删除 Person 表中所有重复的电子邮箱,重复的邮箱里只保留 Id 最小 的那个。

+----+------------------+
| Id | Email            |
+----+------------------+
| 1  | john@example.com |
| 2  | bob@example.com  |
| 3  | john@example.com |
+----+------------------+
Id 是这个表的主键。
例如,在运行你的查询语句之后,上面的 Person 表应返回以下几行:
+----+------------------+
| Id | Email            |
+----+------------------+
| 1  | john@example.com |
| 2  | bob@example.com  |
+----+------------------+
提示:
执行 SQL 之后,输出是整个 Person 表。
使用 delete 语句。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/delete-duplicate-emails
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

解题:

自连接比对
# Write your MySQL query statement below
DELETE p1 FROM Person p1, Person p2 
WHERe p1.Email = p2.Email AND p1.Id > p2.Id;

1436 ms

# Write your MySQL query statement below
DELETe FROM Person
WHERe Id NOT IN
(
    SELECt Id FROM 
    (
        SELECt MIN(Id) Id FROM Person GROUP BY Email
    ) tempTableName
);

1169 ms

 
打赏
 本文转载自:网络 
所有权利归属于原作者,如文章来源标示错误或侵犯了您的权利请联系微信13520258486
更多>最近资讯中心
更多>最新资讯中心
0相关评论

推荐图文
推荐资讯中心
点击排行
最新信息
新手指南
采购商服务
供应商服务
交易安全
关注我们
手机网站:
新浪微博:
微信关注:

13520258486

周一至周五 9:00-18:00
(其他时间联系在线客服)

24小时在线客服