字符串类型

  在SQL中,讲字符串类型分成了六类:char,varchar,text,blob,enum,set

  char,定长字符串

  磁盘(二维表)在定义结构的时候,就已经确定了最终数据的存储长度。

  char(L):L代表length,可以存储长度,单位为字符。最大长度值为255.

  varchar变长字符串

  在分配空间的时候,按照最大的空间分配,但是实际上最终用了多少空间,是根据具体的数据来确定的。

  varchar(L):L表示字符长度,理论长度是65536个字符,但是会多出1到2个字节来确定存储的实际长度。

  例如,varchar(10):存了10个汉字,utf8环境下,10*3+1=31个字节。

            存储3个汉字,3*3+1 = 10(bytes)

  如何选择定长或则是变长字符串呢?

  第一,定长的磁盘空间比较浪费,但是效率高。如果数据基本上确定长度都一样,就是用定长。

  第二,变长比较节约磁盘空间,但是效率低。如果数据不能确定长度,可以采用。

  text,文本字符串

  如果数据量非常大,通常说超过255个字符,就使用文本字符串。

  文本字符串根据存储的数据的格式进行分类:text OR blob.

  Text:存储文字(二进制数据根据实际都是存储路径)

  Blob:存储二进制数据(通常不用)。

  enum,枚举字符串

  事先将所有可能出现的结果都设计好,实际上存储的数据必须是规定好的数据中的一个。

  枚举的使用方式:

  定义:enum(可能出现的元素列表);  -- 如 enum('男','女','妖','保密');

  使用:存储数据,只能存储上面定义好的数据。

  作用:1、规范数据格式,数据只能是规定的数据中的其中一个。枚举实际存储的是数值二不是字符串本身。

     2、节省存储空间(枚举通常有一个别名:单选框)

  在MYSQL中,系统是自动转换数据格式的,而且基本与PHP一样。

  枚举的原理:枚举在进行数据规范的时候(定义数据的时候),系统会自动建立一个数据与枚举元素的对应关系(关系放到日志中),然后在进行数据插入的时候,系统自动将字符转换成对应的数字存储,分然后进行数据提取的时候,系统自动将数值转换成对应的字符串显示。

  集合字符串

  集合和枚举类似:实际存储的是数值,而不是字符串(集合是多选)。

  定义:Set (元素列表)

  使用:可以使用元素列表中的元素(多个),使用逗号分隔。

  集合中没有一个元素。

  集合的强大在于能够规划数据和节省空间,php也可以规范数据,但对于PHP来说效率优先,而且数据的维护可以通过数字进行。PHP没有办法判断数据的在数据库的形式,集合增加PHP的维护成。

  

  MYSQL记录长度

  MYSQL中规定,任何一条记录最长不能超过65535个字节。

  MYSQL记录中:如果有任何一个字段允许为空,那么系统会自动从整个记录中保留一个字节来存储NULL。

  列属性 

  列属性: 真正约束字段的是数据类型,但是数据类型的约束很单一,需要有一些额外的约束,来保证数据的合法性。

  列属性有很多: NULL/NOT NULL , DEFAULT,PRIMARY KEY,UNIQUE KEY,AUTO_INCREMENT,COMMENT.

  空属性:两个值,NULL(空,默认值)和NOT NULL(不为空)

  列描述: comment,描述,没有实际含义,是专门用来描述字段。

  DEFAULT:默认值关键词。

MYSQL基础笔记(七)- 数据类型二的更多相关文章

  1. MYSQL基础笔记(六)- 数据类型一

    数据类型(列类型) 所谓数据烈性,就是对数据进行统一的分类.从系统角度出发时为了能够使用统一的方式进行管理,更好的利用有限的空间. SQL中讲数据类型分成三大类:1.数值类型,2.字符串类型和时间日期 ...

  2. MYSQL基础笔记(二)-SQL基本操作

    SQL基本操作 基本操作:CRUD,增删改查 将SQL的基本操作根据操作对象进行分类: 1.库操作 2.表操作 3.数据操作 库操作: 对数据库的增删改查 新增数据库: 基本语法: Create da ...

  3. MYSQL基础笔记(三)-表操作基础

    数据表的操作 表与字段是密不可分的. 新增数据表 Create table [if not exists] 表名( 字段名 数据类型, 字段名 数据类型, 字段n 数据类型 --最后一行不需要加逗号 ...

  4. MYSQL基础笔记(五)- 练习作业:站点统计练习

    作业:站点统计 1.将用户的访问信息记录到文件中,独占一行,记录IP地址 <?php //站点统计 header('Content-type:text/html;charset=utf-8'); ...

  5. MYSQL基础笔记(四)-数据基本操作

    数据操作 新增数据:两种方案. 1.方案一,给全表字段插入数据,不需要指定字段列表,要求数据的值出现的顺序必须与表中设计的字段出现的顺序一致.凡是非数值数据,到需要使用引号(建议使用单引号)包裹. i ...

  6. MYSQL基础笔记(一)

    关系型数据库概念: 1.什么是关系型数据库? 关系型数据库:是一种建立在关系模型(数学模型)上的数据库 关系模型:一种所谓建立在关系上的模型. 关系模型包含三个方面: 1.数据结构:数据存储的问题,二 ...

  7. mysql基础之基本数据类型

    原文:mysql基础之基本数据类型 列类型学习 mysql三大列类型 整型 Tinyint/ smallint/ mediumint/int/ bigint(M) unsigned zerofill ...

  8. MySql基础笔记(一)Mysql快速入门

    Mysql快速入门 一)基本概念 1)表 行被称为记录,是组织数据的单位.列被称为字段,每一列表示记录的一个属性. 2)主键 主键用于唯一的标识表中的每一条记录.可以定义表中的一列或者多列为主键, 但 ...

  9. MySQL基础笔记(二) 完整性约束

    我们知道,一种数据模型必须包含三个基本的部分: 构造机制(数据结构):主要描述数据的类型.内容.性质以及数据间的联系等. 运算机制(数据操作):主要描述在相应的数据结构上的操作类型和操作方式. 约束机 ...

随机推荐

  1. 基于easyui的验证扩展

    基于easyui的验证扩展 ##前言 自己做项目也有好几年的时间了,一直没有时间整理自己的代码,趁春节比较闲,把自己以前的代码整理了一篇.这是基于easyui1.2.6的一些验证扩展,2012年就开始 ...

  2. Hbase 基本命令

    启动Hbase:./start-hbase.sh 进入Hbase shell控制台:./hbase shell   查看所有表 list   查看数据库状态:status   查看数据库版本:vers ...

  3. JAVA——利用wait和notify实现生产者和消费者

    经典的消费者和生产者的的实现: 注意事项: 1:在循环里面用wait(),因为当线程获得了锁,但是有可能还没有满足其他条件: 2:公用的缓冲池要用锁机制: package demo; import j ...

  4. 【bz2594】水管局长数据加强版

    题意: 给出一张n节点.m条代权无向边的无向联通图 和q个任务 1:询问一条x到y的路径 并使路径上最大权值最小 要求输出路径上最大权值 2:宣布x到y的路径报废题目保证该图永远联通 题解: 这是道凶 ...

  5. java.net.BindException: Address already in use: bind

    环境:jxse-2.7, netty-3.6.6.Final 现象:每次执行都抛出以下异常 八月 08, 2013 8:45:19 下午 net.jxta.logging.Logging logChe ...

  6. HDU 5680 zxa and set (数学 推导结论)

    zxa and set 题目链接: http://acm.hust.edu.cn/vjudge/contest/121332#problem/G Description zxa has a set , ...

  7. codeforces 630B Moore's Law

    B. Moore's Law time limit per test 0.5 seconds memory limit per test 64 megabytes input standard inp ...

  8. Windows Server 2003 R2 64位简体中文版下载

    32位版 CD1: SHA1值:d0dd2782e9387328ebfa45d8804b6850acabf520 ed2k://|file|cn_win_srv_2003_r2_enterprise_ ...

  9. iOS开发代码规范

    1.关于命名 1.1统一要求 含义清楚, 尽量做到不需要注释也能了解其作用,若做不到,就加注释 使用全称不使用缩写 1.2类的命名 大驼峰式命名:每一个单词的首字母都采用大写字母例子: MFHomeP ...

  10. 转:使用memc-nginx和srcache-nginx模块构建高效透明的缓存机制

    原文地址:http://blog.codinglabs.org/articles/nginx-memc-and-srcache.html 为了提高性能,几乎所有互联网应用都有缓存机制,其中Memcac ...