Declaración avanzada de MySQL (2)

Primero, la consulta de la tabla de conexiones.

Unión interna (inner join): devuelve solo filas con campos de unión iguales en las dos tablas

inserte la descripción de la imagen aquí

combinación izquierda (unión izquierda): Devuelve todos los registros, incluidos todos los registros de la tabla de la izquierda y los registros con el mismo campo de combinación en la tabla de la derecha

inserte la descripción de la imagen aquí

combinación derecha (combinación derecha): devuelve todos los registros, incluidos todos los registros en la tabla de la derecha y los registros con el mismo campo de combinación en la tabla de la izquierda

inserte la descripción de la imagen aquí

#内连接:
SELECT * FROM location A RIGHT JOIN Store_Info B on A.Store_Name = B.Store_Name ;
#左连接
SELECT * FROM location A LEFT JOIN Store_Info B on A.Store_Name = B.Store_Name ;
#右连接
SELECT * FROM location A RIGHT JOIN Store_Info B on A.Store_Name = B.Store_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í

Otros métodos de unión interna:

SELECT * FROM location A INNER JOIN Store_Info B on A.Store_Name = B.Store_Name ;

SELECT * FROM location A, Store_Info B WHERE A.Store_Name = B.Store_Name;

inserte la descripción de la imagen aquí

inserte la descripción de la imagen aquí

Dos, CREAR VISTA ---- ver

La diferencia entre una vista y una tabla es que la tabla en realidad almacena registros de datos, mientras que la vista es una estructura construida sobre la tabla y en realidad no almacena registros de datos.
Las tablas temporales desaparecen automáticamente después de que el usuario cierra la sesión o se desconecta la conexión a la base de datos, pero la vista no desaparece.
Una vista no contiene datos, solo se almacena su definición y su uso generalmente simplifica las consultas complejas. Por ejemplo, si desea realizar consultas de unión en varias tablas y también realizar operaciones de clasificación estadística, será muy problemático escribir sentencias SQL Usar una vista para unir varias tablas y luego realizar operaciones de consulta en esta vista es lo mismo como realizar operaciones en una tabla Las consultas son las mismas, muy convenientes.

语法:CREATE VIEW "视图表名" AS "SELECT 语句";
CREATE VIEW V_REGION_SALES AS SELECT A.Region REGION,SUM(B.Sales) SALES FROM location A 
INNER JOIN Store_Info B ON A.Store_Name = B.Store_Name GROUP BY REGION;

SELECT * FROM V_REGION_SALES;
DROP VIEW V_REGION_SALES;

inserte la descripción de la imagen aquí

Tres, UNIÓN ---- conjunto conjunto

Combine los resultados de dos declaraciones SQL, los campos generados por las dos declaraciones SQL deben ser del mismo tipo de registro de datos
UNION: los valores de registro de datos de los resultados generados no se repetirán y se ordenarán según el orden de los campos

语法:[SELECT 语句 1] UNION [SELECT 语句 2];

UNION ALL :将生成结果的数据记录值都列出来,无论有无重复
语法:[SELECT 语句 1] UNION ALL [SELECT 语句 2];

SELECT Store_Name FROM location UNION SELECT Store_Name FROM Store_Info;

SELECT Store_Name FROM location UNION ALL SELECT Store_Name FROM Store_Info;

inserte la descripción de la imagen aquí

inserte la descripción de la imagen aquí

4. Valor de intersección: tome la intersección de los resultados de dos declaraciones SQL

SELECT A.Store_Name FROM location A INNER JOIN Store_Info B ON A.Store_Name = B.Store_Name;

SELECT A.Store_Name FROM location A INNER JOIN Store_Info B USING(Store_Name);

inserte la descripción de la imagen aquí

#取两个SQL语句结果的交集,且没有重复
SELECT DISTINCT A.Store_Name FROM location A INNER JOIN store_info B USING(Store_Name);

SELECT DISTINCT Store_Name FROM location WHERE (Store_Name) IN (SELECT Store_Name FROM store_info);

SELECT DISTINCT A.Store_Name FROM location A LEFT JOIN store_info B USING(Store_Name) WHERE B.Store_Name IS NOT NULL;

SELECT A.Store_Name FROM (SELECT B.Store_Name FROM location B INNER JOIN Store_Info C ON B.Store_Name = C.Store_Name) A 
GROUP BY A.Store_Name;

SELECT A.Store_Name FROM 
(SELECT DISTINCT Store_Name FROM location UNION ALL SELECT DISTINCT Store_Name FROM store_info) A 
GROUP BY A.Store_Name HAVING COUNT(*) > 1;

inserte la descripción de la imagen aquí

Cinco, sin valor de intersección

Muestra los resultados de la primera instrucción SQL y los resultados que no se superponen con la segunda instrucción SQL y no hay duplicación

SELECT DISTINCT Store_Name FROM location WHERE (Store_Name) NOT IN (SELECT Store_Name FROM store_info);

SELECT DISTINCT A.Store_Name FROM location A LEFT JOIN store_info B USING(Store_Name) WHERE B.Store_Name IS NULL;

SELECT A.Store_Name FROM 
(SELECT DISTINCT Store_Name FROM location UNION ALL SELECT DISTINCT Store_Name FROM store_info) A 
GROUP BY A.Store_Name HAVING COUNT(*) = 1;

inserte la descripción de la imagen aquí

6. CASO

Es una palabra clave utilizada por SQL como lógica como IF-THEN-ELSE

语法:
SELECT CASE ("字段名")
  WHEN "条件1" THEN "结果1"
  WHEN "条件2" THEN "结果2"
  ...
  [ELSE "结果N"]
  END
FROM "表名";

#"条件" 可以是一个数值或是公式。 ELSE 子句则并不是必须的。

SELECT Store_Name, CASE Store_Name 
  WHEN 'Los Angeles' THEN Sales * 2 
  WHEN 'Boston' THEN 2000
  ELSE Sales 
  END 
"New Sales",Date 
FROM Store_Info;

#"New Sales" 是用于 CASE 那个字段的字段名。

Siete, la diferencia entre valor vacío (NULL) y sin valor ('')

1. La longitud sin valor es 0, que no ocupa espacio, mientras que la longitud del valor NULL es NULL, que ocupa espacio.
2. IS NULL o IS NOT NULL se utiliza para juzgar si el campo es NULL o no NULL, y no puede averiguar si no tiene valor.
3. Use ='' o <>'' para manejar el juicio sin valor. <> representa no igual a.
4. Al especificar el número de filas contadas por el campo a través de count(), si se encuentra un valor NULL, se ignorará automáticamente y, si no se encuentra ningún valor, se agregará al registro para el cálculo.

)

inserte la descripción de la imagen aquí

SELECT length(NULL), length(''), length('1');
SELECT * FROM City WHERE name IS NULL;

inserte la descripción de la imagen aquí

SELECT * FROM city WHERE name IS NOT NULL;
SELECT * FROM city WHERE name = '';
SELECT * FROM city WHERE name <> '';

inserte la descripción de la imagen aquí

SELECT COUNT(*) FROM city;
SELECT COUNT(name) FROM city;

inserte la descripción de la imagen aquí

Ocho, expresiones regulares ----

patrón de coincidencia describir ejemplo
^ carácter inicial del texto coincidente '^bd' coincide con una cadena que comienza con bd
ps Coincide con el carácter final del texto. 'qn$' coincide con cadenas que terminan en qn
. coincide con cualquier carácter individual 's.t' coincide con cualquier cadena con un carácter entre s y t
* coincide con cero o más de los caracteres que lo preceden 'fo*t' coincide con t precedida por cualquier o
+ Coincide con el carácter anterior 1 o más veces 'hom+' coincide con una cadena que comienza con ho seguida de al menos una m
cadena coincide con la cadena especificada 'clo' coincide con cadenas que contienen clo
p1 p2 coincide con p1 o p2
[…] Coincide con cualquier carácter en el conjunto de caracteres '[abc]' coincide con a o b o c
[^…] coincide con cualquier carácter que no esté entre paréntesis '[^ab]' coincide con una cadena que no contiene a o b
{norte} Coincide con la cadena anterior n veces 'g{2}' coincide con una cadena que contiene 2 g
{Nuevo Méjico} Coincide con la cadena anterior al menos n y como máximo m veces 'f{1,3}' coincide con f al menos 1 vez y como máximo 3 veces

gramática:

SELECT "字段" FROM "表名" WHERE "字段" REGEXP {模式};
SELECT * FROM store_info WHERE Store_Name REGEXP 'os';
SELECT * FROM store_info WHERE Store_Name REGEXP '\^[A-G]';
SELECT * FROM store_info WHERE Store_Name REGEXP 'Ho|Bo';

inserte la descripción de la imagen aquí

Supongo que te gusta

Origin blog.csdn.net/weixin_51728919/article/details/131383476
Recomendado
Clasificación