A instrução SQL mais comumente usada na história

 
 

A instrução SQL mais comumente usada na história

Linguagem de definição de dados DDL (Data Definition Language)

1. Biblioteca de operação

2. Tabela de operação

Linguagem de manipulação de dados DML (Data Manipulation Language)

Um, aumente a inserção em

Dois, deletar deletar

Três, modifique a atualização

Linguagem de consulta de dados DQL (Data Query Language)

1. Palavras-chave básicas

Dois, classificar a consulta por ordem de

3. Função de agregação: pegue uma coluna de dados como um todo e execute cálculos verticais.

Quatro, argamassa de consulta de grupo por

Cinco, consulta de paginação

Seis, consulta de junção interna:

1. Conexão interna implícita: use a condição where para eliminar dados inúteis

 2. União interna explícita

 Sete, consulta de junção externa

1. Consulta de junção externa esquerda de todos os dados na tabela esquerda e sua interseção.

 2. Right outer join - consulta todos os dados da tabela certa e sua interseção.

 8. Subconsulta: consulta aninhada na consulta

   1. O resultado da subconsulta é uma única linha e uma única coluna

   2. O resultado da subconsulta é várias linhas e uma única coluna:

   3. O resultado da subconsulta é várias linhas e colunas:

 Linguagem de controle de dados DCL (Data Control Language)

Gerenciar usuários

Adicionar usuário

deletar usuários

gestão de autoridade

Permissões de consulta

Permissão concedida

Revogar autoridade

  Criar não é fácil, se este blog é útil para você, lembre-se de deixar uma mensagem + curtir.  


Linguagem de definição de dados DDL (Data Definition Language)

1. Biblioteca de operação

-- 创建库
create database db1;
-- 创建库是否存在,不存在则创建
create database if not exists db1;
-- 查看所有数据库
show databases;
-- 查看某个数据库的定义信息 
show create database db1; 
-- 修改数据库字符信息
alter database db1 character set utf8; 
-- 删除数据库
drop database db1; 

2. Tabela de operação

--创建表
create table student(
    id int,
    name varchar(32),
    age int ,
    score double(4,1),
    birthday date,
    insert_time timestamp
);

-- 查看表结构
desc 表名;
-- 查看创建表的SQL语句
show create table 表名;
-- 修改表名
alter table 表名 rename to 新的表名;
-- 添加一列
alter table 表名 add 列名 数据类型;
-- 删除列
alter table 表名 drop 列名;
-- 删除表
drop table 表名;
drop table  if exists 表名 ;

Linguagem de manipulação de dados DML (Data Manipulation Language)

Um, aumente a inserção em

-- 写全所有列名
insert into 表名(列名1,列名2,...列名n) values(值1,值2,...值n);
-- 不写列名(所有列全部添加)
insert into 表名 values(值1,值2,...值n);
-- 插入部分数据
insert into 表名(列名1,列名2) values(值1,值2);

Dois, deletar deletar

-- 删除表中数据
delete from 表名 where 列名  = 值;
-- 删除表中所有数据
delete from 表名;
-- 删除表中所有数据(高效 先删除表,然后再创建一张一样的表。)
truncate table 表名;

Três, modifique a atualização

-- 不带条件的修改(会修改所有行)
update 表名 set 列名 = 值;
-- 带条件的修改
updata 表名 set 列名 = 值 where 列名=值;

Linguagem de consulta de dados DQL (Data Query Language)

Existem muitas instruções de consulta, o básico não será apresentado aqui. Apresenta principalmente consulta de classificação, função agregada, consulta difusa, consulta de grupo, consulta de paginação, junção interna, junção externa, subconsulta

1. Palavras-chave básicas

 ENTRE ... E (entre o quê) e  IN (definir)

-- 查询年龄大于等于20 小于等于30				
SELECT * FROM student WHERE age >= 20 &&  age <=30;
SELECT * FROM student WHERE age >= 20 AND  age <=30;
SELECT * FROM student WHERE age BETWEEN 20 AND 30;
				
-- 查询年龄22岁,18岁,25岁的信息
SELECT * FROM student WHERE age = 22 OR age = 18 OR age = 25
SELECT * FROM student WHERE age IN (22,18,25);

 é nulo ( não é um valor nulo), como (consulta difusa), distinto (remoção de valores duplicados)

-- 查询英语成绩不为null
SELECT * FROM student WHERE english  IS NOT NULL;
	
 _:单个任意字符
 %:多个任意字符
-- 查询姓马的有哪些? like
SELECT * FROM student WHERE NAME LIKE '马%';
-- 查询姓名第二个字是化的人			
SELECT * FROM student WHERE NAME LIKE "_化%";				
-- 查询姓名是3个字的人
SELECT * FROM student WHERE NAME LIKE '___';					
-- 查询姓名中包含德的人
SELECT * FROM student WHERE NAME LIKE '%德%';

-- 关键词 DISTINCT 用于返回唯一不同的值。
-- 语法:SELECT DISTINCT 列名称 FROM 表名称
SELECT DISTINCT NAME FROM  student ;

Dois, classificar a consulta por ordem de

Sintaxe : ordem por cláusula

          ordenar classificando o campo 1, método de classificação 1, classificando o campo 2, método de classificação 2 ...

Nota:
            Se houver várias condições de classificação, a segunda condição será julgada apenas quando o valor da condição atual for o mesmo.

-- 例子
SELECT * FROM person ORDER BY math; --默认升序
SELECT * FROM person ORDER BY math desc; --降序

3. Função de agregação: pegue uma coluna de dados como um todo e execute cálculos verticais.

1.contar: contar o número

2.max: calcula o valor máximo

3.min: calcula o valor mínimo

4.sum: calcule a soma

5.avg: calcule a média

Quatro, argamassa de consulta de grupo por

      Sintaxe : grupo por campo de grupo;

      Nota : Campos a serem consultados após o agrupamento: campos de agrupamento, funções agregadas

-- 按照性别分组。分别查询男、女同学的平均分
SELECT sex , AVG(math) FROM student GROUP BY sex;

-- 按照性别分组。分别查询男、女同学的平均分,人数
 SELECT sex , AVG(math),COUNT(id) FROM student GROUP BY sex;

--  按照性别分组。分别查询男、女同学的平均分,人数 要求:分数低于70分的人,不参与分组
SELECT sex , AVG(math),COUNT(id) FROM student WHERE math > 70 GROUP BY sex;

 --  按照性别分组。分别查询男、女同学的平均分,人数 要求:分数低于70分的人,不参与分组,分组之后。人数要大于2个人
SELECT sex , AVG(math),COUNT(id) FROM student WHERE math > 70 GROUP BY sex HAVING COUNT(id) > 2;
SELECT sex , AVG(math),COUNT(id) 人数 FROM student WHERE math > 70 GROUP BY sex HAVING 人数 > 2;

Cinco, consulta de paginação

    1. Sintaxe : limite de índice inicial, o número de entradas por página;
    2. Fórmula : índice inicial = (número da página atual-1) * número de entradas exibidas por página
    3. limite é um "dialeto" do MySQL 

-- 每页显示3条记录 

SELECT * FROM student LIMIT 0,3; -- 第1页

SELECT * FROM student LIMIT 3,3; -- 第2页

SELECT * FROM student LIMIT 6,3; -- 第3页

Seis, consulta de junção interna:

   1. De quais tabelas consultar os dados

   2. Quais são as condições

   3. Quais campos consultar

1. Conexão interna implícita: use a condição where para eliminar dados inúteis

-- 查询员工表的名称,性别。部门表的名称
SELECT emp.name,emp.gender,dept.name FROM emp,dept WHERE emp.`dept_id` = dept.`id`;

SELECT 
    t1.name, -- 员工表的姓名
    t1.gender,-- 员工表的性别
    t2.name -- 部门表的名称
FROM
    emp t1,
    dept t2
WHERE 
    t1.`dept_id` = t2.`id`;

 2. União interna explícita

-- 语法: 
select 字段列表 from 表名1 [inner] join 表名2 on 条件
-- 例如:
SELECT * FROM emp INNER JOIN dept ON emp.`dept_id` = dept.`id`;   
SELECT * FROM emp JOIN dept ON emp.`dept_id` = dept.`id`; 

 Sete, consulta de junção externa

1. Consulta de junção externa esquerda de todos os dados na tabela esquerda e sua interseção.

-- 语法:select 字段列表 from 表1 left [outer] join 表2 on 条件;
-- 例子:
-- 查询所有员工信息,如果员工有部门,则查询部门名称,没有部门,则不显示部门名称
SELECT  t1.*,t2.`name` FROM emp t1 LEFT JOIN dept t2 ON t1.`dept_id` = t2.`id`;

 2. Right outer join - consulta todos os dados da tabela certa e sua interseção.

-- 语法:
select 字段列表 from 表1 right [outer] join 表2 on 条件;
-- 例子:
SELECT  * FROM dept t2 RIGHT JOIN emp t1 ON t1.`dept_id` = t2.`id`;

 8. Subconsulta: consulta aninhada na consulta

-- 查询工资最高的员工信息
-- 1 查询最高的工资是多少 9000
SELECT MAX(salary) FROM emp;

-- 2 查询员工信息,并且工资等于9000的
SELECT * FROM emp WHERE emp.`salary` = 9000;

 -- 一条sql就完成这个操作。这就是子查询
SELECT * FROM emp WHERE emp.`salary` = (SELECT MAX(salary) FROM emp);

   1. O resultado da subconsulta é uma única linha e uma única coluna

 As subconsultas podem ser usadas como condições, usando operadores para julgar . Operador:>> = << = =

-- 查询员工工资小于平均工资的人
SELECT * FROM emp WHERE emp.salary < (SELECT AVG(salary) FROM emp);

   2. O resultado da subconsulta é várias linhas e uma única coluna:

   A subconsulta pode ser usada como uma condição, use o operador em para julgar

-- 查询'财务部'和'市场部'所有的员工信息
SELECT id FROM dept WHERE NAME = '财务部' OR NAME = '市场部';
SELECT * FROM emp WHERE dept_id = 3 OR dept_id = 2;

-- 子查询
SELECT * FROM emp WHERE dept_id IN (SELECT id FROM dept WHERE NAME = '财务部' OR NAME = '市场部');

   3. O resultado da subconsulta é várias linhas e colunas:

   A subconsulta pode participar da consulta como uma tabela virtual

-- 查询员工入职日期是2011-11-11日之后的员工信息和部门信息
-- 子查询
SELECT * FROM dept t1 ,(SELECT * FROM emp WHERE emp.`join_date` > '2011-11-11') t2 WHERE t1.id = t2.dept_id;

-- 普通内连接
SELECT * FROM emp t1,dept t2 WHERE t1.`dept_id` = t2.`id` AND t1.`join_date` >  '2011-11-11'

 Linguagem de controle de dados DCL (Data Control Language)

Gerenciar usuários

Adicionar usuário

语法:CREATE USER '用户名'@'主机名' IDENTIFIED BY '密码';

deletar usuários

语法:DROP USER '用户名'@'主机名';

gestão de autoridade

Permissões de consulta

-- 查询权限
SHOW GRANTS FOR '用户名'@'主机名';
SHOW GRANTS FOR 'lisi'@'%';

Permissão concedida

-- 授予权限
grant 权限列表 on 数据库名.表名 to '用户名'@'主机名';

-- 给张三用户授予所有权限,在任意数据库任意表上
GRANT ALL ON *.* TO 'zhangsan'@'localhost';

Revogar autoridade

-- 撤销权限:
revoke 权限列表 on 数据库名.表名 from '用户名'@'主机名';
REVOKE UPDATE ON db3.`account` FROM 'lisi'@'%';

  Criar não é fácil, se este blog é útil para você, lembre-se de deixar uma mensagem + curtir.  

Acho que você gosta

Origin blog.csdn.net/promsing/article/details/112793260
Recomendado
Clasificación