最全MySQL-操作数据库(存储引擎)_create database innodb(1),2024年最新面试建议

img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以戳这里获取


前言

数据库是指长期存储在计算机内、有组织的和可共享的数据集合。简而言之,数据库就是一个存储数据的地方。只是,其存储方式有特定的规律。这样可以方便处理数据。数据库的操作包括创建数据库和删除数据库。这些操作都是数据库管理的基础。

一、创建数据库

创建数据库是指在数据库系统中划分一块空间,用来存储相应的数据。这是进行表操作的基础,也是进行数据库管理的基础。

在MySQL中,创建数据库须通过SQL语句CREATE DATABASE实现的。其语法形式如下:

CREATE DATABASE 数据库名;

其中,“数据库名”参数表示所要创建的数据库的名称。在创建数据库之前,可以使用SHOW语句来显示现在已经存在的数据库。语法形式如下:

SHOW DATABASES;

二、删除数据库

删除数据库是指在数据库系统中删除已经存在的数据库。删除数据库之后,原来分配的空间将被收回。值得注意的是,删除数据库会删除该数据库中所有的数据。因此,应该特别小心。

MySQL中,删除数据库是通过SQL语句DROP DATABASE实现的。其语法形式如下:

DROP DATABASE 数据库名;

其中,“数据库名”参数表示所要删除的数据库的名称。

三、数据库存储引擎

MySQL中提到了存储引擎的概念。简而言之,存储引擎就是指表的类型。数据库的存储引擎决定了表在计算机中的存储方式。

1、MySQL存储引擎简介

存储引擎的概念是MySQL的特点,而且是一种插入式的存储引擎概念。这决定了MySQL数据库中的表可以用不同的方式存储。用户可以根据自己的不同要求,选择不同的存储方式、是否进行事务处理等。

下面使用SHOW ENGINES语句可以查看MySQL数据库支持的存储引擎类型。查询方法如下:

show engines;

在这里插入图片描述

查询结果中,Engine参数指存储引擎名称;Support参数说明了MySQL是否支持该类引擎,YES表示支持;Comment参数指对该引擎的评论;例如InnoDB的存储引擎的评论如下图
在这里插入图片描述

Transactions参数表示是否支持事务处理,YES表示支持,可以看到只有InnoDB支持事务处理。XA参数表示是否分布式交易处理的XA规范,YES表示支持;Savepoints参数表示是否支持保存点,以便事务回滚到保存点,YES表示支持。

从查询结果中可以看出,MySQL支持的存储引擎包括很多,其中InnoDB为默认存储引擎。

我们可以使用SHOW语句查询默认的存储引擎。如下

show variables like 'storage_engine';

在这里插入图片描述

结果显示,默认的存储引擎为InnoDB。如果我们想要修改默认的存储引擎,可以在my.ini中进行修改。将“default-storage-engine=INNODB”更改为“default-storage-engine=MyISAM”。然后重启服务,修改生效。

2、InnoDB存储引擎

InnoDB是MySQL数据库的一种存储引擎。InnoDB给MySQL的表提供了事务、回滚、崩溃修复能力和多版本并发控制的事务安全。

InnoDB是MySQL上第一个提供外键约束的表引擎。而且InnoDB对事务处理的能力,也是MySQL其他存储引擎所无法与之比拟的。

InnoDB存储引擎中支持自动增长列AUTO_INCREMENT。自动增长列的值不能为空,且值必须唯一。MySQL中规定自增列必须为主键。在插入值时,如果自动增长列不输入值,则插入的值为自动增长后的值;如果输入的值为0或空(NULL),则插入的值也为自动增长后的值;如果插入某个确定的值,且该值在前面没有出现过,则可以直接插入。

InnoDB存储引擎中支持外键(FOREIGN KEY)。外键所在的表为子表,外键所依赖的表为父表。父表中被子表外键关联的字段必须为主键。当删除、更新父表的某条信息时,子表也必须有相应的改变。

InnoDB存储引擎中,创建的表的表结构存储在.frm文件中。数据和索引存储在innodb_data_home_dir和innodb_data_file_path定义的表空间中。

img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以戳这里获取

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以戳这里获取

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值