目次
基本的なクエリ
直接問い合わせ
すべての列をクエリする
语法:select * from 表名;
-- 查询 student 表中所有内容
select * from student;
指定された列をクエリします
语法:select 字段 from 表名;
-- 查询 student 表中的name列 与 age列
select name, age from student;
AS はエイリアス化されています
AS を使用してフィールドにエイリアスを付ける
语法:select 字段 as 别名 from 表名;(as可省略)
-- 查询 student 表中的name列 与 age列
select name 名字, age 年龄 from student;
-- select name as 名字, age as 年龄 from student;
AS を使用してテーブルに別名を付ける
语法:select 字段 from 表名 as 别名;
-- 查询 student 表中的name列 与 age列,同时给student起个‘学生年龄表’别名
select name 名字, age 年龄 from student 学生年龄表;
重複排除(反復)クエリ
DISTINCT 用于从表中获取不重复的数据
语法:select distinct 列名 from 表名;
-- 查询 student 表中所有的不同年龄
select distinct age from student;
条件付きクエリ
语法:select 字段 from 表名 where 条件;
-- 从 student 表中查询 age = 18 的 name
select name from student where age = 18;
算術演算子のクエリ
语法:>(大于), <(小于), =(等于), !=(不等于), <>(不等于), >=(大于等于), <=(小于等于)
-- 从 student 表中查询 age >=20 的所有记录
select * from student where age >= 20;
論理演算子クエリ
语法:and(且), or(或), not(非) sql 会首先执行 and 条件,再执行 or 语句。除非加括号
-- 从 student 表中查询 age >=20并且成绩高于50分的所有记录
select * from student where age >= 20 and score > 50;
-- 从 student 表中查询 age = 15 或 score = 70 的所有记录
select * from student where age = 15 or score = 70;
正規表現クエリ ⭐
正则表达式要用regexp
语法:select 字段 from 表名 where 字段 regexp '正则表达式';
--从 student 表中查询 name 含有李的所有记录
select * from student where name regexp '李';
--从 student 表中查询 name 含有李或三的所有记录
select * from student where name regexp '李|三';
--从 student 表中查询 name 为李开头的所有记录
select * from student where name regexp '^李';
--从 student 表中查询 name 为五结尾的所有记录
select * from student where name regexp '五$';
-- 字符.用来替代字符串中的任意一个字符
--从 student 表中查询 name 含'赵'和'真'两个字符且中间只隔了一个字符的所有记录
select * from student where name regexp '赵.真';
-- 字符*和+都可以匹配多个该符号之前的字符。不同的是,+表示至少一个字符,而*可以表示 0 个字符。
-- 从 student 表中查询 name 含丰字的所有记录(三*表示丰字前面可以有0-无数个三,因此至少含有丰)
select * from student where name regexp '三*丰';
-- 从 student 表中查询 name 含丰且前面只少有一个三的所有记录(三+表示丰字前面至少个三,因此至少含有三丰)
select * from student where name regexp '三+丰';
-- 从 student 表中查询 name 包含李、三、 真 3 个字符中任意一个的记录
select * from student where name regexp '[李三真]';
-- 方括号[ ]还可以指定集合的区间。例如,“[a-z]”表示从 a~z 的所有字母;“[0-9]”表示从 0~9 的所有数字;“[a-z0-9]”表示包含所有的小写字母和数字;“[a-zA-Z]”表示匹配所有字符;“[\\u4e00-\\u9fa5]”表示中文汉字
-- [^字符集合]用来匹配不在指定集合中的任何字符。
-- 查询 name 字段值包含字母 a~t 以外的字符的所有记录
select * from student where name regexp'[^a-t]';
-- 字符串{n,}表示字符串连续出现 n 次;字符串{n,m}表示字符串连续出现至少 n 次,最多 m 次。
-- a{2,} 表示字母 a 连续出现至少 2 次,也可以大于 2 次;a{2,4} 表示字母 a 连续出现最少 2 次,最多不能超过 4 次。
-- 查询 name 字段值出现字母‘e’ 至少 2 次的记录
select * from student where name regexp'e{2,}';
REGEXP 演算子で一般的に使用されるマッチング方法
オプション | 説明する | 例 | 一致値の例 |
---|---|---|---|
^ | 一致するテキストの開始文字 | '^b' は、文字 b で始まる文字列と一致します。 | 本、大きな、バナナ、自転車 |
$ | テキストの末尾の文字と一致します | 「st$」は st で終わる文字列と一致します | 試す、抵抗する、持続する |
。 | 任意の 1 文字に一致します | 「b.t」は b と t の間の任意の文字に一致します | ビット、バット、でも、噛む |
* | 先行する 0 個以上の文字と一致します | 'f*n' は、任意の文字 f が先行する文字 n と一致します。 | fn、ファン、ファーン、abcn |
+ | 前の文字と 1 回以上一致します | 「ba+」は、少なくとも 1 つの a が続く b に一致します。 | 場、湾、裸、戦い |
<文字列> | 指定された文字を含むテキストと一致します | 「fa」は「fa」を含むテキストと一致します | ファン、アファ、ファアド |
[キャラクターセット] | 文字セット内の任意の文字と一致します | '[xz]' は x または z に一致します | めまい、シマウマ、レントゲン、エクストラ |
[^] | 括弧内にない任意の文字と一致します | '[^abc]' は、a、b、c を含まない任意の文字列と一致します。 | デスク、キツネ、f8ke |
文字列{n,} | 前の文字列と少なくとも n 回一致します | 'b{2}' は 2 つ以上の b に一致します | bbb、bbbb、bbbbbb |
文字列{n,m} | 前の文字列と少なくとも n 回、最大で m 回一致します | 'b{2,4}' は少なくとも 2 つ、最大 4 つの b に一致します | bbb、bbbb |
ファジークエリ
语法:select 字段 from 表名 where 字段 like '%数据%';
-- 从 student 表中查询 name 中含有 '张' 的所有记录
select * from student where name like '%张%';
-- 从 student 表中查询 name 中姓 '张' 的所有记录
select * from student where name like '张%';
範囲クエリ
in与not in between … and …:范围连续(包含端点)
语法:select 字段 from 表名 where 字段 in(列表)//或 not in(列表);
-- 从 student 表中查询 age 为 (18, 19, 20) 之间的所有记录
select * from student where age in(18, 19, 20);
-- 从 student 表中查询 除了age 为 (18, 19, 20) 之间的所有记录
select * from student where age not in(18, 19, 20);
语法:select 字段 from 表名 where 字段 between 值1 and 值2;
-- 从 student 表中查询 age 为 (18, 19, 20) 之间的所有记录
select * from student where age between 18 and 20;
空でないか判定クエリ
null(为空) not (非空) 判断是否为空要用is
语法:select 字段 from 表名 where 字段 is null(not null);
--从 student 表中查询 age 未填写(为空)的所有记录
select * from student where age is null;
優先度
優先順位は高から低の順で、括弧 > NOT > 比較演算子 > 論理演算子です。
ANDはORの前に演算され、同時に現れてORを先に計算したい場合は、()と組み合わせて使用する必要があります
ソートクエリ
语法:select 字段 from 表名 order by 字段 排序方式(升序 asc, 降序 desc);
-- 从 student 表中查询所有记录并按照 age 升序排序
select * from student order by age asc;
进阶 select 字段 from 表名 order by 字段 排序方式,字段 排序方式;
(当第一个字段相同时,按第二个字段排序顺序来)
-- 从 student 表中查询所有记录并按照 age 升序,当 age 相同时,按score降序排序
select * from student order by age asc,score desc;
制限クエリ(ページングクエリ)
语法:limit可以限制制定查询结果的记录条数
注意 0 表示第一行记录,也是从 0 开始
select 字段 from 表名 limit n;查询前n行的记录
select 字段 from 表名 limit n, m;查询第n+1行到第m+n行的记录(也就是从第n+1行开始查询m行记录)
-- 从 student 表中查询第三行到第六行的记录,也就是第三行开始查询4条记录
select * from student limit 2, 4;
ランダムなクエリ
-- 随机显示两个学生信息
select * from student order by rand() limit 2;
グループクエリ
语法:select 字段 from 表名 group by 字段 ;
-- 从 student 表中查询age值和每个age都有多少人
select age ,count(*) from student group by age ;
GROUP BY 句は、WHERE 句の後、ORDER BY 句の前に指定する必要があります。
持っている
HAVING ステートメントは、グループ化されたデータをフィルター処理するために使用されます。
语法:select 字段 from 表名 group by 字段 having 条件;
-- 从 student 表中查询age>19值和每个age>19都有多少人
select age ,count(*) from student group by age having age > 19;
高度な検索
サブクエリ (ネストされたクエリ)
select 文の中に別の select 文が埋め込まれており、埋め込まれた select 文をサブクエリ文、外部の select 文をメインクエリと呼びます。
メインクエリとサブクエリの関係
- サブクエリはメインクエリに埋め込まれています
- サブクエリは、条件またはデータ ソースとしてメイン クエリを補助します。
- サブクエリは独立して存在できるステートメントであり、完全な選択ステートメントです。
语法:语法:嵌套查询也就是在查询语句中包含有子查询语句,所以叫嵌套查询,没有单独的语法,嵌套子查询通常位于查询语句的条件之后;
-- 先查询学生平均年龄,再查询大于平均年龄的学生
select * from student where age > (select avg(age) from student);
行番号
-- row_number() over (排序语句)
-- row_number()从1开始,为每一条分组记录返回一个数字
-- 查询名次 姓名 成绩
select row_number() over (order by score desc) 名次,name 姓名,score 成绩 from student;
ランキング
DENSE_RANK() は、ランク値にギャップがないようにパーティションまたは結果セット内の各行にランクを割り当てるウィンドウ関数です。
- DENSE_RANK()。ランキングに DENSE_RANK() を使用すると、1、1、2、3、4 が得られます。
- ランク()。RANK() を使用してランキングすると、1、1、3、4、5 が得られます。
- ROW_NUMBER()。ランキングに ROW_NUMBER() を使用すると、1、2、3、4、5 が得られます。(通常は番号付けに使用されます)
-- 排名
--排名并列后面名次挨着
select id 编号,name 姓名,score 分数,concat('第',dense_rank() over (order by score
desc),'名') 名次 from student;
--排名并列后面名次不挨着
select id 编号,name 姓名,score 分数,concat('第',rank() over (order by score
desc),'名') 名次 from student;
集計関数
-- 聚合函数
-- 可以实现一些具体的功能,比如找最小值,找最大值,求和,计数等
-- min() 求最小值
语法:select min(字段) from 表名;
-- 从 student 中查询最小的 age
select min(age) from student;
-- max() 求最大值
语法:select max(字段) from 表名;
-- 从 student 中查询最大的 age
select max(age) from student;
-- sum() 求和
语法:select sum(字段) from 表名;
-- 从 student 中统计所有 age 的和
select sum(age) from student;
-- avg() 求平均值
语法:select avg(字段) from 表名;
-- 从 student 中对所有的 age 求平均值
select avg(age) from student;
-- count(字段) 统计个数
语法:select count(字段) from 表名;
-- 从 student 中查询 name 的记录个数
select count(name) from student;
接続クエリ
MySQL クエリ結合は主に、内部結合、外部結合、およびクロス結合の 3 つのカテゴリに分類されます。
内部結合
内部結合
内部結合とは、2 つ以上のテーブルのレコードが対応する関係を持ち、主キーと外部キーで表すことができることを意味します。内部結合は、同じレコードを保持することによって結果を返します。つまり、両方のテーブルに一致するレコードが存在する場合にのみクエリ結果が返されます。
-- 内连接
语法:select 字段 from 表1 inner join 表2 on 表1.字段 = 表2.字段;
根据两个表中共有的字段进行匹配,然后将符合条件的合集进行拼接
on后面是连接条件,也就是共有字段
select * from student inner join engScore on student.name = engScore.name;
-- 将 student 表与 engScore 表通过相同的 name 拼接起来,简单的来说就是两个 excel 合并
例 Student と Course という 2 つのテーブルがあると仮定すると、その列と内容は次のとおりです。
student表:
ID | 名前 | 年 |
---|---|---|
1 | ジャック | 18 |
2 | トム | 19 |
3 | ジェリー | 20 |
4 | ボブ | 18 |
course表:
コースID | コース名 | 学生証 |
---|---|---|
1 | 数学 | 1 |
2 | 英語 | 2 |
3 | 科学 | 2 |
4 | 歴史 | 3 |
ここで、各学生が選択したコースをクエリしたいので、次の SQL ステートメントを使用できます。
SELECT student.name, course.course_name
FROM student
INNER JOIN course
ON student.id = course.student_id;
このクエリは次の結果を返します。
名前 | コース名 |
---|---|
ジャック | 数学 |
トム | 英語 |
トム | 科学 |
ジェリー | 歴史 |
外部結合
外部結合
外部結合の場合は、outer キーワードを省略できます。
外部結合には左結合と右結合があり、2 つ以上のテーブルを結合するときにすべてのレコードが含まれることを意味します。
左 (外側) 結合
左結合は、左側のテーブルがすべてのレコードをフェッチし、右側のテーブルが一致するレコードのみをフェッチすることを意味します。左側のテーブルに右側のテーブルと一致するレコードがない場合、右側のテーブルは NULL 値を返します。
-- 左连接
语法:select 字段 from 表1 left join 表2 on 连接条件;
select * from student left join engScore on student.name = engScore.name;
-- 与内连接形式相同,但左表为主表,指定字段都会显示,右表为从表,无内容会显示 null
例
上記の学生テーブルとコース テーブルを例として、コースを選択していない学生も含め、各学生が選択したコースをクエリする場合を考えます。次の SQL ステートメントを使用できます。
SELECT student.name, course.course_name
FROM student
LEFT JOIN course
ON student.id = course.student_id;
このクエリは次の結果を返します。
名前 | コース名 |
---|---|
ジャック | 数学 |
トム | 英語 |
トム | 科学 |
ジェリー | 歴史 |
ボブ | ヌル |
右 (外側) 結合
右結合は左結合と似ていますが、左右のテーブルの役割が逆になる点が異なります。
-- 右连接
语法:select 字段 from 表1 right join 表2 on 连接条件;
select * from student right join engScore on student.name = engScore.name;
-- 与内连接形式相同,但右表为主表,指定字段都会显示,左表为从表,无内容会显示 null
引き続き、上記の学生テーブルとコース テーブルを例として使用し、コースを選択しなかった学生を含む各コースの学生をクエリする場合を考えます。次の SQL ステートメントを使用できます。
SELECT student.name, course.course_name
FROM student
RIGHT JOIN course
ON student.id = course.student_id;
このクエリは次の結果を返します。
名前 | コース名 |
---|---|
ジャック | 数学 |
トム | 英語 |
トム | 科学 |
ジェリー | 歴史 |
ヌル | 地理 |
完全外部結合 (合成)
SQLにはFULL OUTER JOIN(完全外部結合)もありますが、MySQLではサポートしていません。したがって、UNION ステートメントを使用して完全外部結合をシミュレートできます。
労働組合と労働組合
Union は重複を排除します。ある条件で返されると、次の条件になっても返されません。Union all では重複は削除されません。ある条件で返された場合、次の条件でも重複があった場合にも返されます。
select id, name, age from s1 where age >18union select id, name, agefrom s2 where age >18;
-- 查询s1和s2中所有年纪大于18的学生的id,name,age,并将结果放在一个表中,同时去掉重复
クロスコネクト
クロスジョイン
クロス結合は、2 つ以上のテーブル間の結合条件のない結合です。簡単に言えば、クロス結合を使用すると、考えられるすべての組み合わせをクエリできます。
tb1:
d | 名前 |
---|---|
1 | あ |
2 | B |
3 | C |
次の SQL ステートメントを使用してクロス結合を実行できます。
SELECT t1.name, t2.name
FROM tb1 t1
CROSS JOIN tb1 t2;
検索結果
名前 | 名前 |
---|---|
あ | あ |
あ | B |
あ | C |
B | あ |
B | B |
B | C |
C | あ |
C | B |
C | C |
SELECT 句が従う必要がある順序
句 | 説明する | 使用する必要がありますか |
選択する | 返す列または式 | はい |
から | データを取得するテーブル | テーブルからデータを選択する場合にのみ使用されます |
どこ | 行レベルのフィルタリング | いいえ |
グループ化 | グループの説明 | グループごとに集計を計算する場合にのみ使用されます |
持っている | グループレベルのフィルタリング | いいえ |
注文方法 | 出力のソート順 | いいえ |
リミット | 取得する行数 | いいえ |