mysql数据类型.docx

上传人:李司机 文档编号:4960561 上传时间:2023-05-26 格式:DOCX 页数:7 大小:31.79KB
返回 下载 相关 举报
mysql数据类型.docx_第1页
第1页 / 共7页
mysql数据类型.docx_第2页
第2页 / 共7页
mysql数据类型.docx_第3页
第3页 / 共7页
mysql数据类型.docx_第4页
第4页 / 共7页
mysql数据类型.docx_第5页
第5页 / 共7页
点击查看更多>>
资源描述

《mysql数据类型.docx》由会员分享,可在线阅读,更多相关《mysql数据类型.docx(7页珍藏版)》请在三一办公上搜索。

1、查看文章mysql数据类型2022-01-2720:341. mysql的数据类型在mysql中有如下几种数据类型:(1)数值型数值是诸如32或者153.4这样的值。mysql支持科学表示法,科学表示法由整数或者浮点数后跟“e”或者%”、一个符号(“+”或者“-)和一个整数指数来表示。1.24e+12和23.47e-l都是合法的科学表示法表示的数。而1.24el2不是合法的,因为指数前的符号未给出。浮点数由整数部份、一个小数点和小数部份组成。整数部份和小数部份可以分别为空,但不能同时为空。数值前可放一个负号“-”以表示负值。(2)字符(串)型字符型(也叫字符串型,简称串)是诸如“hello,W

2、Orld!”或者“一个馒头引起的血案”这样的值,或者是电话号码87398413这样的值。既可用单引号也可用双引号将串值括起来。初学者往往分不清数值87398143和字符串87398143的区别。都是数字啊,怎么一个要用数值型,一个要用字符型呢?关键就在于:数值型的87398143是要参预计算的,比如它是金融中的一个货款总额;而字符型的87398143是不参与计算的,只是表示电话号码,这样的还有街道号码、门牌号码等等,它们都不参预计算。(3)日期和时间型日期和时间是一些诸如“2022-07-12”或者“12:30:43”这样的值。mysql还支持日期/时间的组合,如“2022-07-1212:3

3、0:43”。(4) null值null表示未知值。比如填写表格中通讯地址不清晰留空不填写,这就是null值。我们用createtable语句创建一个表(参看前面的章节),这个表中包含列的定义。例如我们在前面创建了一个joke表,这个表中有COntent和Writer两个列:createtablecontentvarchar(20)notnull,writervarchar(10)null定义一个列的语法如下:col_namecol_typycol_attributesgeneral_attributes其中列名由coLname给出。列名可最多包含64个字符,字符包括字母、数字、下划线及美元符号

4、。列名可以名字中合法的任何符号(包括数字)开头。但列名不能彻底由数字组成,因为那样可能使其与数据分不开。mysql保留诸如select、delete和Create这样的词,这些词不能用做列名,但是函数名(如POS和Inin)是可以使用的。列类型CoLtype表示列可存储的特定值。列类型说明符还能表示存放在列中的值的最大长度。对于某些类型,可用一个数值明确地说明其长度。而此外一些值,其长度由类型名蕴含。例如,char(10)明确指定了10个字符的长度,而tinyblob值隐含最大长度为255个字符。有的类型说明符允许指定最大的显示宽度(即显示值时使用多少个字符)。浮点类型允许指定小数位数,所以能

5、控制浮点数的精度值为多少。可以在列类型之后指定可选的类型说明属性,以及指定更多的常见属性。属性起修饰类型的作用,并更改其处理列值的方式,属性有以下类型:(1)专用属性用于指定列。例如,unsigned属性只针对整型,而binary属性只用于char和Varcharo(2)通用属性除少数列之外可用于任意列。可以指定null或者notnull以表示某个列是否能够存放nullo还可以用default,def_value来表示在创建一个新行但未明确给出该列的值时,该列可赋予值def-value0def_value必须为一个常量;它不能是表达式,也不能引用其他列。未能对blob或者text列指定缺省值。

6、如果想给出多个列的专用属性,可按任意顺序指定它们,只要它们跟在列类型之后、通用属性之前即可。类似地,如果需要给出多个通用属性,也可按任意顺序给出它们,只要将它们放在列类型和可能给出的列专用属性之后即可。2. roysql的列(字段)类型数据库中的每一个表都是由一个或者多个列(字段)构成的。在用createtable语句创建一个表时,要为每列(字段)指定一个类型。歹U(字段)的类型比数据类型更为细化,它精确地描述了给定表列(字段)可能包含的值的种类,如是否带小数、是否文字不少。2.1 数值列类型mysql有整数和浮点数值的列类型,如表1所示。整数列类型可以有符号也可无符号。有一种特殊的属性允许整

7、数列值自动生成,这对需要惟一序列或者标识号的应用系统来说是非常实用的。类型说明tinyintIE常小的整数Smallint较小整数mediumint中等大小整数int标准整数bigint更大整数float单精度浮点数double双精度浮点数decimal一个串的浮点数表1:数值列类型每种数值类型的名称和取值范围如表2所示。类型说明取值范围tinyint(m)有符号值:-128到127(-27到27-1)无符号值:0到255(0到28-1)smallint(m)有符号值:-32768到32767(-215到215-1)无符号值:0至IJ65535(0至IJ216-1)mediumint(m)看符

8、号值:888M888607(-223到223-1)无符号值:0到16777215(0到224-1)int(m)有符号值:-2147683648到2147683647(-231到231-1)无符号值:0到4294967295(0到232-1)bigint(m)有符号值:-9223372036854775808到9223373036854775807(-263到263-1)无符号值:0到18446744073709551615(0到264Dfloat(m,d)最小非零值:1.175494351e-38doublet(m,d)度小非零值:2.2250738585072022c-308decimal(

9、m,d)可变;其值的范围依赖于m和d表2:数值列类型的取值范围各种类型值所需的存储量如表3所示。类型说明存储需求tinyint(m)11字节smallint(m)2字节mediumint(m)字节ht(m),字节bigint(m)8字节float(m,d)4字节double(m,d)8字节一decimal(m,d)m字节(mysql3.23)表3:数值列类型的存储需求mysql提供了五种整型:tinyint、smallintmediumintint和bigintoint为integer的缩写。这些类型在可表示的取值范围上是不同的。整数列可定义为unsigned从而禁用负值;这使列的取值范围为0

10、以上。各种类型的存储量需求也是不同的。取值范围较大的类型所需的存储量较大。mysql提供三种浮点类型:floatdouble和decimal与整型不同,浮点类型不能是unsigned的,其取值范围也与整型不同,这种不同不仅在于这些类型有最大值,而且还有最小非零值。最小值提供了相应类型精度的一种度量,这对于记录科学数据来说是非常重要的(固然,也有负的最大和最小值)。在选择了某种数值类型时,应该考虑所要表示的值的范围,只需选择能覆盖要取值的范围的最小类型即可。选择较大类型会对空间造成浪费,使表不必要地增大,处理起来没有选择较小类型那样有效。对于整型值,如果数据取值范围较小,如人员年龄或者兄弟姐妹数

11、,则tinyint最合适。mediumint能够表示数百万的值并且可用于更多类型的值,但存储代价较大。bigint在全部整型中取值范围最大,而且需要的存储空间是表示范围次大的整型int类型的两倍,因此只在确实需要时才用。对于浮点值,double占用float的两倍空间。除非特殊需要高精度或者范围极大的值,普通应使用只用一半存储代价的float型来表示数据。在定义整型列时,可以指定可选的显示尺寸mo如果这样,m应该是一个1到255的整数。它表示用来显示列中值的字符数。例如,IIIediumint(4)指定了一个具有4个字符显示宽度的mediumint歹J0如果定义了一个没有明确宽度的整数列,将会

12、自动分配给它一个缺省的宽度。缺省值为每种类型的“最长”值的长度。如果某个特定值的可打印表示需要不止m个字符,则显示彻底的值;不会将值截断以适合m个字符。对每种浮点类型,可指定一个最大的显示尺寸m和小数位数dom的值应该取1到255od的值可为0到30,但是不应大于In-2(如果熟悉odbc术语,就会知道m和d对应于Odbc概念的“精度”和“小数点位数”)。m和d对float和double都是可选的,但对于decimal是必须的。在选项m和d时,如果省略了它们,则使用缺省值。2.2 字符串列类型mysql提供了几种存放字符数据的串类型,其类型如下:类型名说明char定长字符串varchar可变长

13、字符串Linyblob非常小的blob(二进制大对象)blob小blobmediumblob中等的blobIongblob大blobtinytext非常小的文本串text小文本串mediumtext中等文本串Iongtext大文本串enum枚举;列可赋予某个枚举成员set集合;列可赋予多个集合成员表4:字符串列类型下表给出了mysql定义串值列的类型,以及每种类型的最大尺寸和存储需求。对于可变长的列类型,各行的值所占的存储量是不同的,这取决于实际存放在列中的值的长度。这个长度在表中用1表示。类型说明最大尺寸存储需求char(m)m字节m字节varchar(m)m字节1+1字节tinyblob,

14、tinytext2-1字节1+1字节blob,text2.6-1字节1+2字节mediumblob,mediumtext22.-1字节1+3字节Iongblob,Iongtext%-1字节1+4字节enum(valuelw,“value2,.)65535个成W1或者2字节set(wValuelw,“value2,.)64个成员1、2、3、4或者8字节表5:串列类型最大尺寸及存储需求1以外所需的额外字节为存放该值的长度所需的字节数。mysql通过存储值的内容及其长度来处理可变长度的值。这些额外的字节是无符号整数。请注意,可变长类型的最大长度、此类型所需的额外字节数以及占用相同字节数的无符号整数之

15、间的对应关系。例如,mediumblob值可能最多224-1字节长并需要3个字节记录其结果。3个字节的整数类型mediumint的最大无符号值为224-1。这并非偶然。2.3 日期时间列类型mysql提供了几种时间值的列类型,它们分别是:datedatetime、time、timestamp和year0下表给出了mysql为定义存储日期和时间值所提供的这些类型,并给出了每种类型的合法取值范围。类型名说明date“yyyy-mm-dd”格式表示的日期值Itime“hh:mm:ss”格式表示的时间值datetime“yyyy-mm-ddhh:mm:SS”格式timestampayyyymmddhh

16、mmss,格式表示的时间戳值yearyyyy”格式的年份值表6:日期时间列类型类型名取值范围I存储需求datewIOOO-Ol-Olw到“9999-12-31”3字节time“-838:59:59”到“838:59:59”3割节datetimeuIOOO-Ol-Ol00:00:00”到u9999-12-3123:59:59”8字节timestamp19700101000000到2037年的某个时刻4字节year1901到21551字节表7:日前时间列类型的取值范围和存储需求下面举个例子:createtablestudent(namevarchar(20)notnullChinesetinyint(3),mathstinyint(3),englishtinyint(3),birthdaydate这个例子创建一个student表,这个表中有name字段,字符类型列,不允许null(空值)。有chinesexmaths和english三个整数类型列。还有个birthday日期类型列。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 生活休闲 > 在线阅读


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号