Mysql

mysql-黑马-day01

2020-10-09  本文已影响0人  垃圾简书_吃枣药丸

一、 密码与连接

二、 索引

2.1 索引(index)的概述:

索引是帮助mysql高效查询数据结构!这些索引以某种方式指向(或引用)了mysql中的数据。

2.2 索引的优势与劣势

2.3 索引的结构

Mysql中的索引是在存储引擎中实现的。

2.3.1 BTREE结构


image.png

2.3.2 B+TREE结构


image.png
image.png

2.3.3 Mysql中的B+TREE


image.png image.png

2.4 索引的分类


image.png

2.5 索引操作语法
2.5.1 创建索引

2.5.2 查看索引

2.5.3 删除索引

2.5.4 通过alter命令修改表-修改索引

2.6 索引的设计原则


image.png image.png

三、 视图

视图就是一张虚拟的表,里面封装了一条select语句。


# 创建视图
create view view_supervisor as
select visit_user_id, visit_user_name, visit_user_position_name, visit_user_mobile
from project_user_visit
where creation_date < current_date;

# 从视图查询数据
select *
from view_supervisor
where visit_user_name like '%宋%';

# 操作视图更新数据源的数据
update view_supervisor
set visit_user_name='小宋宋'
where visit_user_name = '小宋';

# 修改视图
alter view view_supervisor as select...;

# 查询视图和查看表一样
show tables;

# 查看创建视图的语句
show create view view_supervisor;

# 删除视图
drop view view_supervisor;

四、 存储过程和存储函数

事先经过编译并存储在数据库中的一段SQL语句的集合,调用存储过程可以简化开发人员的工作,减少数据传输,对于提高数据处理的效率是有好处的。

4.1 操作

# 创建存储过程
create procedure pro_test1()
begin
    # SQL语句
    select * from project_user_visit;
end;

# 调用
call pro_test1();

# 查询存储过程
show procedure status;

# 查询存储过程创建语句
show create procedure pro_test1;

# 删除存储过程
drop procedure pro_test1;

4.2 存储过程变量

create procedure pro_test2()
begin
   # 声明一个变量
   declare num int default 10;
   # 变量赋值
   set num = 100;
   select count(*)
   # 将查询结果赋值给变量
   into num
   from project_user_visit;
   select concat('当前num值为:', num);
end;

4.3 条件

if condition then statement_list;
  elseif condition then statement_list;
  else statement_list;
end if;
create procedure pro_test2()
begin
    # 声明一个变量
    declare num int default 10;
    declare msg varchar(255);
    # 变量赋值
    set num = 100;
    select count(*)
           # 将查询结果赋值给变量
    into num
    from project_user_visit;
    select concat('当前num值为:', num);
    if num > 10000 then
        SET msg = '多于1000条';
    elseif num = 10000 then
        SET msg = '等于10000条';
    else
        SET msg = '少于10000条';
    end if;
    select concat(msg);
end;

4.4 传递参数给存储过程

create procedure p_name([in/out/inout] 参数名 参数类型)
begin

end;
# 演示入参与出参
create procedure pro_test2(in height int, out formatted_str varchar(255))
begin
    if height <= 150 then
        SET formatted_str = '袖珍小人';
    elseif height < 190 then
        SET formatted_str = '标准身材';
    else
        SET formatted_str = '实在是高🐂';
    end if;
end;

# 调用
call pro_test2(151, @_desc);
# 读取返回值
select @_desc;
image.png

4.5 more ... skip ...

五、 触发器

image.png
image.png
-- 记录日志,增/改/删
create trigger trigger_insert_puv
    -- before/after insert/update/delete
    after insert
    -- 操作的表
    on project_user_visit
    -- 行级触发器
    for each row
-- 具体逻辑
begin
    insert into project_user_visit_ops_log(id, operation_type, operation_time, operation_table_id,
                                           operation_params)
                                           -- 使用new来引用新插入的数据
    values (null, 'insert', now(), new.id, concat('附加信息:', new.visit_user_name));
end;


insert into project_user_visit(id, visit_user_name)
values (1, '喜欢'),
       (2, '天文'),
       (3, '的'),
       (4, 'Pony'),
       (5, '站长');
image.png
image.png

日志记录成功。

-- 记录update操作
create trigger trigger_update_puv
    after update
    on project_user_visit
    for each row
begin
    insert into project_user_visit_ops_log(id, operation_type, operation_time, operation_table_id, operation_params)
    values (null, 'update', now(), old.id,
            concat('修改之前的name为:', old.visit_user_name, ';修改之后的name为: ', new.visit_user_name));
end;

update project_user_visit
set visit_user_name='热爱'
where id = 1;
image.png image.png

-- 记录delete操作
create trigger trigger_delete_puv
    after delete
    on project_user_visit
    for each row
begin
    insert into project_user_visit_ops_log(id, operation_type, operation_time, operation_table_id, operation_params)
    VALUES (null, 'delete', now(), old.id, concat('被删除的name为:', old.visit_user_name));
end;

delete
from project_user_visit
where id = '1';
image.png
image.png
-- 查看触发器
show triggers;
-- 删除触发器
drop trigger trigger_delete_puv;
上一篇 下一篇

猜你喜欢

热点阅读