1. Join关键字,就是把多个表连接起来 而on和where都是条件,但是针对的对象不一样 1.1. 关键字 On是指怎样把两个表连接起来,如: on a.name = b.name 是一行一行的比较,然后联合起来,此时并没有判断where子句的内容 1.2. 关键字 Where 是针对所有表联合起来的 最终的数据,所以说它们的作用是不一样的 2. 适当的优化 关键字 Where 是遍历最终联合的数据,逐条遍历与条件匹配,所以最终数据的数据行数越少,效率越高(题外,where条件字段的顺序对效…
    sql优化核心 是数据库中 解析器+优化器的工作,我觉得主要有以下几个大方面:1>扫表的方法(索引非索引.主键非主键.书签查.索引下推)2>关联表的方法(三种),关键是内存如何利用3>处理排序聚合的方法,如何利用内存 即 少扫磁盘多用内存 --=====2 表关联方式-----0 概述类别 Nested Loop Hash Join Merge Join使用条件 任何条件 等值连接(=) 等值或非等值连接(>,<,=,>=,<=),‘<>’除外…
创建db5数据库 create database db5 charset=utf8; use db5; 例一:一个用户只有一个博客 用户表: id name 1 mike 2 alex 3 jack mysql) not null); Query OK, rows affected (0.07 sec) 插入用户记录 mysql> insert into user(name) values('mike'),('alex'),('jack'); Query OK, rows affected (0…
创建db5数据库 create database db5 charset=utf8; use db5; 例二:一个管理员唯一对应一个用户 用户表: id user password 1 egon xxxx 2 alex yyyy 创建用户表 mysql> create table user( id int primary key auto_increment, ) not null, password ) not null); Query OK, rows affected (0.12 sec)…
练习:账号信息表,用户组,主机表,主机组 #用户表 mysql> create table user( id int not null unique auto_increment, username ) not null, password ) not null, primary key(username,password)); Query OK, rows affected (0.12 sec) 插入用户信息 mysql'); Query OK, rows affected (0.01 sec…
创建数据库db6 create database db6 charset=utf8; user db6; # 创建班级表 mysql) not null unique); Query OK, rows affected (0.15 sec) mysql> select * from class; Empty set (0.00 sec) mysql> insert into class(caption) values('三年二班'),('一年三班'),('三年一班'); Query OK, r…
1,表的水平划分 如果一个表的记录数太多,比如成千上万条,而且需要经常检索,那么我们有必要化整为零.如果我拆成100个表,那么每个表只有10万条记录.当然需要数据在逻辑上可以划分.一个好的划分依据,有利于程序的简单实现,也可以充分利用水平分表的优势.比如系统界面上只提供按月查询的功能,那么把表按月拆分成12个,每个查询只查询一个表就够了.如果非要按照地域来分,即时把表拆的再小,查询还是要联合所有表来查,还不如不拆了.所以一个好的拆分依据是最重要的. 比如qq用户信息,单个user数据表存储太卡,…
新功能写好之后,需要把以前表数据更新一下,字段数据从以前的表中获取,只更新两个字段 UPDATE TABLE1,TABLE2 SET TABLE1.COLUMN1 = TABLE2.COLUMN1 , TABLE1.COLUMN2 = TABLE2.COLUMN2 WHERE TABLE1.RID = TABLE2.RID…
可以从这些方面进行优化: 数据库(表)设计合理 SQL语句优化 数据库配置优化 系统层.硬件层优化 数据库设计 关系数据库三范式 1NF:字段不可分; 2NF:有主键,非主键字段依赖主键; 3NF:非主键字段不能相互依赖; 解释: 1NF:原子性 字段不可再分,否则就不是关系数据库; 2NF:唯一性 一个表只说明一个事物; 3NF:每列都与主键有直接关系,不存在传递依赖; - 不符合第一范式的例子(关系数据库中create不出这样的表): [表]字段1, 字段2(字段2.1, 字段2.2), 字…
MySQL性能优化---EXPLAIN 参见:https://blog.csdn.net/jiadajing267/article/details/81269067 参见:https://www.cnblogs.com/clphp/p/5403215.html explain关键字用于分析sql语句的执行情况,可以通过他进行sql语句的性能分析. 对explain查询出来的结果含义进行分析: id值的含义: ​ id为语句的查询序号,也就是查询的执行顺序,如果id值相同表示语句是自上而下的执行的…