笔记来自于黑马程序员课程 引用站外地址 黑马程序员JavaWeb基础教程 Java web从入门到企业实战完整版 mysql高级 今日目标 掌握约束的使用 掌握表关系及建表原则 重点掌握多表查询操作...注意:MySQL不支持检查约束。 这样是不是就没办法保证年龄在指定的范围内了?从数据库层面不能保证,以后可以在java代码中进行限制,一样也可以实现要求。...,必须使所有的数据都保持一致状态 隔离性(Isolation) :多个事务之间,操作的可见性 持久性(Durability) :事务一旦提交或回滚,它对数据库中的数据的改变就是永久的 ==说明:== mysql
BEFORE INSERT,BEFORE DELETE,BEFORE UPDATE AFTER INSERT,AFTER DELETE,AFTER UPDATE 创建触发器 mysql> create...table log(id int primary key auto_increment not null, -> time datetime); mysql> delimiter || mysql...where id = stuid -> ; -> end -> || Query OK, 0 rows affected (0.29 sec) mysql> delimiter...sec) mysql> select * from v_stu; // 查看表中索引 mysql> show index from student; // 创建索引 mysql> create index...stu_index on student(index); // 删除索引 mysql> drop index stu_index on student;
Mysql高级01 MySQL高级课程简介 序号 01** 02** 03** 04** 1 基本硬件知识 体系结构 应用优化 MySQL 常用工具 2 索引 存储引擎 查询缓存优化 MySQL 日志...3 视图 优化SQL步骤 内存管理及优化 MySQL 主从复制 4 存储过程和函数 索引使用 MySQL锁问题 5 触发器 SQL优化 常用SQL技巧 1.基本硬件知识(了解) 1.1计算机工作原理...2.索引 2.1索引概述 MySQL官方对索引的定义为:索引(index)是帮助MySQL高效获取数据的数据结构(有序)。...在数据 之外,数据库系统还维护者满足特定查找算法的数据结构,这些数据结构以某种方式引用(指向)数 据, 这样就可以在这些数据结构上实现高级查找算法,这种数据结构就是索引。...2.3.2MySQL中的B+Tree MySql索引数据结构对经典的B+Tree进行了优化。
一、MySQL存储过程和函数 1.存储过程和函数的概念 存储过程和函数是 事先经过编译并存储在数据库中的一段 SQL 语句的集合 2.存储过程和函数的好处 存储过程和函数可以重复使用,减轻开发人员的工作量...将一些业务逻辑在数据库层面来实现,可以减少代码层面的业务处理 3.存储过程和函数的区别 函数必须有返回值 存储过程没有返回值 4.创建存储过程 小知识 /* 该关键字用来声明sql语句的分隔符,告诉MySQL...(实际参数); -- 调用stu_group存储过程 CALL stu_group(); 6.查看存储过程 查看存储过程语法 -- 查询数据库中所有的存储过程 标准语法 SELECT * FROM mysql.proc...8.9游标 游标的概念 游标可以遍历返回的多行结果,每次拿到一整行数据 在存储过程和函数中可以使用游标对结果集进行循环的处理 简单来说游标就类似于集合的迭代器遍历 MySQL中的游标只能用在存储过程和函数中
我们可以定义视图 子查询 普通查询 查询每位学生的各科成绩 mysql> select sname as 姓名, -> (select scores.score from scores inner
高级查询 关键字书写顺序 关键字执行顺序 select:投影结果 1 5 from:定位到表 2 1 where:分组前第一道过滤 ...select *,row_number() over(order by 主键列) as myid from 表 ) as temp where myid between 起始号码 and 每页数据量 --mysql...加快数据访问速度 临时表存在于系统数据库 SQL Sever : 存在于系统数据库tempdb #表名:局部临时表: 只对当前会话有效 ##表名:全局临时表 所有会话共享 MySQL...: 在会话断开销毁 所有临时表都是服务于当前连接 临时表只在当前连接可见,当关闭连接时,Mysql会自动删除表并释放所有空间。...在mysql中是一个摆设 select *; select * from dual; select * from dual; 报错 oracle中 必须使用 from dual; select *
MySQL高级课程简介 序号 01 02 03 04 1 基本硬件知识 体系结构 应用优化 MySQL 常用工具 2 索引 存储引擎 查询缓存优化 MySQL 日志 3 视图 优化SQL步骤 内存管理及优化...MySQL 主从复制 4 存储过程和函数 索引使用 MySQL锁问题 5 触发器 SQL优化 常用SQL技巧 1....索引 2.1 索引概述 MySQL官方对索引的定义为:索引(index)是帮助MySQL高效获取数据的数据结构(有序)。...在数据之外,数据库系统还维护者满足特定查找算法的数据结构,这些数据结构以某种方式引用(指向)数据, 这样就可以在这些数据结构上实现高级查找算法,这种数据结构就是索引。...2.3.2 MySQL中的B+Tree MySql索引数据结构对经典的B+Tree进行了优化。
MySQL的优化方式有很多,大致我们可以从以下几点来优化MySQL: 从设计上优化 从查询上优化 从索引上优化 从存储上优化 查看SQL执行频率 MySQL 客户端连接成功后,通过 show [session...show processlist:该命令查看当前MySQL在进行的线程,包括线程的状态、是否锁表等,可以实 时地查看 SQL 的执行情况,同时对一些锁表操作进行优化。...的最低阈值时间 set global long_query_time=4; 定位低效率执行SQL-show processlist show processlist; 1) id列,用户登录mysql...show profile分析SQL Mysql从5.0.37版本开始增加了对 show profiles 和 show profile 语句的支持。...支持进一步选择all、cpu、block io 、context switch、 page faults等明细类型类查看MySQL在使用什么资源上耗费了过高的时间。
Mysql锁问题 5.1 锁概述 锁是计算机协调多个进程或线程并发访问某一资源的机制(避免争抢)。...5.3 Mysql 锁 相对其他数据库而言,MySQL的锁机制比较简单,其最显著的特点是不同的存储引擎支持不同的锁机制。...5.2 MyISAM 表锁 MyISAM 存储引擎只支持表锁,这也是MySQL开始几个版本中唯一支持的锁类型。...高级','2088-01-01','1'); 执行插入, 直接报错 , 由于当前tb_book 获得的是 读锁, 不能执行更新操作。...客户端 二 : 7) 执行插入操作 insert into tb_book values(null,'Mysql高级','2088-01-01','1'); 当在客户端一中释放锁指令 unlock tables
MySQL 也不例外。...日志分类 错误日志 二进制日志 查询日志 慢查询日志 错误日志 错误日志是 MySQL 中最重要的日志之一,它记录了当 mysqld 启动和停止时,以及服务器在运行 过程中发生任何严重错误时的相关信息...该日志是默认开启的 , 默认存放目录为 mysql 的数据目录, 默认的日志文件名为 hostname.err(hostname是主机名)。...此日志对于灾难时的数据恢复起着极其重要的作用,MySQL的主 从复制, 就是通过该binlog实现的。...二进制日志,MySQl8.0默认已经开启,低版本的MySQL的需 要通过配置文件开启,并配置MySQL日志的格式。
内置函数 概念 在开发称之为 ‘方法’ 将一组逻辑语句在方法体中 对外暴露的方法名 作用 1隐藏代码实现细节 2提高代码的重性 调用方法 select 函数名 ...
在MySQL中的事务(Transaction)是由存储引擎实现的,在MySQL中,只有InnoDB存储引擎才 支持事务。...事务操作 MySQL的事务操作主要有以下三种: 1、开启事务:Start Transaction 任何一条DML语句(insert、update、delete)执行,标志事务的开 启 命令:BEGIN...自动帮我们完成的,每执行一条SQL时MySQL就 帮我们自动提交事务,因此如果想要手动控制事务,则必须关闭MySQL的事务自动提交。...在 MySQL中直接用 SET 来改变 MySQL 的自动提交模式: set autocommit=0 禁止自动提交 set autocommit=1 开启自动提交 create database if...插入数据 insert into account values(1,'zhangsan',1000); insert into account values(2,'lisi',1000); -- 设置MySQL
相对其他数据库而言,MySQL的锁机制比较简单,其最显著的特点是不同的存储引擎支持不同的 锁机制。...下表中罗列出了各存储引擎对锁的支持情况: MySQL锁的特性可大致归纳如下 : 从上述特点可见,很难笼统地说哪种锁更好,只能就具体应用的特点来说哪种锁更合适!...MyISAM 存储引擎只支持表锁 表锁特点 -- MySQL的锁机制 drop database if exists mydb14_lock; create database mydb14_lock
MySQL的核心就是存储引擎。...分类 MyISAM:Mysql 5.5之前的默认数据库引擎,最为常用。...并且其内容会在MYSQL重新启动是会丢失。 Archive :非常适合存储大量的独立的,作为历史记录的数据。因为它们不经常被读取。...关闭mysql服务 2. 找到mysql安装目录下的my.ini文件: 3....启动mysql服务
MySQL支持一台主库同时向多台从库进行复制, 从库同时也可以作为其他从服务器的主库,实现链状复制。 3.2 复制原理 MySQL 的主从复制原理如下。...binlog-ignore-db=mysql #指定同步的数据库 #binlog-do-db=db01 2) 执行完毕之后,需要重启Mysql: service mysql restart; 3)...服务端ID,唯一 server-id=2 #指定binlog日志 log-bin=/var/lib/mysql/mysqlbin 2) 执行完毕之后,需要重启Mysql: service mysql...Mysql权限管理 4.1 MySQL 权限介绍 mysql中存在4个控制权限的表,分别为user表,db表,tables_priv表,columns_priv表,在MySQL8.0之后,还新增了role...用户 有两种方式创建MySQL授权用户 执行create user/grant命令(推荐方式) 通过insert语句直接操作MySQL系统权限表 # 这只是创建用户并没有权限 mysql>
2.3优化order by语句 2.4优化group by 2.5优化子查询 2.6优化limit查询 1.使用索引优化 索引是数据库优化最常用也是最重要的手段之一, 通过索引通常可以帮助用户解决大多数的MySQL...`createtime` datetime, primary key(`sellerid`) ); 索引是数据库优化最常用也是最重要的手段之一, 通过索引通常可以帮助用户解决大多数的MySQL...对于Filesort , MySQL 有两种排序算法: 1) 两次扫描算 法 :MySQL4.1 之前,使用该方式排序。...MySQL 通过比较系统变量 max_length_for_sort_data 的大小和Query语句取出的字段总大小, 来判定是否那种排序算法,如 果max_length_for_sort_data...一个常见又非常头疼的问题就是 limit 900000,10 ,此时需要MySQL排序前900010 记录,仅仅返回900000 - 900010 的记录,其他记录 丢弃,查询排序的代价非常大 。
MySQL中的游标 1.什么是游标 虽然我们也可以通过筛选条件 WHERE 和 HAVING,或者是限定返回记录的关键字 LIMIT 返回一条记录,但是,却无法在结果集中像指针一样,向前定位一条记录...MySQL中游标可以在存储过程和函数中使用。 2.使用游标的步骤 游标必须在声明处理程序之前被声明,并且变量和条件还必须在声明游标或处理程序之前被声明。...FETCH cur_score INTO stu_id, grade ; 注意:游标的查询结果集中的字段数,必须跟 INTO 后面的变量数一致,否则,在存储过程执行的时候,MySQL 会提示错误。...PROC_CURSOR # 调用存储过程 SET @s_count = 0; CALL PROC_CURSOR(400,@s_count) ; SELECT @s_count; 4.小结 游标是 MySQL
多字段排序 了解了MySQL的排序方式,优化目标就清晰了:尽量减少额外的排序,通过索引直接返回有序数据。...对于Filesort , MySQL 有两种排序算法: 1) 两次扫描算法 :MySQL4.1 之前,使用该方式排序。...创建索引 : create index idx_emp_age_salary on emp(age,salary); 5.5 优化嵌套查询 Mysql4.1版本之后,开始支持SQL的子查询。...一个常见又非常头疼的问题就是 limit 2000000,10 ,此时需要MySQL排序前2000010 记录,仅仅返回2000000 - 2000010 的记录,其他记录丢弃,查询排序的代价非常大 。...5.8.1 USE INDEX 在查询语句中表名的后面,添加 use index 来提供希望MySQL去参考的索引列表,就可以让MySQL不再考虑其他可用的索引。
Connections 试图连接 MySQL 服务器的次数。 Uptime 服务器工作时间。 Slow_queries 慢查询的次数。...如将主键置于where列表中,MySQL 就能将该查询转换为一个常亮。...using temporary 使用了临时表保存中间结果,MySQL在对查询结果排序时使用临时表。...由于在Sending data状态下,MySQL线程往往需要做大量的磁盘读取操作,所以经常是整各查询中耗时最长的状态。...在获取到最消耗时间的线程状态后,MySQL支持进一步选择all、cpu、block io 、context switch、page faults等明细类型类查看MySQL在使用什么资源上耗费了过高的时间
下面是一个合并表的例子: mysql> CREATE TABLE t1(a INT NOT NULL PRIMARY KEY)ENGINE=MyISAM; mysql> CREATE TABLE...t2(a INT NOT NULL PRIMARY KEY)ENGINE=MyISAM; mysql> INSERT INTO t1(a) VALUES(1),(2); mysql> INSERT...下面的INSERT语句对合并表和下属表都可见: mysql> INSERT INTO mrg(a) VALUES(3); mysql> SELECT a FROM t2; +---+...mysql> DROP TABLE t1, t2; mysql> SELECT a FROM mrg; +------+ | a | +------+...合并表对性能的影响 MySQL对合并表的实现对性能有一些重要的影响。和其他MySQL特性一样,它在某些条件下性能会更好。
领取专属 10元无门槛券
手把手带您无忧上云