From 2de7db37de93f743d1c4271269dc309f227124d1 Mon Sep 17 00:00:00 2001 From: Mars Liu <mars.liu@outlook.com> Date: Tue, 24 May 2022 16:15:51 +0800 Subject: [PATCH] operator --- .../2.\344\277\256\346\224\271/config.json" | 4 +- .../2.\344\277\256\346\224\271/update.json" | 7 ++ .../2.\344\277\256\346\224\271/update.md" | 43 +++++++++ .../3.\345\210\240\351\231\244/config.json" | 4 +- .../3.\345\210\240\351\231\244/delete.json" | 7 ++ .../3.\345\210\240\351\231\244/delete.md" | 90 +++++++++++++++++++ .../1.SELECT/config.json" | 6 +- .../1.SELECT/select.json" | 7 ++ .../1.SELECT/select.md" | 43 +++++++++ .../2.WHERE/config.json" | 4 +- .../2.WHERE/where.json" | 7 ++ .../2.WHERE/where.md" | 64 +++++++++++++ .../config.json" | 9 +- .../geo.json" | 7 ++ .../geo.md" | 45 ++++++++++ gears/sql/goods.sql | 9 ++ gears/sql/orders.sql | 10 +++ gears/sql/points.sql | 5 ++ 18 files changed, 364 insertions(+), 7 deletions(-) create mode 100644 "data/1.MySQL\345\210\235\351\230\266/5.\346\225\260\346\215\256\344\277\256\346\224\271/2.\344\277\256\346\224\271/update.json" create mode 100644 "data/1.MySQL\345\210\235\351\230\266/5.\346\225\260\346\215\256\344\277\256\346\224\271/2.\344\277\256\346\224\271/update.md" create mode 100644 "data/1.MySQL\345\210\235\351\230\266/5.\346\225\260\346\215\256\344\277\256\346\224\271/3.\345\210\240\351\231\244/delete.json" create mode 100644 "data/1.MySQL\345\210\235\351\230\266/5.\346\225\260\346\215\256\344\277\256\346\224\271/3.\345\210\240\351\231\244/delete.md" create mode 100644 "data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/1.SELECT/select.json" create mode 100644 "data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/1.SELECT/select.md" create mode 100644 "data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/2.WHERE/where.json" create mode 100644 "data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/2.WHERE/where.md" create mode 100644 "data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/3.\350\277\220\347\256\227\347\254\246/geo.json" create mode 100644 "data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/3.\350\277\220\347\256\227\347\254\246/geo.md" create mode 100644 gears/sql/goods.sql create mode 100644 gears/sql/orders.sql create mode 100644 gears/sql/points.sql diff --git "a/data/1.MySQL\345\210\235\351\230\266/5.\346\225\260\346\215\256\344\277\256\346\224\271/2.\344\277\256\346\224\271/config.json" "b/data/1.MySQL\345\210\235\351\230\266/5.\346\225\260\346\215\256\344\277\256\346\224\271/2.\344\277\256\346\224\271/config.json" index 133e7cb..7670c9d 100644 --- "a/data/1.MySQL\345\210\235\351\230\266/5.\346\225\260\346\215\256\344\277\256\346\224\271/2.\344\277\256\346\224\271/config.json" +++ "b/data/1.MySQL\345\210\235\351\230\266/5.\346\225\260\346\215\256\344\277\256\346\224\271/2.\344\277\256\346\224\271/config.json" @@ -2,7 +2,9 @@ "node_id": "mysql-2eb9e9d351e848f580b70cf9e7b93280", "keywords": [], "children": [], - "export": [], + "export": [ + "update.json" + ], "keywords_must": [], "keywords_forbid": [], "group": 0 diff --git "a/data/1.MySQL\345\210\235\351\230\266/5.\346\225\260\346\215\256\344\277\256\346\224\271/2.\344\277\256\346\224\271/update.json" "b/data/1.MySQL\345\210\235\351\230\266/5.\346\225\260\346\215\256\344\277\256\346\224\271/2.\344\277\256\346\224\271/update.json" new file mode 100644 index 0000000..f06ad1a --- /dev/null +++ "b/data/1.MySQL\345\210\235\351\230\266/5.\346\225\260\346\215\256\344\277\256\346\224\271/2.\344\277\256\346\224\271/update.json" @@ -0,0 +1,7 @@ +{ + "type": "code_options", + "author": "ccat", + "source": "update.md", + "notebook_enable": false, + "exercise_id": "cf4476a1954440b499c84e022ec463ea" +} \ No newline at end of file diff --git "a/data/1.MySQL\345\210\235\351\230\266/5.\346\225\260\346\215\256\344\277\256\346\224\271/2.\344\277\256\346\224\271/update.md" "b/data/1.MySQL\345\210\235\351\230\266/5.\346\225\260\346\215\256\344\277\256\346\224\271/2.\344\277\256\346\224\271/update.md" new file mode 100644 index 0000000..005dd6c --- /dev/null +++ "b/data/1.MySQL\345\210\235\351\230\266/5.\346\225\260\346\215\256\344\277\256\346\224\271/2.\344\277\256\346\224\271/update.md" @@ -0,0 +1,43 @@ +# æ›´æ–°æ•°æ® + +现有 employee 表如下: + +```mysql +create table employee +( + id serial primary key, + name text, + dept text, + salary money +); +``` + +Joe 希望修改销售部(dept å—段为 sale)员工 Dora Muk çš„å·¥èµ„ï¼Œå°†å…¶å¢žåŠ 1000。æ£ç¡®çš„修改è¯å¥æ˜¯ï¼š + +## ç”案 + +```mysql +update employee set salary = salary + 1000 where dept = 'sale' and name = 'Dora Muk'; +``` + +## 选项 + +### 过滤æ¡ä»¶ä¸ä¸¥è°¨ + +```mysql +update employee set salary = salary + 1000 where name = 'Dora Muk'; +``` + + +### 缺少过滤æ¡ä»¶ + +```mysql +update employee set salary = salary + 1000; +``` + +### 错误的赋值è¯å¥ + +```mysql +update employee set salary += 1000; +``` + diff --git "a/data/1.MySQL\345\210\235\351\230\266/5.\346\225\260\346\215\256\344\277\256\346\224\271/3.\345\210\240\351\231\244/config.json" "b/data/1.MySQL\345\210\235\351\230\266/5.\346\225\260\346\215\256\344\277\256\346\224\271/3.\345\210\240\351\231\244/config.json" index 584abe0..d0f6500 100644 --- "a/data/1.MySQL\345\210\235\351\230\266/5.\346\225\260\346\215\256\344\277\256\346\224\271/3.\345\210\240\351\231\244/config.json" +++ "b/data/1.MySQL\345\210\235\351\230\266/5.\346\225\260\346\215\256\344\277\256\346\224\271/3.\345\210\240\351\231\244/config.json" @@ -2,7 +2,9 @@ "node_id": "mysql-3cae643e21644d6d937d69b59014922f", "keywords": [], "children": [], - "export": [], + "export": [ + "delete.json" + ], "keywords_must": [], "keywords_forbid": [], "group": 0 diff --git "a/data/1.MySQL\345\210\235\351\230\266/5.\346\225\260\346\215\256\344\277\256\346\224\271/3.\345\210\240\351\231\244/delete.json" "b/data/1.MySQL\345\210\235\351\230\266/5.\346\225\260\346\215\256\344\277\256\346\224\271/3.\345\210\240\351\231\244/delete.json" new file mode 100644 index 0000000..721e9e3 --- /dev/null +++ "b/data/1.MySQL\345\210\235\351\230\266/5.\346\225\260\346\215\256\344\277\256\346\224\271/3.\345\210\240\351\231\244/delete.json" @@ -0,0 +1,7 @@ +{ + "type": "code_options", + "author": "ccat", + "source": "delete.md", + "notebook_enable": false, + "exercise_id": "cfdd2c9789fd4fe493541cfa8811e4c9" +} \ No newline at end of file diff --git "a/data/1.MySQL\345\210\235\351\230\266/5.\346\225\260\346\215\256\344\277\256\346\224\271/3.\345\210\240\351\231\244/delete.md" "b/data/1.MySQL\345\210\235\351\230\266/5.\346\225\260\346\215\256\344\277\256\346\224\271/3.\345\210\240\351\231\244/delete.md" new file mode 100644 index 0000000..ba9bf94 --- /dev/null +++ "b/data/1.MySQL\345\210\235\351\230\266/5.\346\225\260\346\215\256\344\277\256\346\224\271/3.\345\210\240\351\231\244/delete.md" @@ -0,0 +1,90 @@ +# åˆ é™¤ + +现在 orders 表结构如下: + +```mysql +create table orders ( + id int primary key auto_increment, + item_id int, + amount int, + unit_price decimal(12, 4), + total_price decimal(12, 4), + description varchar(2000), + ts timestamp default now(), + deal bool default false +); +``` + +有一个业务系统会实时的将已ç»æˆäº¤ï¼ˆdeal å—段为 true)的订å•æ•°æ®è½¬å‚¨ï¼ŒçŽ°åœ¨æˆ‘们仅需è¦ä¸€ä¸ªæ¸…ç† ç¨‹åºï¼Œå°†å·²ç»æˆ 交的数æ®ä»Ž orders è¡¨åˆ é™¤å¹¶è®°å½•è¢«åˆ é™¤çš„æ•°æ®id。下é¢å“ªä¸ªæ“作是对的? + +## ç”案 + +在一个独立的定时任务ä¸æ‰§è¡Œ + +```mysql +delete +from orders +where deal; +``` + +## 选项 + +### A + +在一个独立的定时任务ä¸æ‰§è¡Œ + +```mysql +truncate orders; +``` + +### B + +在一个独立的定时任务ä¸æ‰§è¡Œ + +```mysql +delete +from orders; +``` + +### C + +在一个独立的定时任务ä¸æ‰§è¡Œ + +```mysql +drop table orders; +create table if not exists orders ( + id int primary key auto_increment, + item_id int, + amount int, + unit_price decimal(12, 4), + total_price decimal(12, 4), + description varchar(2000), + ts timestamp default now(), + deal bool default false +); +``` + +### D + +建立视图 + +```mysql +create view order_view as +select id, meta, content, created_at +from orders +where not deal; +``` + +并è¦æ±‚业务系统åªèƒ½è®¿é—®è¿™ä¸ªè§†å›¾ã€‚ + +### E + +在一个独立的定时任务ä¸æ‰§è¡Œ + +```mysql +delete +from orders +where deal; +``` + +并记录æ“作å‰åŽè¡¨ä¸çš„最大 id \ No newline at end of file diff --git "a/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/1.SELECT/config.json" "b/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/1.SELECT/config.json" index c3a29aa..ec9bfce 100644 --- "a/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/1.SELECT/config.json" +++ "b/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/1.SELECT/config.json" @@ -1,8 +1,10 @@ { "node_id": "mysql-f5527eae7f3148108c92ff99a6d4ed4a", - "keywords": [], + "keywords": ["查询", "select"], "children": [], - "export": [], + "export": [ + "select.json" + ], "keywords_must": [], "keywords_forbid": [], "group": 0 diff --git "a/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/1.SELECT/select.json" "b/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/1.SELECT/select.json" new file mode 100644 index 0000000..c6a7989 --- /dev/null +++ "b/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/1.SELECT/select.json" @@ -0,0 +1,7 @@ +{ + "type": "code_options", + "author": "ccat", + "source": "select.md", + "notebook_enable": false, + "exercise_id": "c873b09db60f4f93a8603a15e31d2a3a" +} \ No newline at end of file diff --git "a/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/1.SELECT/select.md" "b/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/1.SELECT/select.md" new file mode 100644 index 0000000..f5f2920 --- /dev/null +++ "b/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/1.SELECT/select.md" @@ -0,0 +1,43 @@ +# 基本è¯æ³• + +下列 SQL è¯å¥ï¼Œå“ªä¸€é¡¹ä¸åˆæ³•ï¼Ÿ + +## ç”案 + +```mysql +from test select abc; +``` + +## 选项 + + +### A + +```mysql +select 3.14; +``` + +### B + +```mysql +select * from employee; +``` + +### C + +```mysql +select * from employee where dept = 'hr'; +``` + +### D + +```mysql +select id, name, dept, salary from employee where salary > 10000; +``` + +### E + +```mysql +select now(); +``` + diff --git "a/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/2.WHERE/config.json" "b/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/2.WHERE/config.json" index 47cc2ef..ae466af 100644 --- "a/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/2.WHERE/config.json" +++ "b/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/2.WHERE/config.json" @@ -2,7 +2,9 @@ "node_id": "mysql-91cc9c73e58945d3ba654370a057a1c7", "keywords": [], "children": [], - "export": [], + "export": [ + "where.json" + ], "keywords_must": [], "keywords_forbid": [], "group": 0 diff --git "a/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/2.WHERE/where.json" "b/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/2.WHERE/where.json" new file mode 100644 index 0000000..5ceeca3 --- /dev/null +++ "b/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/2.WHERE/where.json" @@ -0,0 +1,7 @@ +{ + "type": "code_options", + "author": "ccat", + "source": "where.md", + "notebook_enable": false, + "exercise_id": "1407e367ecca4e159cb7777fe141e8d4" +} \ No newline at end of file diff --git "a/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/2.WHERE/where.md" "b/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/2.WHERE/where.md" new file mode 100644 index 0000000..fc661ea --- /dev/null +++ "b/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/2.WHERE/where.md" @@ -0,0 +1,64 @@ +# Where æ¡ä»¶ + +Joe 希望从 orders 表 + +```mysql +create table orders +( + id int primary key auto_increment, + item_id int, + amount int, + unit_price decimal(12, 4), + total_price decimal(12, 4), + description varchar(2000), + ts timestamp default now(), + deal bool default false +); +``` + +查询 2022 å¹´ 5 月 25 日下å•çš„所有å•ä»·ä½ŽäºŽ 20 的订å•id,那么这个查询应该如何写? + +## ç”案 + +```mysql +select id +from orders +where date(ts) = '2022-05-25' + and unit_prise < 20; +``` + +## 选项 + +### A + +```mysql +select id +from (select * from orders where date(ts) = '2022-05-25') as o +where unit_prise < 20; +``` + +### B + +```mysql +select id +from orders +where date(ts) = '2022-05-25' + or unit_prise < 20; +``` + +### C + +```mysql +select id +from orders +if date(ts) = '2022-05-25' or unit_prise < 20; +``` + +### D + +```mysql +select id +from orders +which date(ts) = '2022-05-25' + or unit_prise < 20; +``` diff --git "a/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/3.\350\277\220\347\256\227\347\254\246/config.json" "b/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/3.\350\277\220\347\256\227\347\254\246/config.json" index db4df1b..e30f547 100644 --- "a/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/3.\350\277\220\347\256\227\347\254\246/config.json" +++ "b/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/3.\350\277\220\347\256\227\347\254\246/config.json" @@ -1,8 +1,13 @@ { "node_id": "mysql-8f2aac71ea494f1b84372d43aa436135", - "keywords": [], + "keywords": [ + "operator", + "è¿ç®—符" + ], "children": [], - "export": [], + "export": [ + "geo.json" + ], "keywords_must": [], "keywords_forbid": [], "group": 0 diff --git "a/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/3.\350\277\220\347\256\227\347\254\246/geo.json" "b/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/3.\350\277\220\347\256\227\347\254\246/geo.json" new file mode 100644 index 0000000..7fd1dc4 --- /dev/null +++ "b/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/3.\350\277\220\347\256\227\347\254\246/geo.json" @@ -0,0 +1,7 @@ +{ + "type": "code_options", + "author": "ccat", + "source": "geo.md", + "notebook_enable": false, + "exercise_id": "09df5b5537d340fab861362b9123fbfd" +} \ No newline at end of file diff --git "a/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/3.\350\277\220\347\256\227\347\254\246/geo.md" "b/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/3.\350\277\220\347\256\227\347\254\246/geo.md" new file mode 100644 index 0000000..99a5334 --- /dev/null +++ "b/data/1.MySQL\345\210\235\351\230\266/6.\346\225\260\346\215\256\346\237\245\350\257\242/3.\350\277\220\347\256\227\347\254\246/geo.md" @@ -0,0 +1,45 @@ +# 数值计算 + +Points 表结构如下: + +```mysql +create table points( + id int primary key auto_increment, + x float, + y float +) +``` + +现在 Joe 想è¦æ±‚写一个查询,得到æ¯ä¸ªç‚¹çš„idå’Œæ¨¡ã€‚å³ âˆš(x^2+y^2) 。这个查询应该是: + +## ç”案 + +```mysql +select id, sqrt(x^2 + y^2) from points; +``` + +## 选项 + +### A + +```mysql +select sqrt(vx+vy) from (select x^2 as vx, y^2 as vy from points) as t; +``` + +### B + +```mysql +select sqrt(vx + vy) from points where x^2 as vx, y^2 as vy ; +``` + +### C + +```mysql +select id + sqrt(x^2 + y^2) from points; +``` + +### D + +```mysql +select id || sqrt(x^2 + y^2) from points; +``` \ No newline at end of file diff --git a/gears/sql/goods.sql b/gears/sql/goods.sql new file mode 100644 index 0000000..4ebaf58 --- /dev/null +++ b/gears/sql/goods.sql @@ -0,0 +1,9 @@ +create table goods( + id int primary key auto_increment, + category_id int, + category varchar(64), + name varchar(256), + price decimal(12, 4), + stock int, + upper_time timestamp +) \ No newline at end of file diff --git a/gears/sql/orders.sql b/gears/sql/orders.sql new file mode 100644 index 0000000..1d69a2a --- /dev/null +++ b/gears/sql/orders.sql @@ -0,0 +1,10 @@ +create table orders ( + id int primary key auto_increment, + item_id int, + amount int, + unit_price decimal(12, 4), + total_price decimal(12, 4), + description varchar(2000), + ts timestamp default now(), + deal bool default false +); \ No newline at end of file diff --git a/gears/sql/points.sql b/gears/sql/points.sql new file mode 100644 index 0000000..5d6342e --- /dev/null +++ b/gears/sql/points.sql @@ -0,0 +1,5 @@ +create table points( + id int primary key auto_increment, + x float, + y float +) \ No newline at end of file -- GitLab