zoukankan      html  css  js  c++  java
  • 高性能MySQL笔记

    锁粒度:表锁、行级锁
    表锁锁定整张表

    隔离级别:
    未提交读:事务中的修改,即使没有提交,对其他事务也是可见的。事务可以读取未提交的数据,也被称为脏读。实际应用中比较少用
    提交读:一个事务提交之前,所做的任何修改对其他事务都是不可见的。两次执行同样的查询,可能得到不同的结果。也叫不可重复读。
    可重复读:是MySQL默认的事务隔离级别,存在幻读问题。
    可串行化:事务串行执行,避免幻读问题

    死锁的解释:两个进程在同一个资源上相互占用,并请求锁定对方占用的资源。这个解释很简练。sql也存在死锁问题。
    InnoDB处理死锁的方式:将持有最少行级排它锁的事务进行回滚。

    MySQL提供两种事务型存储引擎:InnoDB、NDB Cluster
    MySQL默认采用自动提交模式。每个查询都被当做一个事务执行提交操作。也就是说我执行一条sql语句,update整张表所有记录中的某一个字段,执行到某一条记录时出错,将全部回滚。

    MyISAM是非事务型的表,没有COMMIT和ROLLBACK的概念。

    在文件系统中,MySQL将每个数据库保存未数据目录下的一个子目录。创建表时,就在子目录创建一个与表同名的.frm文件

    查看一张表的状态命令:

    show table status like 'user'
    

    MyISAM在对于只读数据或表比较小的操作,可以使用(但尽量默认使用InnoDB)

    修改表引擎命令

    alter table user engine = InnoDB;
    

    性能优化并不是降低CPU利用率,而是增加CPU利用率,即等量的任务下,降低CPU的使用率。

    尽量避免null,可以为null的列会使用更多的存储空间,当然将null的列改为not null带来的性能提升比较小,在设计的时候尽量设置为not null

    varchar(5)和varchar(200),最好的策略是只分配真正需要的空间

    MySQL提供两种相似的日期类型:Datetime和timestamp

    范式化和反范式化

  • 相关阅读:
    c语言输入一个字符串,统计其字母,数字和其他字符的个数,并以柱状图输出
    c语言中的#ifdef和#ifndef
    宏定义#define
    c语言中的register int
    android SDK 更新的几个网址
    android studio启动不进行fetching Android sdk compoment information
    android eclipse ADT 安装maven插件失败
    Jsp 的映射
    Jsp 九大隐式对象
    Jsp 乱码处理
  • 原文地址:https://www.cnblogs.com/fonxian/p/6045560.html
Copyright © 2011-2022 走看看