电商秒杀系统-数据库表设计
来源:互联网 发布:跑步路线规划软件 编辑:程序博客网 时间:2024/06/04 18:11
动态MyISAM:如果数据表中出现varchar、xxxtext或xxxBLOB字段时,服务器将自动选择这种表类型。相对于静态MyISAM,这种表存储空间比较小,但由于每条记录的长度不一,所以多次修改数据后,数据表中的数据就可能离散的存储在内存中,进而导致执行效率下降。同时,内存中也可能会出现很多碎片。因此,这种类型的表要经常用optimize table 命令或优化工具来进行碎片整理。
压缩MyISAM:以上说到的两种类型的表都可以用myisamchk工具压缩。这种类型的表进一步减小了占用的存储,但是这种表压缩之后不能再被修改。另外,因为是压缩数据,所以这种表在读取的时候要先时行解压缩。
但是,不管是何种MyISAM表,目前它都不支持事务,行级锁和外键约束的功能。
2 MyISAM Merge引擎:这种类型是MyISAM类型的一种变种。合并表是将几个相同的MyISAM表合并为一个虚表。常应用于日志和数据仓库。
3 InnoDB:InnoDB表类型可以看作是对MyISAM的进一步更新产品,它提供了事务、行级锁机制和外键约束的功能。
4 memory(heap):这种类型的数据表只存在于内存中。它使用散列索引,所以数据的存取速度非常快。因为是存在于内存中,所以这种类型常应用于临时表中。
5 archive:这种类型只支持select 和 insert语句,而且不支持索引。常应用于日志记录和聚合分析方面。
当然MySql支持的表类型不止上面几种。
MySql中关于存储引擎的操作
1 查看数据库可以支持的存储引擎
用show engines; 命令可以显示当前数据库支持的存储引擎情况,如图1所示:
图1 数据库的存储引擎
由上图可见当前系统的默认数据表类型是MyISAM。当然,我们可以通过修改数据库配置文件中的选项,设定默认表类型。
2 查看表的结构等信息的若干命令
要查看表的定义结构等信息可以使用以下几种命令:
2.1Desc[ribe] tablename; //查看数据表的结构
例如,查看表t1的结构,可得下图。
图2:查看表t1的结构
2.2 Show create table tablename; //显示表的创建语句
同上查询表t1,得下图:
图3 显示创建表t1的语句
2.3 show table status like ‘tablename’\G显示表的当前状态值
同上查询表t1,得下图:
图4 显示表t1 的当前状态值
综上可见,后两种方式都可以帮助我们查看某一表的存储引擎类型(图中已用红色方框标出)。
3 设置或修改表的存储引擎
3.1创建数据库表时设置存储存储引擎的基本语法是:
Create table tableName(
columnName(列名1) type(数据类型) attri(属性设置),
columnName(列名2) type(数据类型) attri(属性设置),
……..) engine = engineName
例如,假设要创建一个名为user的表,此表包括id,用户名username和性别sex三个字段,并且要设置表类型为merge。则可用如下的方式创建此数据表,
create table user(
id int not null auto_increment,
username char(20) not null,
sex char(2),
primary key(id)
) engine=merge
具体执行结果见下图:
图5 创建表user
查看创建后表user的信息,可见表的当前存储引擎是merge,如图所示:
图6 显示表t1 的当前状态值
3.2修改存储引擎,可以用命令Alter table tableName engine =engineName
假如,若需要将表user的存储引擎修改为archive类型,则可使用命令alter table user engine=archive。如下图所示:
图7 修改表user的存储引擎
查看修改后的表类型,可见表类型已经变为archive类型。
图8 显示表user修改后的状态值
- 电商秒杀系统-数据库表设计
- 设计数据库系统设计
- 投票管理系统的数据库表设计
- 教学管理系统-数据库设计
- 考试系统数据库设计
- 数据库系统设计初步
- 进销存系统数据库设计
- 教务系统--数据库设计
- 进销存系统数据库设计
- 权限系统数据库设计
- 抽奖系统数据库设计
- 投票系统数据库设计
- 博客系统数据库设计
- 数据库系统设计
- 【数据库系统概论】-数据库设计
- 权限系统--系统数据库设计
- 系统设计——关于数据库表设计的感悟
- 进销存系统数据库设计报告
- C++获取一个文件夹下的所有文件名
- NYOJ-28 大数阶乘
- re模块--正则
- 完成端口模型
- XZ_iOS之使用webView加载后台返回的一串html代码,HTML中的图片不显示
- 电商秒杀系统-数据库表设计
- Atom Editor for Windows 插件安装方法
- kail install chinese
- CodeForces 688AOpponents
- C# winForm启动最小化到任务栏右侧通知栏并交互操作
- For the payment term field in the order
- iOS开源加密相册Agony的实现(三)
- 使用fastjson和xUtils框架来获取聚合笑话数据
- jQuery Mobile 笔记三