mysql-黑马-day01

本文涉及的产品
RDS DuckDB + QuickBI 企业套餐,8核32GB + QuickBI 专业版
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
简介: mysql-黑马-day01

一、 密码与连接



  • 修改密码:

set password = password('xxx');

  • 授权远程访问: grant all privileges on *.* to 'root' @'%' identified by 'pwd';
  • 刷新权限: flush privileges;


二、 索引



2.1 索引(index)的概述:

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

2.2 索引的优势与劣势

  • 优势
  • 由于索引类似于目录,所以可以快速查询数据
  • 通过索引对数据进行排序,降低数据排序成本,降低CPU消耗。
  • 劣势:
  • 索引也需要占用空间。
  • 加快了查询速度,但是降低了新增/修改/删除的效率,因为更新数据时,索引也需要相应更新。

2.3 索引的结构

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

  • mysql支持的4中索引:
  • BTREE索引(B+TREE): 最常见的索引类型,大部分存储引擎都支持。
  • HASH索引: 只有Memory引擎支持,使用场景简单。
  • R-tree索引: 空间索引是MyISAM引擎的一个特殊索引类型,主要用于地理空间数据。
  • Full-text: 全文索引也是MyISAM引擎的一个特殊索引类型,主要用于全文索引,Innodb从5.6版本也开始支持全文索引。

2.3.1 BTREE结构


image.png

CNGAHEKQMFWLTZDPRXYS


image.png


2.3.2 B+TREE结构


image.png

image.png


2.3.3 Mysql中的B+TREE


image.pngimage.png

2.4 索引的分类

image.png


2.5 索引操作语法

2.5.1 创建索引

  • create [UNIQUE|FULLTETXT|SPATIAL] index index_name [USING index_type] ON table_name(index_col_name,...)
    create index idx_city_name using btree on project_user_visit (visit_user_name);
  • mysql中主键会自动创建主键索引

2.5.2 查看索引

  • show index from project_user_visit;


image.png

格式化show index from project_user_visit\G;


image.png

image.png


2.5.3 删除索引

  • drop index index_name on table_name;
  • drop index idx_city_name on project_user_visit;

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

  • alter table table_name add index index_name(col_list)

2.6 索引的设计原则


image.png


image.png

三、 视图



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


  • 优点

image.png


  • 操作

# 创建视图
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 存储过程变量

  • 变量声明在begin和end之间
  • 定义: declare ...
  • 给变量赋值:
  1. SET variable=xxx;
  2. SELECT INTO variable FROM ...

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;
  • demo

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;
  • demo

# 演示入参与出参
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

  • Demo: 演示使用触发器 记录增/改/删日志

-- 记录日志,增/改/删
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.pngimage.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;


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
机器学习/深度学习 人工智能 前端开发
未来趋势:人工智能在前端开发中的应用
随着人工智能技术的快速发展,前端开发领域也迎来了新的变革。本文将深入探讨人工智能在前端开发中的应用现状,并展望未来的发展趋势,带领读者一窥未来前端开发的可能面貌。
|
5月前
|
消息中间件 JSON 监控
​​​​​​​淘宝促销API实战:自动发放优惠券,智能提升转化率!
本文详解如何利用淘宝开放平台促销API实现优惠券自动发放,通过用户行为触发、精准定向与批量管理,提升转化率15%-30%。涵盖创建、发放、追踪全流程,助力商家实现高效、智能营销。(238字)
379 0
|
5月前
|
存储 编解码 JSON
16 RPC 实战:剖析 gRPC 源码,动手实现一个完整的 RPC
本课通过剖析gRPC源码,实战实现完整RPC框架。从动态代理、序列化到HTTP/2协议,详解请求发送与接收流程,涵盖Stub生成、数据封装、Frame传输、Netty编解码等核心机制,助你掌握高性能RPC设计精髓。
|
Dubbo Java 应用服务中间件
Spring Cloud Dubbo:微服务通信的高效解决方案
【10月更文挑战第15天】随着信息技术的发展,微服务架构成为企业应用开发的主流。Spring Cloud Dubbo结合了Dubbo的高性能RPC和Spring Cloud的生态系统,提供高效、稳定的微服务通信解决方案。它支持多种通信协议,具备服务注册与发现、负载均衡及容错机制,简化了服务调用的复杂性,使开发者能更专注于业务逻辑的实现。
418 2
|
人工智能 前端开发 API
OpenAI 12天发布会内容全纪录!一文快速回顾获知亮点信息,原文附发布会中文字幕视频
OpenAI 于12月5日宣布将举行为期12天的系列发布活动,期间每天发布一个产品或样品,包括备受期待的AI视频生成工具Sora和新的推理模型。本文将介绍这12天的发布会每日的发布内容和相关亮点信息。
1176 82
|
安全 网络协议 算法
HTTPS网络通信协议揭秘:WEB网站安全的关键技术
HTTPS网络通信协议揭秘:WEB网站安全的关键技术
1273 4
HTTPS网络通信协议揭秘:WEB网站安全的关键技术
|
Dubbo 网络协议 Java
性能基础之常见RPC框架浅析
【4月更文挑战第23天】性能基础之常见RPC框架浅析
963 1
性能基础之常见RPC框架浅析
|
存储 关系型数据库 MySQL
解读 MySQL 容器信息:`docker inspect` 字段详解
解读 MySQL 容器信息:`docker inspect` 字段详解
1395 1
|
存储 大数据 分布式数据库
什么是 Apache HBase?
【8月更文挑战第31天】
485 0
真正解决:gpg --verify sig: 无法检查签名:找不到公钥
真正解决:gpg --verify sig: 无法检查签名:找不到公钥
1657 0

热门文章

最新文章