• 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)导入数据





  • 相关阅读:
    基础理论:多线程、多进程、并行、并发
    Node: 使用nvm切换node版本
    python: is 和 == 的区别
    React:TypeError: Cannot read properties of undefined (reading 'map')
    pycharm: 注释自动生成
    前端包管理工具概览
    UE4蓝图学习
    mysql kill process解决死锁
    【分享】VCK190 PCIe QDMA 通用数据传输参考设计
    对Linux kernel代码格式重排后编译失败
  • 原文地址:https://www.cnblogs.com/gavanwanggw/p/7399733.html
Copyright © 2020-2023  润新知