Declaraciones SQL avanzadas para la base de datos MySQL (¡gráficos y texto detallados!)


Preparación: primero cree una base de datos y una tabla

mysql -uroot -p
show databases;

create database plane;
use plane;
create table destination (
region char(20),
place_name char(20));

insert into destination values('southwest','chengdu');
insert into destination values('north China','beijing');
insert into destination values('southwest','kunming');
insert into destination values('north China','tianjin');
select * from destination;

create table info (
place_name char(20),
sales int(10),
date char(10));

insert into info values('chengdu','350','2021-02-10');
insert into info values('beijing','294','2021-02-10');
insert into info values('kunming','330','2021-02-10');
insert into info values('beijing','392','2021-02-16');
select * from info;

Inserte la descripción de la imagen aquí
Inserte la descripción de la imagen aquí

Una, declaración avanzada de MySQL

1 SELECCIONAR

Mostrar todos los datos en uno o varios campos de la tabla

语法:SELECT "栏位" FROM "表名";
例:
select region from destination;
select date,sales from info;
select date,sales from info;

Inserte la descripción de la imagen aquí

2.DISTINTO

No mostrar datos duplicados

语法:SELECT DISTINCT "栏位" FROM "表名";
例:
select place_name from info;
select distinct place_name from info;

Inserte la descripción de la imagen aquí

3.DÓNDE

Consulta condicional

语法:SELECT "栏位" FROM "表名" WHERE "条件";
例:
select * from info;
select place_name from info where sales > 300;

Inserte la descripción de la imagen aquí

4.Y | O

Y | o

语法:SELECT "栏位" FROM "表名" WHERE "条件1" {
    
    [AND|OR] "条件2"}+ ;
例:
select * from info;
select place_name from info where sales > 350 or sales < 300;
select place_name from info where sales > 300 and sales < 350;

Inserte la descripción de la imagen aquí

5.IN

Mostrar datos de valores conocidos

语法:SELECT "栏位" FROM "表名" WHERE "栏位" IN ('值1', '值2', ...);
例:
select * from info where place_name in ('beijing');
select * from info where place_name in ('beijing','kunming');

Inserte la descripción de la imagen aquí

6 ENTRE

Mostrar datos dentro de dos rangos de valores

语法:SELECT "栏位" FROM "表名" WHERE "栏位" BETWEEN '值1' AND '值2';
例:
select * from info where sales between '300' and '350';

Inserte la descripción de la imagen aquí

7. Comodín

Por lo general, los comodines se usan con LIKE

% :百分号表示零个、一个或多个字符
_ :下划线表示单个字符
例:
'A_Z':所有以 'A' 起头,另一个任何值的字符,且以 'Z' 为结尾的字符串。例如,'ABZ''A2Z' 都符合这一个模式,而 'AKKZ' 并不符合 (因为在 A 和 Z 之间有两个字符,而不是一个字符)'ABC%': 所有以 'ABC' 起头的字符串。例如,'ABCD''ABCABC' 都符合这个模式。
'%XYZ': 所有以 'XYZ' 结尾的字符串。例如,'WXYZ''ZZXYZ' 都符合这个模式。
'%AN%': 所有含有 'AN'这个模式的字符串。例如,'LOS ANGELES''SAN FRANCISCO' 都符合这个模式。
'_AN%':所有第二个字母为 'A' 和第三个字母为 'N' 的字符串。例如,'SAN FRANCISCO' 符合这个模式,而 'LOS ANGELES' 则不符合这个模式。

8 ME GUSTA

Haga coincidir un patrón para encontrar la información que queremos

语法:SELECT "栏位" FROM "表名" WHERE "栏位" LIKE {
    
    模式};
例:
select * from info where place_name like '_ei%';

Inserte la descripción de la imagen aquí

9.PEDIDO POR

Ordenar por palabra clave

语法:SELECT "栏位" FROM "表名" [WHERE "条件"] ORDER BY "栏位" [ASC, DESC];
#ASC 是按照升序进行排序的,是默认的排序方式。(Ascending)
#DESC 是按降序方式进行排序。(Descending)
例:
select place_name,sales,date from info order by sales;
select place_name,sales,date from info order by sales asc;
select place_name,sales,date from info order by sales desc;

Inserte la descripción de la imagen aquí

10. Función

(1) Funciones matemáticas

abs(x)	          返回 x 的绝对值
rand()	          返回 0 到 1 的随机数
mod(x,y)	      返回 x 除以 y 以后的余数
power(x,y)        返回 x 的 y 次方
round(x)	      返回离 x 最近的整数
round(x,y)        保留 x 的 y 位小数四舍五入后的值
sqrt(x)	          返回 x 的平方根
truncate(x,y)	  返回数字 x 截断为 y 位小数的值
ceil(x)	          返回大于或等于 x 的最小整数
floor(x)	      返回小于或等于 x 的最大整数
greatest(x1,x2…)  返回集合中最大的值
least(x1,x2…)	  返回集合中最小的值

SELECT abs(-1), rand(), mod(5,3), power(2,3), round(1.89);
SELECT round(1.8937,3), truncate(1.235,2), ceil(5.2), floor(2.1), least(1.89,3,6.1,2.1);

Inserte la descripción de la imagen aquí

(2) Función agregada

avg()	返回指定列的平均值
count()	返回指定列中非 NULL 值的个数
min()	返回指定列的最小值
max()	返回指定列的最大值
sum(x)	返回指定列的所有值之和

#count(*)包括了所有的列的行数,在统计结果的时候,不会忽略值为NULL
#count(列名)只包括列名那一列的行数,在统计结果的时候,会忽略列值为NULL的行

例:
select avg(sales) from info;

select count(place_name) from info;
select count(distinct place_name) from info;

select max(sales) from info;
select min(sales) from info;

select sum(sales) from info;

Inserte la descripción de la imagen aquí
Inserte la descripción de la imagen aquí

(3) Función de cadena

trim()	返回去除指定格式的值
concat(x,y)	将提供的参数 x 和 y 拼接成一个字符串
substr(x,y)	获取从字符串 x 中的第 y 个位置开始的字符串,跟substring()函数作用相同
substr(x,y,z)	获取从字符串 x 中的第 y 个位置开始长度为 z 的字符串
length(x)	返回字符串 x 的长度
replace(x,y,z)	将字符串 z 替代字符串 x 中的字符串 y
upper(x)	将字符串 x 的所有字母变成大写字母
lower(x)	将字符串 x 的所有字母变成小写字母
left(x,y)	返回字符串 x 的前 y 个字符
right(x,y)	返回字符串 x 的后 y 个字符
repeat(x,y)	将字符串 x 重复 y 次
space(x)	返回 x 个空格
strcmp(x,y)	比较 x 和 y,返回的值可以为-1,0,1
reverse(x)	将字符串 x 反转

Nota: Si sql_mode está activado y PIPES_AS_CONCAT está activado, "||" se considera un operador de concatenación de cadenas en lugar de un operador o, que es similar a la función de concatenación de cadenas Concat, que es lo mismo que la base de datos de Oracle usando
Inserte la descripción de la imagen aquí
trim () para devolver y eliminar Especificar el valor del formato

select TRIM ([ [位置] [要移除的字符串] from ] 字符串);
#[位置]:的值可以为 LEADING (起头), TRAILING (结尾), BOTH (起头及结尾)。 
#[要移除的字符串]:从字串的起头、结尾,或起头及结尾移除的字符串。缺省时为空格。
例:
select trim(leading '123' from '1234567');

Inserte la descripción de la imagen aquí
concat (x, y) concatenar los parámetros proporcionados xey en una cadena

select concat(region, place_name) from destination;

select region || ' ' || place_name from destination;
select region || ' ' || place_name from destination where place_name = 'beijing';

Inserte la descripción de la imagen aquí
Inserte la descripción de la imagen aquí
substr (x, y) Obtiene la cadena comenzando desde la posición y-ésima en la cadena
x, que tiene el mismo efecto que la función subcadena () substr (x, y, z) Obtiene la longitud comenzando desde la posición y-ésima en la cadena x Una cadena de z

select * from destination;
select substr(place_name,3) from destination where place_name = 'beijing';
select substr(place_name,2,4) from destination where place_name = 'beijing';

Inserte la descripción de la imagen aquí
length (x) devuelve la longitud de la cadena x

select place_name from destination;
select length(place_name) from destination;
select region,length(place_name) from destination;

Inserte la descripción de la imagen aquí
reemplazar (x, y, z) reemplaza la cadena z con la cadena y en la cadena x
Inserte la descripción de la imagen aquí
superior (x) cambia todas las letras de la cadena x a mayúsculas minúsculas
(x) cambia todas las letras de la cadena x a minúsculas

select * from destination;
select upper(region) from destination;
select lower(region) from destination;

Inserte la descripción de la imagen aquí
left (x, y) devuelve los primeros caracteres y de la cadena x
right (x, y) devuelve los últimos caracteres y de la cadena x

Inserte la descripción de la imagen aquí
repeat (x, y) Repite la cadena x y veces

select repeat(region,2) from destination;
select repeat(123,2);

Inserte la descripción de la imagen aquí
espacio (x) devuelve x espacios

select space(20);
select space(10);

Inserte la descripción de la imagen aquí
strcmp (x, y) compara xey, el valor devuelto puede ser -1,0,1

select strcmp(5,6);
select strcmp(5,5);
select strcmp(6,5);

Inserte la descripción de la imagen aquí
revertir (x) revertir la cuerda x
Inserte la descripción de la imagen aquí

11.GRUPO POR

Recopile y agrupe los resultados de la consulta de la columna después de GROUP BY.
Nota:
1) Por lo general, se usa en combinación con funciones agregadas.
2) GROUP BY tiene un principio, es decir, en todas las columnas después de SELECT, columnas que no usan agregados las funciones deben aparecer después de GROUP BY.

语法:SELECT "栏位1", SUM("栏位2") FROM "表名" GROUP BY "栏位1";
例:
select place_name,sum(sales) from info group by place_name order by sum(sales);

Inserte la descripción de la imagen aquí

12.TENER

Se usa para filtrar la tabla de registros devuelta por la instrucción GROUP BY.
Nota:
1) Por lo general, se usa junto con la instrucción GROUP BY.
2) La existencia de la instrucción HAVING compensa la insuficiencia de la palabra clave WHERE que no se puede usar en en conjunción con funciones agregadas. Si solo se selecciona la columna de función, la cláusula GROUP BY no es necesaria.

语法:SELECT "栏位1", SUM("栏位2") FROM "表格名" GROUP BY "栏位1" HAVING (函数条件);
例:
select place_name,sum(sales) from info group by place_name having sum(sales) > 400;

Inserte la descripción de la imagen aquí

13. Alias

Alias ​​de campo

语法:SELECT "表格別名"."栏位1" [AS] "栏位別名" FROM "表格名" [AS] "表格別名";
例:
select A.place_name "name",sum(A.sales) "sum_sales" from info A group by name;

Inserte la descripción de la imagen aquí

14. Subconsulta: tabla de unión

Inserte otra instrucción SQL en la sub cláusula WHERE o HAVING cláusula

语法:
#外查询
SELECT "栏位1" FROM "表格1" WHERE "栏位2" [比较运算符]
#内查询
(SELECT "栏位1" FROM "表格2" WHERE "条件");
#可以是符号的运算符,例如:=、>、<、>=、<= ;也可以是文字的运算符,例如 LIKE、IN、BETWEEN

Ejemplo 1:

select sum(sales) from info where place_name in (select place_name from destination where region = 'southwest');
#下面这个句子就是上面的简化版
select sum(sales) from info where place_name in('chengdu','kunming');

Ejemplo 2:

select sum(a.sales) from info a where a.place_name in(select place_name from destination b where b.place_name = a.place_name);
select sum(a.sales) from info a where a.place_name in(select place_name from destination b where b.place_name = a.place_name);

Inserte la descripción de la imagen aquí
Inserte la descripción de la imagen aquí
Inserte la descripción de la imagen aquí

15.EXISTEN

Se usa para probar si la consulta interna produce algún resultado.

  • Si los valores booleanos similares son verdaderos
  • Si es así, el sistema ejecutará la instrucción SQL en la consulta externa. De lo contrario, la declaración SQL completa no producirá ningún resultado.
语法:SELECT "栏位1" FROM "表格1" WHERE EXISTS (SELECT * FROM "表格2" WHERE "条件");
例:
select sum(sales) from info where exists (select * from destination where region = 'southwest');

Inserte la descripción de la imagen aquí

Dos, consulta de conexión

Inserte la descripción de la imagen aquí

1.unión interna (valor igual conectado)

Solo devuelve filas con campos de combinación iguales en dos tablas

SELECT * FROM 表1 表1的别名 INNER JOIN 表2 表2的别名 on 表1别名.栏位 = 表2别名.栏位;  #这里的栏位名称相同
例:
select * from destination a inner join info b on a.place_name = b.place_name;

Inserte la descripción de la imagen aquí

2.unión a la izquierda (unión a la izquierda)

Retorno que incluye todos los registros de la tabla de la izquierda y los registros de la tabla de la derecha donde el campo de combinación es igual

SELECT * FROM 表1 表1的别名 LEFT JOIN 表2 表2的别名 on 表1别名.栏位 = 表2别名.栏位;  #这里的栏位名称相同
例:
select * from destination a left join info b on a.place_name = b.place_name;

Inserte la descripción de la imagen aquí

3.unir a la derecha (unir a la derecha)

Retorno que incluye todos los registros de la tabla de la derecha y los registros de la tabla de la izquierda donde el campo de combinación es igual

SELECT * FROM 表1 表1的别名 RIGHT JOIN 表2 表2的别名 on 表1别名.栏位 = 表2别名.栏位;  #这里的栏位名称相同
例:
select * from destination a right join info b on a.place_name = b.place_name;

Inserte la descripción de la imagen aquí

Supongo que te gusta

Origin blog.csdn.net/qq_35456705/article/details/114083233
Recomendado
Clasificación