MYSQL--存储引擎、数据类型、约束条件、
存储引擎:
不同的数据应该有不同的处理机制
mysql存储引擎
Innodb:默认的存储引擎 查询速度相比于myisam慢 但是更安全
myisam:mysql老版本用的存储引擎
memory:内存引擎(数据全部存在内存中)
blackhole:无论存什么都立刻消失(黑洞)
show engines;
数据类型:
创建表的完整语法:
create table 表名(
字段名1 类型[(宽度) 约束条件],
字段名2 类型[(宽度) 约束条件],
字段名3 类型[(宽度) 约束条件]
);
注意:
1、字段名和字段类型都是必须的 中括号内的参数都是可选的参数
2、同一张表中字段名不能重复
3、最后一个字段后面不能加括号
宽度:(使用数据库的准则:尽可能让它少干活)
对存储数据的限制
char(1) 只能存一个字符如果超过了mysql会自动帮你截取或者直接报错(mysql中的严格模式)
alter table tablename modify name char not null; not null(该字段不能为空)
类型和中括号内的约束:
类型约束的是数据的存储类型
而约束是基于类型之上的额外的限制
字段类型:
整形: SMALLINT TINYINT INT BIGINT
TINYINT:默认是带有符号的(-128,127),超出这个限制之后会存最大值或最小值
create table tablename(id TINYINT);
not null 不能为空
unsigned 无正负符号
zerofill 0填充多余的位数
char后面的数字是用来限制存储数据的长度的
特例:只有整型后面的数字不是用来限制存储数据的长度的 而是用来控制展示数据的位数的
int(8) 够/超8位有几位存几位,不够8位就用空格填充
强调:对于整型来说,数据类型后的宽度并不是存储限制,而是限时限制,所以在创建表的时候,如果字段采用的是int类型,完全可以不指定限时宽度,默认的限时宽度,足够显示完整当初存放的数据
模糊匹配:
like
%:匹配任意多个字符
_:匹配任意一个字符
set session 临时有效 只在你当前操作的窗口有效
set global全局有效 终生有效
设置完成之后,你需要重新退出再次登陆就OK了
浮点型
float(255,30) 总共255位 小数部分占30位
double(255,30) 总共255位 小数部分占30位
decimal(65,30) 总共65位 小数部分占30位
create table t12(id FLOAT(255,30));
create table t13(id DOUBLE(255,30));
create table t14(id DECIMAL(65,30));
精确度:float < double < decimal
字符类型
char(4):最大只能存4个字符超出就会直接报错 如果少了 会自动用空格填充
varchar(4):最大只能存4个字符 超出就会直接报错 如果少了 有几个就存几个
create table t15(name char(4));
create table t16(name varchar(4));
char_length():
msyq在存储char类型字段的时候 硬盘上确确实实存在的是固定长度的数据,但是在取出来的那一瞬间,mysql就会自动将填充的空格去除(可以通过严格模式,来修改该机制 让其不做自动去处处理)
char与varchar的区别:
char取的时候方便直接按固定的长度取就可以
varchar:取得时候比较繁琐,无法是知道数据到底有多长
char定长:
1、浪费空间
2、存取速度快
varchar变长:
1、节省空间
2、存取速度慢(相对于char比较慢)
存的时候 需要献给数据将一个记录长度的报头
取的时候 需要先读取报头才能读取真是数据
日期类型
date:年月日
datetime:年月日时分秒
year:年
time:时分秒
枚举和集合类型
枚举:enum限制某个字段能够存储的数据类型
集合:set限制某个字段能够存储的数据内容
约束条件:
not null:不能为空
unique:唯一
单列唯一:
限时某一个字段是唯一的
联合唯一:
在语句的最后用括号的形式,表示哪几个字段组合的结果是唯一的
default:给某个字段设置默认值(当用户写了就用写的,没有的话就用默认的)
create table t17(id int,name char(16) default 'william
primary key:主键
限制效果跟not null + unique 组合效果一致 非空且唯一
create table t18(id int primary key);
primary key也是innodb引擎查询必备的索引,索引可以当成书的目录
innodb引擎在创建表的时候 必须要有一个主键,当你没有指定主键的时候:
1、会将非空且唯一的字段自动升级为主键
2、当你的表中没有任何的约束条件的时候 innodb会采用自己的内部默认的一个主键字段,该主键字段你在查询的时候是无法使用的,查询数据的速度就会变得很慢,就好像是一页一页翻书
通常每张表都应该有一个id字段,并且应该将id设置为表的主键字段
联合主键:多个字段联合起来作为表的一个主键, 本质还是一个主键!!!
ps:innodb引擎中一张表有且只有一个主键
auto_increment:自动递增
delete from :仅仅是删除数据没 不会重置主键
truncate:初始化表 会重置主键
MYSQL--存储引擎、数据类型、约束条件、的更多相关文章
- MySQL存储引擎、基础数据类型、约束条件
MySQL存储引擎 存储引擎 # 存储引擎可以堪称是处理数据的不同方式 # 查看存储引擎的方式 show engines; # 需要掌握的四个存储引擎 MyISAM MySQL5.5之前的默认的存储引 ...
- MySQL存储引擎的实际应用以及对MySQL数据库中各主要存储引擎的独特特点的描述
MySQL存储引擎的实际应用以及对MySQL数据库中各主要存储引擎的独特特点的描述: 1.MySQL有多种存储引擎: MyISAM.InnoDB.MERGE.MEMORY(HEAP).BDB(Berk ...
- MySQL存储引擎总结
MySQL存储引擎总结 作者:果冻想 字体:[增加 减小] 类型:转载 这篇文章主要介绍了MySQL存储引擎总结,本文讲解了什么是存储引擎.MyISAM.InnoDB.MEMORY.MERGE等内 ...
- 数据库 --> MySQL存储引擎介绍
MySQL存储引擎介绍 MyISAM是MySQL的默认数据库引擎(5.5版之前),由早期的ISAM(Indexed Sequential Access Method:有索引的顺序访问方法)所改良.虽然 ...
- MySQL存储引擎对比
MySQL存储引擎对比 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.MySQL的存储引擎 大家应该知道MySQL的存储引擎应该是表级别的概念,因为我们无法再创建databas ...
- MySQl学习-——Mysql体系结构与Mysql存储引擎
Mysql体系结构与Mysql存储引擎 Mysql体系结构 mysql体系结构图:
- MYSQL存储引擎介绍--应用场景
MySQL存储引擎通常有哪3种?各自分别有什么特点?应用场景是哪些? MySQL5.5以后默认使用InnoDB存储引擎,其中InnoDB和BDB提供事务安全表,其它存储引擎都是非事务安全表.若要修改默 ...
- Mysql存储引擎的选择
Mysql存储引擎概述 mysql的存储引擎是插件式的,用户可以根据需求选择如何存储和索引数据是否使用事务等. Mysql支持多种存储引擎,用户可以选择不同的引擎来提高应用的效率,灵活的存储方案,存储 ...
- MYSQL初级学习笔记二:数据表相关操作及MySQL存储引擎!(视频序号:初级_5,7-22|6)
知识点三:数据表相关操作(5,7-22) --------------------------------整型--------------------------------- --测试整型 CREA ...
- mysql 存储引擎学习
现在我们常用的MySQL存储引擎主要是两种:InnoDB and MyISAM. 1.MyISAM 执行效率高 不支持事务 不支持外键 每个MyISAM在磁盘上存储成3个文件,其中文件名和表名都相同, ...
随机推荐
- printf打印参数的顺序问题
C语言的printf函数处理的参数顺序是从右向左的,例如如下程序: #include <stdio.h> int main() { int a = 1, b = 2, c ...
- 20141209-基本概念-BlogEngine.NET(1)-笔记
最近在读BlogEngine.NET3.1源代码,希望能坚持到底吧. 刚接触源代码,没有思路,于是读了14篇关于BlogEngine.Net1.4.5的系列博客,地址:http://www.cnblo ...
- KdTree && Octree 原理学习对比以及可视化分析--"索引树"
1. Kdtree 原理 k-d树(k-dimensional树的简称),是一种分割k维数据空间的数据结构.主要应用于多维空间关键数据的搜索(如:范围搜索和最近邻搜索): 索引结构中相似性查询有两种基 ...
- Loadrunner基本概念解析<一>
学习性能测试前需要掌握的基本概念,以下做一个记录,本文会持续更新,我期望的是,用通俗简洁的语言来进行更好的理解. [基本概念如下:] ---并发用户数: 1️⃣错误的理解: 使用系统的全部用户数 ...
- python函数知识四 迭代器、生成器
15.迭代器:工具 1.可迭代对象: 官方声明,只要具有__iter__方法的就是可迭代对象 list,dict,str,set,tuple -- 可迭代对象,使用灵活 #方法一: list.__ ...
- flash put_movie loadmovie 区别
put_Movie 应该是c++的函数用来往程序加载一个swf用的,as3里没有loadmovie是flash用的,用来加载另一个swf或jpeg文件 不过这个loadmovie这个函数是在as2中用 ...
- 记一次java.lang.NoClassDefFoundError异常
前阵子做了个评论过滤敏感词的功能,本地测试没有任何问题,然后就部署到线上服务器,通知相关人员线上测试.大约过了十来天,那货和我说接口出问题了,当时一脸懵逼,用了十来天突然出问题了???好吧,出问题了咱 ...
- [剑指offer] 54. 字符流中第一个不重复的字符
题目描述 请实现一个函数用来找出字符流中第一个只出现一次的字符.例如,当从字符流中只读出前两个字符"go"时,第一个只出现一次的字符是"g".当从该字符流中读出 ...
- sqlserver 2008 无法使用特殊主体‘sa’,错误15405
今天莫名其妙的遇到一个问题,还原了几个数据库到新的服务器上,突然发现sa用户对某几个数据库没有权限(用户映射): 我手工勾选相应数据库的db_owner权限之后,报错:无法使用特殊主体'sa',错误1 ...
- Linux卸载MySql——ubuntu版
卸载mysql 1)删除mysql的数据文件 sudo rm /var/lib/mysql/ -R 2)删除mqsql的配置文件 sudo rm /etc/mysql/ -R 3)自动卸载mysql的 ...