zoukankan      html  css  js  c++  java
  • mysql存储引擎的一点学习心得总结

    首先我们应该了解mysql中的一个重要特性——插件式存储引擎,从名字就能够看出在mysql中,用户能够依据自己的需求随意的选择存储引擎。实际上也是这样。即使在同一个数据库中。不同的表也能够使用不同的存储引擎。Mysql中支持的存储引擎有非常多种,这个能够去baidu或者google,本文主要说两种比較经常使用的存储引擎。myisam和innodb。

    myisam的特点是
    1)索引和数据分开存储,myisam有三个文件(.frm文件,存储表定义;.MYI存储索引 my index。  MYD存储数据 my data)
    2)不支持事务以及外键
    3)支持全文索引
    4)支持数据压缩(myisam支持3种不同存储格式。静态表,动态表,压缩表)
    5)Select和Insert效率较高。所以一般以Select和insert为主的应用使用myisam存储引擎。
    6)表锁

    innodb的特点
    1)支持外键和事务
    2)假设非常多是update和delete操作,那么选择innodb是合适的。
    3)数据和索引存储在一起。
    4)innodb不支持全文索引
    5)InnoDB 中不保存表的详细行数。也就是说,运行select count(*) from table时。InnoDB要扫描一遍整个表来计算有多少行,可是MyISAM仅仅要简单的读出保存好的行数就可以。注意的是。当count(*)语句包括 where条件时。两种表的操作是一样的。
    6)行级锁

    在对于字符串存储的时候,假设是myisam建议使用固定长度数据列
    假设使用innodb,建议使用varchar数据类型

    ================================华丽切割线===================================================

    以下简单提一下mysql中字符集的选择

    通常是这种。假设数据库仅仅是须要支持一般中文,那么使用gbk就够了。不须要使用uft8。原因是gbk一个汉字2个字节,utf8中一个汉字3个字节。

    mysql的字符集有两个概念,一个是字符集,一个是校对规则
    字符集用来定义存储字符串的方式
    校对规则用来定义字符串的比較方式
    假设校对规则是ci(比較时,大写和小写不敏感) cs(比較时大写和小写敏感)。bin(二元,和字符编码有关)

    怎样改动一个数据库中的字符集呢?
    假设没有数据,直接改动就是,可是假设数据库中已经存在数据,那么怎样改动字符集呢?
    1)导出表结构
    2)手动改动导出的表结构(一个sql文件A.sql)
    3)导出全部记录(B.sql)
    4)改动B.sql中的set names utf8
    5)使用新的字符集创建数据库
    6)创建表
    7)导入数据





  • 相关阅读:
    web 后台返回json格式数据的方式(status 406)
    消息队列比较
    CAP
    Redis分布式锁的正确实现方式
    idea 快捷键
    给web请求加遮罩动画
    java动态代理实现与原理详细分析(代码层面解释了AOP的实现)
    Spring框架IOC和AOP的实现原理(概念)
    springboot后台控制重定向
    消息队列如何保证幂等性?
  • 原文地址:https://www.cnblogs.com/gavanwanggw/p/7399733.html
Copyright © 2011-2022 走看看