Mysql DDL DML DCL DQL语句

文章目录

    • DDL语句
        • 1. 库操作
        • 2. 表操作
    • DML语句
        • 1. 插入数据
        • 2. 更新数据
        • 3. 删除数据
    • DCL语句
        • 创建删除用户
        • 用户权限
        • 用户密码管理
    • DQL语句
        • 1. 简单的查询
        • 2. 高级查询
        • 3. 查询结果参与运算
        • 4. 多表关联查询

DDL语句

数据库定义语言
创造框架
数据库、表、视图、索引、存储过程

1. 库操作

select version(),current_date  #查询数据库的版本和系统时间
create database 库名;   # 创建库
show databases;       # 列出所有的库
use 库名 ;            # 进入库 
select database();    # 查询当前所在的库

drop database 库名;    #删除库 

查询库的使用状况

2. 表操作

create table 表名(字段1 类型,字段2 类型...);

show tables;                                    # 查看库里所有的表
desc 表名;  查询表结构
alter table 修改前表名称 rename 修改后表名称;      #修改表名称
drop table 表名;       # 删除表 
create table 新表名 as select * from 旧表名;     # 复制表

show index from 表名 ;                         #查看索引
alter table 表名称 add index 索引名称 (字段名)#添加索引
drop index on 表名;                            #删除索引,主键索引不能直接删除alter table 表名 drop primary key;
#普通索引(INDEX)   唯一索引(UNIQUE)  主键索引(PRIMARY KEY)

alter table 表名称 add Pprimary key (字段名)#添加主键

DML语句

数据库操纵语言
添加数据
插入数据、删除数据、更新数据

1. 插入数据

 #一次性插入多行。
insert into user(字段1,字段2..) values(数值1 ‘数值2..),(数值1 ‘数值2..)...(数值1 ‘数值2..); 
 #插入查询的数据            
insert into 要插入的表名(字段1,字段2..) select 字段1,字段2.. from 查询的表;

2. 更新数据

update 表名 set 字段1=‘新数据’;                    # 更新这个字段所有数据
update 表名 set 字段1=‘新数据’ where 字段2=‘数据’;  # 更新这个字段指定的数据

3. 删除数据

truncate table 表名;              # 只删除表数据,不删除表结构
select *from 表名 where 字段1=‘’; # 删除指定的列

DCL语句

数据库控制语言
控制用户的访问权限grant、revoke

创建删除用户

create user '用户名' @ '主机名' identifide by '密码';  #创建用户
drop user '用户名'@'主机名';                          #删除用户    

用户权限

show grants for test;                                  #查询用户权限
create 权限1,权限2 on 数据库名.表名 to '用户名'@'主机名';   #授权
revoke 权限1,权限2 on 数据库.数据表 from '用户'@'IP地址'#撤销权限 - 整个库,使用 on datebase.*; - 整个表:使用 on datebase.table;
FLUSH PRIVILEGES;       # 刷新使用户权限生效

可授权列表: 
    SELECT:表示授予用户可以使用 SELECT 语句访问特定数据库中所有表和视图的权限。
    INSERT:表示授予用户可以使用 INSERT 语句向特定数据库中所有表添加数据行的权限。
    DELETE:表示授予用户可以使用 DELETE 语句删除特定数据库中所有表的数据行的权限。
    UPDATE:表示授予用户可以使用 UPDATE 语句更新特定数据库中所有数据表的值的权限。
    REFERENCES:表示授予用户可以创建指向特定的数据库中的表外键的权限。
    CREATE:表示授权用户可以使用 CREATE TABLE 语句在特定数据库中创建新表的权限。
    ALTER:表示授予用户可以使用 ALTER TABLE 语句修改特定数据库中所有数据表的权限。
    SHOW VIEW:表示授予用户可以查看特定数据库中已有视图的视图定义的权限。
    CREATE ROUTINE:表示授予用户可以为特定的数据库创建存储过程和存储函数的权限。
    ALTER ROUTINE:表示授予用户可以更新和删除数据库中已有的存储过程和存储函数的权限。
    INDEX:表示授予用户可以在特定数据库中的所有数据表上定义和删除索引的权限。
    DROP:表示授予用户可以删除特定数据库中所有表和视图的权限。
    CREATE TEMPORARY TABLES:表示授予用户可以在特定数据库中创建临时表的权限。
    CREATE VIEW:表示授予用户可以在特定数据库中创建新的视图的权限。
    EXECUTE ROUTINE:表示授予用户可以调用特定数据库的存储过程和存储函数的权限。
    LOCK TABLES:表示授予用户可以锁定特定数据库的已有数据表的权限。
    SHOW DATABASES:表示授权可以使用SHOW DATABASES语句查看所有已有的数据库的定义的权限。
    ALL或ALL PRIVILEGES:表示以上所有权限。

用户密码管理

mysqladmin -uroot -p password 新密码 (不需要加引号)#在shell中修改root密码
set password for '用户名'@'主机名'= password('新密码'); #在数据库中修改普通用户密码
lush privileges;            #刷新


validate_password_length=1; #设置密码长度为1个
validate_password_number_count=2; #设置密码数字最少为2个
flush privileges;           #刷新
参数解释:
validate_password_length :#密码最少长度,默认值是8最少是0
validate_password_dictionary_file:#用于配置密码的字典文件,字典文件中存在的密码不得使用。
validate_password_policy: #代表的密码策略,默认是MEDIUM
validate_password_number_count :#最少数字字符数,默认1最小是0
validate_password_mixed_case_count :#最少大写和小写字符数(同时有大写和小写),默认为1最少是0
validate_password_special_char_count :#最少特殊字符数,默认1最小是0

DQL语句

数据库查询语言
查询数据 select

1. 简单的查询

select * from 表名                  # 查询表内所有内容
select 字段1 字段2 ... from 表名     # 查询指定字段的数据
select distinct 字段名 from 表名;    # 清除重复值
select 字段名 1 as 别名, 字段名 2 as 别名... from 表名;  #查询结果,赋予字段显示别名

2. 高级查询

比较运算符查询
- 大于 <小于 <=小于等于 >=大于等于 =等于 <>!=不等于   

逻辑运算符查询
-- and(&&) 多个条件同时满足 or(||) 多个条件其中一个满足 not(!) 不满足

in 关键字查询
select * from 表名 where id in (1,3,5);  # 查询这张表中id字段中包含1,3,5,的行

模糊查询
like 和 % 的运用
select * from 表名 where name like '福%';   #查询表 name关键字 以福字开头的行
select * from 表名 where name like '%福';   #查询表 name关键字 以福字结尾的行
select * from 表名 where name like '福__';  #查询表 name关键字 查询福字且有三个字的行

函数查询
select max(字段1) from employee5;    # 查询字段1 最大值
max() 最大值  
min()最小值  
avg()平均值  
now()  现在的时间 【select now()

3. 查询结果参与运算

select 列名 1(必须是数值) + 列名 2(必须是数值) from 表名;  # 列名2也可修改成固定的数值

4. 多表关联查询

内连接:
在做多张表查询时,这些表中应该存在着有关联的两个字段,组合成一条记录。只连接匹配到的行
例如:只找出有相同部门的员工
select 1.编号,1.员工,2.部门 from 1, 2表  where  1.编号 =  2.编号;

外连接:
在做多张表查询时,所需要的数据,除了满足关联条件的数据外,还有不满足关联条件的数据。此时需要使用外连接.外连接分为三种
左外连接:表A left [outer] join 表B  on 关联条件,表A是主表,表B是从表
右外连接:表A right [outer] join 表B  on 关联条件,表B是主表,表A是从表
全外连接:表A  full [outer] join 表B on 关联条件,两张表的数据不管满不满足条件,都做显示。

======================================================================================================================================================================================================================================================================================================
辛苦浏览观看,如果对你有帮助,请顺手点个赞吧 (σ゚∀゚)σ…:*☆

你可能感兴趣的:(Mysql,mysql,linux,运维)