字符串类型

  在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. SendMessage()、WPARAM、LPARAM函数使用例子(转)

      http://chujiaba.blog.163.com/blog/static/18991813720106209350592/ 2010-07-20 21:35:00|  分类: C |  标 ...

  2. 【恒天云技术分享系列11】Sheepdog简介

    sheepdog是近几年开源社区新兴的分布式块存储文件系统,采用完全对称的结构,没有类似元数据服务的中心节点.这种架构带来了线性可扩展性,没有单点故障和容易管理的特性.对于磁盘和物理节点,SheepD ...

  3. UVALive 7281 Saint John Festival (凸包+O(logn)判断点在凸多边形内)

    Saint John Festival 题目链接: http://acm.hust.edu.cn/vjudge/contest/127406#problem/J Description Porto's ...

  4. [iOS基础控件 - 6.9.4] 抓取网页图片资源

    A.需求 1.利用浏览器取得网页的源码 2.解析源码,获取图片地址(这里使用了java的一个库来解析html) 3.获取资源,生成plist目录   B.实现步骤 1.打开一个网页,最好里面是包含了静 ...

  5. dns解析对SEO产生的影响

    DNS 是域名系统 (Domain Name System) 的缩写,它是由解析器和域名服务器组成的.域名服务器是指保存有该网络中所有主机的域名和对应的IP地址,并具有将域名转换为IP地址功能的服务器 ...

  6. C#中垃圾回收与内存管理机制

    今天抽空来讨论一下.Net的垃圾回收与内存管理机制,也算是完成上个<WCF分布式开发必备知识>系列后的一次休息吧.以前被别人面试的时候问过我GC工作原理的问题,我现在面试新人的时候偶尔也会 ...

  7. ASP.NET MVC- 数据验证机制

    ASP.NET MVC的数据验证机制,比起ASP.NET WEBFORM那种高效很多.下面记录以下两个示例,以便日后方便查阅. 方式一:在Controller里通过AddModelError方法返回错 ...

  8. Date String转换

    这种转换要用到java.text.SimpleDateFormat类 字符串转换成日期类型: 方法1: 也是最简单的方法 Date date=new Date("2008-04-14&quo ...

  9. 十,选择cfee编辑器并学会调试程序。以及结束语。

    为什么推荐用cfree呢?因为我认为这个编辑器界面友好,用起来方便. 你也许会问,调试程序是什么? 那么下面思考几个问题:对于前面讲的分支结构和循环结构有点不懂怎么办?如果写的程序语法没有错误但是运算 ...

  10. idea 搭建java项目

    IntelliJ IDEA 12.0搭建Maven Web SSH2架构项目示例         以IDEA为环境,搭建SSH架构示例程序,用Maven管理依赖.这篇文章是一个示例,你需要首先搭建好M ...