一、 数据库操作

1.1 创建数据库

  1. 创建数据库是指在数据库系统中划分一块空间,用来存储相应的数据,这是进行表操作的基础,也是数据库管理的基础
  2. 在MySQL中创建数据库之前,可以使用show语句来显示当前已经存在的数据库,具体SQL语句如下
    show databases
  3. 创建数据库的SQL语句如下,其中参数database_name代表所要创建的数据库的名称
    create database database_name;
  4. 创建数据库之前判断是否已存在,其中参数database_name代表所要创建的数据库的名称
    create database if not exists database_name
  5. 创建数据库并指定字符集,其中参数database_name代表所要创建的数据库的名称、UTF8代表字符集
    create database database_name character set utf8

1.2 选择数据库

  1. 在操作数据对象之前,首先需要确定是哪一个数据库,即在对数据库操作对象进行操作时,需要先选择一个数据库,语句如下
    use database_name
  2. 如果选择一个不存在的数据库,就会出现unkown database ‘database_name’错误

1.3 删除数据库

  1. 在删除数据库之前,首先需要确定所需要的数据库对象已经存在,在MySQL中删除数据库使用SQL语句 drop database来实现,语句如下
    drop database datavase_name;

二、 什么是存储引擎

  1. MySQL中提到了存储引擎的概念,简而言之,存储引擎就是指表的类型,在具体开发时,为了提高MySQL数据库管理系统的使用效率和灵活性,可以根据实际需要来选择存储引擎,存储引擎指定了表的类型,即如何存储和索引数据、是否支持事务等,同时存储引擎也决定了表在计算机中的存储方式
  2. 用户在选择存储引擎之前,首先需要确定数据库管理系统支持那些存储引擎,在MySQL数据库管理系统中,通过show engines来查看支持的存储引擎,语法如下
    show engines;

  • engines参数:表示存储引擎的名称
  • Support参数:表示MySQL数据库系统是否支持该存储引擎
  • default参数:系统默认支持的存储引擎
  • Comment参数:表示对存储引擎的评论
  • Transaction参数:表示存储引擎是否支持事务
  • XA参数:表示存储引擎所支持的分布式是否复合XA规范
  • Savepoints参数:表示存储引擎是否支持事务处理的保存点
  1. 还可以通过show variables来查看所支持的存储引擎,具体语句如下
    show variables like 'have%';
  2. 创建表时,若没有指定存储引擎,表的存储引擎将为默认存储引擎,查看默认存储引擎,语句如下
    show variables like 'default_storage_engine%'

  • variable_name参数:表示存储引擎的名字
  • value参数:表示MySQL数据库管理系统是否支持存储引擎

2.1 InnoDB存储引擎

  1. InnoDB是MySQL数据库的一中存储引擎, InnoDB给MySQL的表提供了事务、回滚、崩溃修复能力和多版本并发控制的事务安全,MySQL从3.23.34a开始就包含InnoDB存储引擎,InnoDB是MySQL第一个提供外键约束的表引擎,而且InnoDB对事务处理的能力是MySQL的其它存储引擎所无法比拟的。
  2. InnDB存储引擎支持自动增长列auto_increment。自动增长列的值不能为空吗,且值必须唯一,MySQL中规定自动增长列必须为主键,在插入值时,如果自动增长列不输入值,插入的值就为自动增长后的值,如果输入的值为0或空,插入的值也为自动增长后的值,如果插入某个确定的值,且该值在前面没有出现过,就可以直接插入
  3. InnoDB存储引擎支持外键(foreign key,外键所在的表为子表,外键所依赖的表为父表,父表中被子表外键关联的字段必须为主键,当删除、更新父表某条信息时,子表必须有相应的变化
  4. InnoDB存储引擎的优势在于提供了良好的事务管理、崩溃修复能力和并发控制,缺点是读写效率差,占用数据空间相对比较大

2.2 MyISAM

  1. MyISAM存储引擎的表存储成三个文件,文件的名字和表名相同,扩展名包括frm、MYD和MYI,其中,frm为扩展名的文件存储表的结构;MYD为扩展名的文件存储数据,其是MYData的缩写;MYI为扩展名的文件存储的索引,其是MYIndex的缩写
  2. 基于MyISAM存储引擎的表支持三种存储格式,包括静态型、动态型和压缩型。其中,静态型为MyISAM存储引擎的默认存储格式,其字段是固定长度的,动态性包括变长字段,记录的长度是不固定的,压缩型需要使用myisampack工具创建,占用的磁盘空间较小
  3. MyISAM存储引擎的优点在于占用空间小,处理数据块,缺点是不支持事务的完整性和并发性

2.3 MEMORY存储引擎

  1. MEMORY存储引擎是MySQL中的一类特殊的存储引擎,其使用存储在内存中的内容来创建表,而且所有数据都放在内存中, 这些特性都与InnDB存储引擎、MyISAM存储引擎不同
  2. 每个基于MEMORY存储引擎的表实际对应一个磁盘空间,该文件的文件名与表名相同,类型为frm,该文件中只存储表的结构,而其数据文件都存储在内存中,这样有利于对数据的快速处理,提高整个表的处理效率,值得注意的是,服务器需要足够的内存来维持MEMORY存储引擎的表的使用,如果不需要使用就可以释放这些内存,甚至可以删除不需要的表
  3. MEMORY存储引擎默认使用哈希索引,其数据要比使用B型树索引快,如果需要使用B型树索引,就可以在创建索引时选择使用
  4. MEMORY表的大小是受到限制的,表的大小主要取决于两个参数,分别是max_rows和max_heap_table_size。其中max_rows可以在创建表时指定;max_heap_table_size的大小默认为16MB,可以按需要扩大,因此其存在内存中的特性,这类表的处理数据非常快,但是,其数据容易丢失,生命周期短,基于这个缺陷,选择MEMORY存储引擎时需要特别小心

2.4 选择存储引擎

  1. 在具体使用MySQL数据库管理系统时,选择一个合适的存储引擎是一个非常复杂的问题,因为每种存储引擎都有自己的特性,优势和应用场合,所以不能随便选择存储引擎,为了正确的选择存储引擎必须掌握各种存储引擎的特性
  2. 下面从存储引擎的事务安全、存储限制、空间使用、内存使用、插入数据的数据和对外键支持等角度来比较InnDB、MyISAM和MEMORY。
特性InnoDBMyISAMMEMORY
事务安全支持
存储显示64TB
空间使用
内存使用
插入数据的速度
锁机制行锁表锁表锁
对外键的支持支持
数据可压缩支持
批量插入速度
  • INNoDB存储引擎支持事务处理,支持外键,同时支持崩溃修复能力和并发控制,如果对事务的完整性要求比较高,要求实现并发控制,那么选择INNoDB存储引擎有很大的优势,**需要频繁的更新、删除操作的数据库,**也可以选择INNoDB存储引擎,因为这类存储引擎可以实现事务的提交和回滚
  • MyISAM存储引擎出入数据块,空间和内存使用比较低,如果表主要用于插入新记录和读出记录,那么选择MyISAM存储引擎能实现处理的高效率,如果应用的完整性、并发性要求很低,也可以选择MyISAM 存储引擎
  • MEMORY存储引擎的所有数据都在内存中,数据的处理速度快,但安全性不高,如果要很快的读写速度,对数据的安全性要求比较低,就可以选择MEMORY存储引擎,MEMORY存储引擎对表的大小有要求,不能建立太大的表,所有这类数据库使用相对较小的数据库表,
  • 这些选择存储引擎的建议是根据各个存储引擎的不同的特点提出的,并不是绝对的,实际应用中还需要根据实际情况进行分析
  • 在同一个数据库中,不同的表可以使用不同的存储引擎,如果一个表要求较高的事务处理,就可以使用InnoDB存储引擎,如果一个表会被频繁查询,就可以选择MyISAM存储引擎,如果一个用于查询的临时表,就可以选择MEMORY存储引擎

面试题

  1. 如何查看默认存储引擎
  2. 如何选择存储引擎