欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解MySQL中數(shù)據(jù)類型和字段類型

 更新時(shí)間:2022年09月26日 11:33:37   作者:洛陽泰山  
這篇文章主要為大家詳細(xì)介紹了MySQL中數(shù)據(jù)類型和字段類型的使用,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)MySQL有一定幫助,需要的可以參考一下

1. mysql的數(shù)據(jù)類型 

在mysql中有如下幾種數(shù)據(jù)類型: 

(1)數(shù)值型 

數(shù)值是諸如32 或153.4 這樣的值。mysql 支持科學(xué)表示法,科學(xué)表示法由整數(shù)或浮點(diǎn)數(shù)后跟“e”或“e”、一個(gè)符號(hào)(“+”或“-”)和一個(gè)整數(shù)指數(shù)來表示。1.24e+12 和23.47e-1 都是合法的科學(xué)表示法表示的數(shù)。而1.24e12 不是合法的,因?yàn)橹笖?shù)前的符號(hào)未給出。 

浮點(diǎn)數(shù)由整數(shù)部分、一個(gè)小數(shù)點(diǎn)和小數(shù)部分組成。整數(shù)部分和小數(shù)部分可以分別為空,但不能同時(shí)為空。 

數(shù)值前可放一個(gè)負(fù)號(hào)“-”以表示負(fù)值。 

(2)字符(串)型 

字符型(也叫字符串型,簡(jiǎn)稱串)是諸如“hello, world!”或“一個(gè)饅頭引起的血案”這樣的值,或者是電話號(hào)碼87398413這樣的值。既可用單引號(hào)也可用雙引號(hào)將串值括起來。

初學(xué)者往往分不清數(shù)值87398143和字符串87398143的區(qū)別。都是數(shù)字啊,怎么一個(gè)要用數(shù)值型,一個(gè)要用字符型呢?關(guān)鍵就在于:數(shù)值型的87398143是要參與計(jì)算的,比如它是金融中的一個(gè)貨款總額;而字符型的87398143是不參與計(jì)算的,只是表示電話號(hào)碼,這樣的還有街道號(hào)碼、門牌號(hào)碼等等,它們都不參與計(jì)算。 

(3)日期和時(shí)間型 

日期和時(shí)間是一些諸如“2006-07-12”或“12:30:43”這樣的值。mysql還支持日期/時(shí)間的組合,如“2006-07-12 12:30:43”。 

(4)null值 

null表示未知值。比如填寫表格中通訊地址不清楚留空不填寫,這就是null值。 

我們用create table語句創(chuàng)建一個(gè)表(參看前面的章節(jié)),這個(gè)表中包含列的定義。例如我們?cè)谇懊鎰?chuàng)建了一個(gè)joke表,這個(gè)表中有content和writer兩個(gè)列:    

create table
(
content varchar(20) not null,
writer varchar(10) null
)

定義一個(gè)列的語法如下:   

col_name col_typy [col_attributes] [general_attributes]

其中列名由col_name 給出。列名可最多包含64個(gè)字符,字符包括字母、數(shù)字、下劃線及美元符號(hào)。列名可以名字中合法的任何符號(hào)(包括數(shù)字)開頭。但列名不能完全由數(shù)字組成,因?yàn)槟菢涌赡苁蛊渑c數(shù)據(jù)分不開。mysql保留諸如select、delete和create這樣的詞,這些詞不能用做列名,但是函數(shù)名(如pos 和min)是可以使用的。 

列類型col_type表示列可存儲(chǔ)的特定值。列類型說明符還能表示存放在列中的值的最大長(zhǎng)度。對(duì)于某些類型,可用一個(gè)數(shù)值明確地說明其長(zhǎng)度。而另外一些值,其長(zhǎng)度由類型名蘊(yùn)含。例如,char(10) 明確指定了10個(gè)字符的長(zhǎng)度,而tinyblob值隱含最大長(zhǎng)度為255個(gè)字符。有的類型說明符允許指定最大的顯示寬度(即顯示值時(shí)使用多少個(gè)字符)。浮點(diǎn)類型允許指定小數(shù)位數(shù),所以能控制浮點(diǎn)數(shù)的精度值為多少。 

可以在列類型之后指定可選的類型說明屬性,以及指定更多的常見屬性。屬性起修飾類型的作用,并更改其處理列值的方式,屬性有以下類型: 

  • 專用屬性用于指定列。例如,unsigned 屬性只針對(duì)整型,而binary屬性只用于char 和varchar。 
  • 通用屬性除少數(shù)列之外可用于任意列。可以指定null 或not null 以表示某個(gè)列是否能夠存放null。還可以用default,def_value 來表示在創(chuàng)建一個(gè)新行但未明確給出該列的值時(shí),該列可賦予值def_value。def_value 必須為一個(gè)常量;它不能是表達(dá)式,也不能引用其他列。不能對(duì)blob 或text 列指定缺省值。 

如果想給出多個(gè)列的專用屬性,可按任意順序指定它們,只要它們跟在列類型之后、通用屬性之前即可。類似地,如果需要給出多個(gè)通用屬性,也可按任意順序給出它們,只要將它們放在列類型和可能給出的列專用屬性之后即可。

2. mysql的列(字段)類型 

數(shù)據(jù)庫(kù)中的每個(gè)表都是由一個(gè)或多個(gè)列(字段)構(gòu)成的。在用create table語句創(chuàng)建一個(gè)表時(shí),要為每列(字段)指定一個(gè)類型。列(字段)的類型比數(shù)據(jù)類型更為細(xì)化,它精確地描述了給定表列(字段)可能包含的值的種類,如是否帶小數(shù)、是否文字很多。 

2.1數(shù)值列類型 

mysql有整數(shù)和浮點(diǎn)數(shù)值的列類型,如表1所示。整數(shù)列類型可以有符號(hào)也可無符號(hào)。有一種特殊的屬性允許整數(shù)列值自動(dòng)生成,這對(duì)需要唯一序列或標(biāo)識(shí)號(hào)的應(yīng)用系統(tǒng)來說是非常有用的。

表1:數(shù)值列類型

類型說明
tinyint    非常小的整數(shù)
smallint    較小整數(shù)
mediumint    中等大小整數(shù)
int    標(biāo)準(zhǔn)整數(shù)
bigint    較大整數(shù)
float單精度浮點(diǎn)數(shù)
double    雙精度浮點(diǎn)數(shù)
decimal    一個(gè)串的浮點(diǎn)數(shù)

每種數(shù)值類型的名稱和取值范圍如表2所示。

表2:數(shù)值列類型的取值范圍

類型說明 取值范圍
tinyint[(m)] 有符號(hào)值:-128 到127(- 27 到27 - 1)
無符號(hào)值:0到255(0 到28 - 1) 
smallint[(m)]有符號(hào)值:-32768 到32767(- 215 到215 - 1)
無符號(hào)值:0到65535(0 到21 6 - 1)
mediumint[(m)]有符號(hào)值:-8388608 到8388607(- 22 3 到22 3 - 1 )
無符號(hào)值:0到16777215(0 到22 4 - 1)
int[(m)]有符號(hào)值:-2147683648 到2147683647(- 231 到231- 1)
無符號(hào)值:0到4294967295(0 到232 - 1)
bigint[(m)]有符號(hào)值:-9223372036854775808 到9223373036854775807(- 263到263-1)
無符號(hào)值:0到18446744073709551615(0到264 – 1)
float[(m, d)]最小非零值:±1.175494351e - 38
double[(m,d)]最小非零值:±2.2250738585072014e - 308
decimal (m, d)可變;其值的范圍依賴于m 和d

各種類型值所需的存儲(chǔ)量如表3所示。

表3:數(shù)值列類型的存儲(chǔ)大小

類型說明 存儲(chǔ)大小
tinyint[(m)]1字節(jié)
smallint[(m)] 2字節(jié)
mediumint[(m)]3字節(jié)
int[(m)] 4字節(jié)
bigint[(m)]8字節(jié)
float[(m, d)]4字節(jié)
double[(m, d)] 8字節(jié)
decimal (m, d)m字節(jié)(mysql < 3.23),m+2字節(jié)(mysql > 3.23 )

mysql提供了五種整型: tinyint、smallint、mediumint、int和bigint。int為integer的縮寫。這些類型在可表示的取值范圍上是不同的。整數(shù)列可定義為unsigned從而禁用負(fù)值;這使列的取值范圍為0以上。各種類型的存儲(chǔ)量需求也是不同的。取值范圍較大的類型所需的存儲(chǔ)量較大。 

mysql 提供三種浮點(diǎn)類型: float、double和decimal。與整型不同,浮點(diǎn)類型不能是unsigned的,其取值范圍也與整型不同,這種不同不僅在于這些類型有最大值,而且還有最小非零值。最小值提供了相應(yīng)類型精度的一種度量,這對(duì)于記錄科學(xué)數(shù)據(jù)來說是非常重要的(當(dāng)然,也有負(fù)的最大和最小值)。 

在選擇了某種數(shù)值類型時(shí),應(yīng)該考慮所要表示的值的范圍,只需選擇能覆蓋要取值的范圍的最小類型即可。選擇較大類型會(huì)對(duì)空間造成浪費(fèi),使表不必要地增大,處理起來沒有選擇較小類型那樣有效。對(duì)于整型值,如果數(shù)據(jù)取值范圍較小,如人員年齡或兄弟姐妹數(shù),則tinyint最合適。mediumint能夠表示數(shù)百萬的值并且可用于更多類型的值,但存儲(chǔ)代價(jià)較大。bigint在全部整型中取值范圍最大,而且需要的存儲(chǔ)空間是表示范圍次大的整型int類型的兩倍,因此只在確實(shí)需要時(shí)才用。對(duì)于浮點(diǎn)值,double占用float的兩倍空間。除非特別需要高精度或范圍極大的值,一般應(yīng)使用只用一半存儲(chǔ)代價(jià)的float型來表示數(shù)據(jù)。 

在定義整型列時(shí),可以指定可選的顯示尺寸m。如果這樣,m應(yīng)該是一個(gè)1 到255的整數(shù)。它表示用來顯示列中值的字符數(shù)。例如,mediumint(4)指定了一個(gè)具有4個(gè)字符顯示寬度的mediumint列。如果定義了一個(gè)沒有明確寬度的整數(shù)列,將會(huì)自動(dòng)分配給它一個(gè)缺省的寬度。缺省值為每種類型的“最長(zhǎng)”值的長(zhǎng)度。如果某個(gè)特定值的可打印表示需要不止m個(gè)字符,則顯示完全的值;不會(huì)將值截?cái)嘁赃m合m個(gè)字符。 

對(duì)每種浮點(diǎn)類型,可指定一個(gè)最大的顯示尺寸m 和小數(shù)位數(shù)d。m 的值應(yīng)該取1 到255。d的值可為0 到3 0,但是不應(yīng)大于m - 2(如果熟悉odbc 術(shù)語,就會(huì)知道m(xù) 和d 對(duì)應(yīng)于odbc 概念的“精度”和“小數(shù)點(diǎn)位數(shù)”)。m和d對(duì)float和double 都是可選的,但對(duì)于decimal是必須的。在選項(xiàng)m 和d時(shí),如果省略了它們,則使用缺省值。

2.2字符串列類型 

mysql提供了幾種存放字符數(shù)據(jù)的串類型,其類型如下:

表4:字符串列類型

類型名說明
char    定長(zhǎng)字符串
varchar    可變長(zhǎng)字符串
tinyblob非常小的blob(二進(jìn)制大對(duì)象)
blob標(biāo)準(zhǔn)blob
mediumblob中blob
longblob大blob
tinytext非常小的文本串
text標(biāo)準(zhǔn)的文本串
mediumtext中等的文本串
longtext大文本串
enum枚舉;列可賦予某個(gè)枚舉成員
set集合;列可賦予多個(gè)集合成員

下表給出了mysql 定義串值列的類型,以及每種類型的最大尺寸和存儲(chǔ)需求。對(duì)于可變長(zhǎng)的列類型,各行的值所占的存儲(chǔ)量是不同的,這取決于實(shí)際存放在列中的值的長(zhǎng)度。這個(gè)長(zhǎng)度在表中用l 表示。

表5:串列類型最大尺寸及存儲(chǔ)需求

類型名最大存儲(chǔ)實(shí)際存儲(chǔ)
char     m 字節(jié) m 字節(jié)
varchar     m 字節(jié)l + 1字節(jié)
tinyblob    28- 1字節(jié)  l + 1字節(jié)
blob    216 - 1 字節(jié)    l + 2字節(jié)
mediumblob    224- 1字節(jié)l + 3字節(jié)
longblob232- 1字節(jié)l + 4字節(jié)
tinytext28- 1字節(jié)l + 1字節(jié)
text216 - 1 字節(jié)l + 2字節(jié)
mediumtext224- 1字節(jié)l + 3字節(jié)
longtext232- 1字節(jié)l + 4字節(jié)
enum2字節(jié)1 或2字節(jié)
set8字節(jié)1、2、3、4或8字節(jié)

l 以外所需的額外字節(jié)為存放該值的長(zhǎng)度所需的字節(jié)數(shù)。mysql 通過存儲(chǔ)值的內(nèi)容及其長(zhǎng)度來處理可變長(zhǎng)度的值。這些額外的字節(jié)是無符號(hào)整數(shù)。請(qǐng)注意,可變長(zhǎng)類型的最大長(zhǎng)度、此類型所需的額外字節(jié)數(shù)以及占用相同字節(jié)數(shù)的無符號(hào)整數(shù)之間的對(duì)應(yīng)關(guān)系。例如,mediumblob 值可能最多224 - 1字節(jié)長(zhǎng)并需要3 個(gè)字節(jié)記錄其結(jié)果。3 個(gè)字節(jié)的整數(shù)類型mediumint 的最大無符號(hào)值為224 - 1。這并非偶然。

2.3日期時(shí)間列類型 

mysql 提供了幾種時(shí)間值的列類型,它們分別是: date、datetime、time、timestamp和year。下表給出了mysql 為定義存儲(chǔ)日期和時(shí)間值所提供的這些類型,并給出了每種類型的合法取值范圍。

表6:日期時(shí)間列類型

類型名說明
date    “yyyy-mm-dd”格式表示的日期值
time    “hh:mm:ss”格式表示的時(shí)間值
datetime    “yyyy-mm-dd hh:mm:ss”格式
timestamp“yyyymmddhhmmss”格式表示的時(shí)間戳值
year“yyyy”格式的年份值

表7: 日前時(shí)間列類型的取值范圍和存儲(chǔ)大小

類型名 取值范圍存儲(chǔ)大小
date    “1000-01-01”到“9999-12-31”3字節(jié)
time    “-838:59:59”到“838:59:59”3字節(jié)
datetime“1000-01-01 00:00:00” 到“9999-12-31 23:59:59”8字節(jié)
timestamp19700101000000 到2037 年的某個(gè)時(shí)刻4字節(jié)
year1901 到21551字節(jié)

下面舉個(gè)例子:   

create table student
(
name varchar(20) not null,
chinese tinyint(3),
maths tinyint(3),
english tinyint(3),
birthday date
)

這個(gè)例子創(chuàng)建一個(gè)student表,這個(gè)表中有name字段,字符類型列,不允許null(空值)。有chinese、maths和english三個(gè)整數(shù)類型列。還有個(gè)birthday日期類型列。

到此這篇關(guān)于詳解MySQL中數(shù)據(jù)類型和字段類型的文章就介紹到這了,更多相關(guān)MySQL數(shù)據(jù) 字段類型內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • mysql 8.0.16 winx64及Linux修改root用戶密碼 的方法

    mysql 8.0.16 winx64及Linux修改root用戶密碼 的方法

    這篇文章主要介紹了mysql 8.0.16 winx64及Linux修改root用戶密碼 的方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-07-07
  • mysql select語句操作實(shí)例

    mysql select語句操作實(shí)例

    這篇文章主要介紹了mysql select語句操作實(shí)例,本文給出了ORDER BY查詢、GROUP BY查詢、LIMIT查詢、UNION等語句的實(shí)例,需要的朋友可以參考下
    2014-12-12
  • MySQL聯(lián)表查詢的簡(jiǎn)單示例

    MySQL聯(lián)表查詢的簡(jiǎn)單示例

    這篇文章主要給大家介紹了關(guān)于MySQL聯(lián)表查詢的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用MySQL具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • sqoop export導(dǎo)出 map100% reduce0% 卡住的多種原因及解決

    sqoop export導(dǎo)出 map100% reduce0% 卡住的多種原因及解決

    這篇文章主要介紹了sqoop export導(dǎo)出 map100% reduce0% 卡住的多種原因及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • Mysql關(guān)于進(jìn)程中的死鎖和解除鎖問題

    Mysql關(guān)于進(jìn)程中的死鎖和解除鎖問題

    Mysql 經(jīng)常會(huì)遇到語句或者存儲(chǔ)過程長(zhǎng)時(shí)間沒有反應(yīng),大概率就是掛掉了,或者死鎖了,這篇文章主要介紹了Mysql關(guān)于進(jìn)程中的死鎖和解除鎖問題,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-07-07
  • 詳解MySQL中的基本表與視圖

    詳解MySQL中的基本表與視圖

    Mysql是一種常用的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),其中的基本表和視圖是數(shù)據(jù)庫(kù)中存儲(chǔ)和操作數(shù)據(jù)的兩種重要方式,本文將介紹什么是基本表和視圖,并探討為何要使用視圖以及視圖的優(yōu)缺點(diǎn),最后,將給出在Mysql中創(chuàng)建視圖的方法,需要的朋友可以參考下
    2023-09-09
  • mysql存儲(chǔ)引擎和數(shù)據(jù)類型(二)

    mysql存儲(chǔ)引擎和數(shù)據(jù)類型(二)

    這篇文章主要為大家詳細(xì)介紹了mysql存儲(chǔ)引擎和數(shù)據(jù)類型第二篇,感興趣的小伙伴們可以參考一下
    2016-08-08
  • SQL匯總統(tǒng)計(jì)與GROUP BY過濾查詢實(shí)現(xiàn)

    SQL匯總統(tǒng)計(jì)與GROUP BY過濾查詢實(shí)現(xiàn)

    這篇文章主要介紹了SQL匯總統(tǒng)計(jì)與GROUP BY過濾查詢實(shí)現(xiàn),GROUP BY 實(shí)質(zhì)是先排序后分組,遵照索引建的最佳左前綴。當(dāng)無法使用索引時(shí),增大max_length_for_sort_data和sort_buffer參數(shù)的值
    2023-01-01
  • MySQL常用表級(jí)操作總結(jié)

    MySQL常用表級(jí)操作總結(jié)

    這篇文章主要為大家詳細(xì)介紹了MySQL中常用的表級(jí)操作,文中的示例代碼簡(jiǎn)潔易懂,對(duì)我們學(xué)習(xí)MySQL有一定的幫助,感興趣的小伙伴可以學(xué)習(xí)一下
    2023-08-08
  • MySQL中SQL命令語句條件查詢實(shí)例詳解

    MySQL中SQL命令語句條件查詢實(shí)例詳解

    SELECT語句可以通過WHERE條件來設(shè)定查詢條件,查詢結(jié)果是滿足查詢條件的記錄,下面這篇文章主要給大家介紹了關(guān)于MySQL中SQL命令語句條件查詢的相關(guān)資料,需要的朋友可以參考下
    2022-11-11

最新評(píng)論