sql语句,索引,视图,存储过程

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: sql语句,索引,视图,存储过程

       数据库是按照数据结构来组织,存储和管理数据的仓库;是一个长期存储在计算机内的,有组织的,可共享的,统一管理的大量数据的集合;访问数据库在内存的数据,数据需要落盘后才会返回结果;

       mysql中oltp是用B+树或lsm存储数据;olap是用列式存储的;

       DML是数据操作语言的简称,即增删改;

       DQL是数据查询语言简称,即select;

       DDL是数据定义语言简称,即create创建,alter修改,drop删除表,试图,数据库对像等;

       DCL是数据控制语言简称,grant授予用户权限,revoke收回用户权限;

       TCL是事务控制语言简称,commit事务提交,rollback事务回滚;

mysql内部执行方式,网络处理模型使用了io多路复用select+阻塞io,每条线程处理一条连接的数据,所以mysql命令处理是多线程并发处理的模式,线程的默认配置最大数为151;mysql是采用短链接的方式,如果连接长时间没有使用,会断开这条连接,回收对应的线程资源;

mysql体系结构

       connection pool提前分配了一些线程,当一条连接到达,我们就分配线程给这条连接;其作用有鉴权密码验证,线程复用,连接限制,检查内存,caches等;

       sql interface对sql语言进行词法语法分析,生成语法树;parser用于过滤表等是否存在的情况;Optimizer优化器用于制定执行计划,因为不同的sql语句有不同的执行方式,选择执行成本最小的计划;Caches&Buffers用于缓存热点数据,如果缓存中没有对应的数据就得检索磁盘加载数据;

       mysql默认使用的可插拔引擎是InnoDB;

数据库设计三范式和反范式

       三范式是为了降低空间,其内容有列不可分,依赖主键(联合索引),在依赖主键的基础上直接依赖;反范式是通过增加空间来减少运行时间,允许冗余存储,为了提升查询效率;

CRUD

       百分之九十以上的事情都是在做CRUD,百分之九考虑表是怎么设计的,剩下百分之一的时间可能就是做些索引优化之类的事情;

       crud中有五大约束,not null 非空约束,auto_increment 自增约束,unique 唯一约束,primary 主键约束,foreign 外键约束;

       删除数据有三种方式,drop删除整张表,表结构和表数据,包括索引,约束,触发器等,速度最快,不能回滚;truncate删除表数据,其他保留,速度较快,不能回滚,以页为单位进行删除;delete删除部分或全部数据,其他保留,条件删除,速度最慢,可以回滚,逐行删除;

高级查询

       1)分组聚合

               去除重复,合并重复,通过聚合函数实现;

       2)联表查询

               把表想象成集合,分为内联inner join,内联是取交集的意思;外联left join或right join或full join;

       3)子查询

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
1月前
|
存储 SQL 数据库
SQL Server存储过程的优缺点
【10月更文挑战第18天】SQL Server 存储过程具有提高性能、增强安全性、代码复用和易于维护等优点。它可以减少编译时间和网络传输开销,通过权限控制和参数验证提升安全性,支持代码共享和复用,并且便于维护和版本管理。然而,存储过程也存在可移植性差、开发和调试复杂、版本管理问题、性能调优困难和依赖数据库服务器等缺点。使用时需根据具体需求权衡利弊。
|
28天前
|
存储 SQL 缓存
SQL Server存储过程的优缺点
【10月更文挑战第22天】存储过程具有代码复用性高、性能优化、增强数据安全性、提高可维护性和减少网络流量等优点,但也存在调试困难、移植性差、增加数据库服务器负载和版本控制复杂等缺点。
|
30天前
|
SQL Oracle 关系型数据库
SQL优化-使用联合索引和函数索引
在一次例行巡检中,发现一条使用 `to_char` 函数将日期转换为字符串的 SQL 语句 CPU 利用率很高。为了优化该语句,首先分析了 where 条件中各列的选择性,并创建了不同类型的索引,包括普通索引、函数索引和虚拟列索引。通过对比不同索引的执行计划,最终确定了使用复合索引(包含函数表达式)能够显著降低查询成本,提高执行效率。
|
1月前
|
存储 SQL 数据库
Sql Server 存储过程怎么找 存储过程内容
Sql Server 存储过程怎么找 存储过程内容
31 1
|
1月前
|
存储 SQL 数据库
SQL Server存储过程的优缺点
【10月更文挑战第17天】SQL Server 存储过程是预编译的 SQL 语句集,存于数据库中,可重复调用。它能提高性能、增强安全性和可维护性,但也有可移植性差、开发调试复杂及可能影响数据库性能等缺点。使用时需权衡利弊。
|
1月前
|
SQL 关系型数据库 MySQL
如何确认SQL用了索引:详细技巧与方法
在数据库管理中,索引是提高SQL查询性能的重要手段
|
1月前
|
SQL 存储 关系型数据库
SQL默认索引是什么:深入解析与技巧
在SQL数据库中,索引是一种用于提高查询性能的重要数据结构
|
1月前
|
SQL 存储 关系型数据库
SQL默认索引是什么
在SQL数据库中,索引是一种用于提高查询性能的数据结构
|
16天前
|
存储 SQL NoSQL
|
1月前
|
存储 SQL 关系型数据库
MySql数据库---存储过程
MySql数据库---存储过程
33 5