1.存储引擎查看:命令SHOW ENGINES
2.support字段说明:
default的为默认的引擎
为YES表示可以使用
为NO表示不能使用
1.使用场景:一般事务性,均使用该引擎,用途最广,如果把握不准使用何种引擎,就使用该引擎
2.特点:
修改快,支持事务
存储限制:64TG
事务支持:支持事务
1.使用场景:由于易失性,可以用于存储在分析中产生的中间表
2.特点:
所有的数据都保存在内存中,一旦服务器重启,所有memory存储引擎的表数据会消失但是表结构会保存下来
存储限制:取决于RAM (随机存储器)
事务支持:不支持事务
1.使用场景:在日志和数据采集的时候可以使用
2.特点:
只允许插入和查询,不允许修改和删除,压缩存储,节约空间,可以实现高并发的插入,支持在自增ID上建立索引
rarchive表比MylSAM表要小大约75%,比支持事务处理的InnoDB表小大约83%
不支持索引 (自增ID列除外)
1.元数据库简介:记录MySQL自身数据的数据库
2.元数据库分类:
information_schema:信息数据库,保存mysql所维护的其他数据库信息例如:数据库名,数据库的表,表栏的数据类型与访问权限等
mysql:核心数据库,主要负责存储数据库的用户、权限设置、关键字等mysql自己需要使用的控制和管理信息。
perfohance_schema:用于mysql的监控数据的存放
3.相关操作:数据库的增删改查及使用
use 数据库名
create database if not exists 数据库名 default charset utf8 collate utf8 general ci:(设置了字符集编码以及不区分大小写)
show databases.
drop database 数据库名
4.MySQL库:权限相关
1、user表(用户层权限)
2、db表(数据库层权限)
3、tables_priv表(表层权限)
4、columns_priv表(字段层权限)
第一范式:列不可再分(原子性):例如:湖南省长沙市岳麓区xxxxx
第二范式:主键约束:例如:订单项表设计: id、单价 数量、小计
第三范式:外键约束:例如:患者id、患者姓名同时存在于一张关联表中
1.优化原则
更小通常更好:
更小通常更快更小通常更快
更少的CPU周期
2.简单原则
整型比字符串操作代价更小
用时间类型表示日期 (date、datetime等)而不用字符串
3.尽量避免NULL
NULL为列的默认值,但除非确实需要,应尽量避免使用NULL
尽量指定列为NOT NULL,特别是需要建索引的列
查询中包括有NULL的类,MySQL更难优化:
1.不利于使用索引
2.索引统计更复杂
3.值比较更复杂
用整型值而不是字符串表示IP地址:
1.INET_ATON()
2.INET_NTOA()
1.整数
tinyint 8位(-128 ~127)
smallint 16位(-32768-32767)
mediumint24位(-8388608-8388607)
int32位大约正负21亿
bigint64位
2.实数(带有小数点)
float 4个字节
double 8个字节
decimal 最多允许65个数字
3.字符串
char:
定长,啊ySQL根据定义字符串的长度一次分配足够的空间
适用场景:较短的字符串,且所有值接近同一长度
varchar:
比定长类型节约空间
适用场景:字符串的最长长度比评估长度大很多,列的更新转
缺点:频繁修改,且字符串的长度变化大时,可能出现页分裂
4.text&blob
1.text存储字符数据:
tinytext
smalltext
mediumtext
text
lopgtext
2.blob存储二进制数据
tinyblob
smallblob
mediumblob
blob
ongblob
5.日期时间
1.datetime
精度:秒
与时区无关,8个字节存储空间
范围:1001至9999年
2.timestamp
保存1970年1月1日午夜以来的秒数
占用4个字节存储空间
范围:1970年至2038年
与时区有关
默认为NOTNULL
通常尽量使用timestamp
精度:秒
3.data
yyyy-MM-dd
4.time
HH:mm:ss
1.用来进行关联操作
2.在其他表中作为外键
3.整型通常是标识列的最好选择
4.相关的表中使用相同的数据类型
5.尽量避免字符串作为标识列,尤其是随机生成的字符串,(如: UUID) 导致insert与select都很慢
插入值被随机写到索引的不同位置,insert慢,容易导致页分裂,磁盘随机读取逻辑上相邻的行被分布在磁盘和内存的不同地方,select 慢
是MySQL查询缓存失效
如果需要存储UUID,则应将”去除
查询用户:SELECT * from user;
查看用户常用信息:select host,user from user.
删除用户(慎用):命令: drop user 用户名#drop user ls;
2.权限操作
设置权限(Grant):
#语法: grant privileges on databasename.tablename to username@host#给 Zs用户赋予数据库db xiaoli中的表t p1user 查询权限grant SELECT on dbxiaoli.t_p1 user to zs@%#给 Zs用户赋予数据库db_xiaoli中的表t_p1_user 修改权限grant UPDATE on db_xiagi.t_p1_user to zs@%#给zs用户赋子数据库db xiaoli中所有表查询权限grant SELECT on db xiaoli.* to zs@%':#给 Zs用户赋子数据库db xiaoli中所有表 所有权限grant ALL on db xiaoli.* to zs@%
撤销权限(Revoke):#语法: revoke privileges on databasename.tablename from username@'host;#啥也不能回收不会对GRANTALLPRIVILEGES ONdb xiaoli.TOzs@%有任revoke DELETE on db xiaoli.t p1 user from zs@%#可以回收GRANTSELECT,UPDATEONdb xiaolit p1 user TOzs @%这条revoke all on db xiaoli.t p1 user from zs@%:#可以回收GRANTALLPRIVILEGESONdb xiaoliTOzs @%这条赋权语句带revoke all on db xiaoli. from zs@%'02:11#注: revoke只能回收grants列表中更小的
查看用户权限:命令: show grants for 用户名show grants for ‘zs’@%
5.7版本
1.创建用户并设置登录密码:命令: create user 用户名 identified by密码#注: identified by会将纯文本密码加密作为散列值存储create user ls identified by "123456
2.修改用户密码:命令: set password for 用户名=password( 新密码);set password for zs=password(123456);flush privileges;
8.0版本
1.创建用户并设置登录密码:用户名密码创建需要分开命令: create user 用户名create user ls.
2.修改用户密码:ALTER USER ‘root’@‘localhost’ IDENTIFIED WITH mysql_native_password BY ‘123456’;