Directorio de artículos
- Primero, la consulta de la tabla de conexiones.
- Dos, CREAR VISTA ---- ver
- Tres, UNIÓN ---- conjunto conjunto
- 4. Valor de intersección: tome la intersección de los resultados de dos declaraciones SQL
- Cinco, sin valor de intersección
- 6. CASO
- Siete, la diferencia entre valor vacío (NULL) y sin valor ('')
- Ocho, expresiones regulares ----
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
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
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
#内连接:
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 ;
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;
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;
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;
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);
#取两个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;
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;
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.
)
SELECT length(NULL), length(''), length('1');
SELECT * FROM City WHERE name IS NULL;
SELECT * FROM city WHERE name IS NOT NULL;
SELECT * FROM city WHERE name = '';
SELECT * FROM city WHERE name <> '';
SELECT COUNT(*) FROM city;
SELECT COUNT(name) FROM city;
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';