INSERT 陳述式完成下列操作,這些操作全都涉及資料類型:
■ 將整數值14 賦給整數列i n t _ c o l。
■ 將串值“ a”和“b”傳遞給函數C O N C AT( )。C O N C AT( ) 返回串值“a b”,這個串值被賦予串列s t r _ c o l。
■ 將整數值1999 0 115 賦給日期列date _ c o l。而這是不匹配的,因此, MySQL將自動進行資料類型轉換。要有效地利用MySQL,必須理解其怎樣處理資料。本章描述了MySQL能夠處理的資料類型,並討論了在處理這些資料類型時所出現的問題,主要內容如下:
■ 通用資料類型,包括NULL 值。
■ 特殊資料類型,以及描述每種列類型的屬性。有些列類型是相當常見的,如CHAR 串類型。而有的如AUTO_INCREMENT 整型和T I M E S TAMP 日期類型,其效能很特殊,應該加以理解以免出錯。
■ 恰當地選擇表的列類型。在建立表時,重要的是要瞭解怎樣為自己的目的選擇最好的類型,以及在幾種類型都可以用於想要儲存的值時選擇一種類型。
■ 運算式求值規則。MySQL提供了許多可用於運算式的運算子和函數,以便對資料進行檢索、顯示和處理。運算式求值的規則包括類型轉換規則,在一種類型的值用於另一類型的值的情況時需用到類型轉換規則。理解何時進行類型轉換以及怎樣進行轉換很重要;有的轉換沒有意義而且會產生錯誤值。將串“13”賦給整數列結果為值13,但是將串“a b c” 賦給該列得到0 值,因為“a b c”不是一個數。更壞的是,如果進行比較而不瞭解值的轉換,可能會帶來很大的危險,如在打算只對幾行進行操作時,可能會更新或刪除了表中的所有行。附錄B和附錄C提供了MySQL列類型、運算和函數的更多資訊。
2.1MySQL資料類型
MySQL有幾種資料類型,下面分別進行介紹。
1. 數值值
數值是諸如48 或193.62 這樣的值。MySQL支援說明為整數(無小數部分)或浮點數(有小數部分)的值。整數可按十進位形式或十六進位形式表示。整數由數字序列組成。以十六進位形式表示的整數由“ 0 x”後跟一個或多個十六進位數字(” 0”到“9”及“a”到“f”)組成。例如, 0x0a 為十進位的10,而0 x ffff 為十進位的6 5 5 3 5。十六進位數字不區分大小寫,但其首碼“ 0 x”不能為“ 0 X”。即0x0a 和0x0A 都是合法的,但0X0a 和0X0A 不是合法的。浮點數由一個阿拉伯數字序列、一個小數點和另一個阿拉伯數字序列組成。兩個阿拉伯數字序列可以分別為空白,但不能同時為空白。MySQL支援科學標記法。科學標記法由整數或浮點數後跟“ e”或“E”、一個符號(“+”或“-”)和一個整數指數來表示。1.34E+12 和43.27e-1都是合法的科學標記法表示的數。而1.34E12 不是合法的,因為指數前的符號未給出。指數前的“ e”也是一個合法的十六進位數字,因此有可能會弄錯。數值前可放一個負號“ -”以表示負值。
2. (字元)串值 串是諸如“Madison, Wi s c o n s i n”或“patient shows improvement”這樣的值。既可用單引號也可用雙引號將串值括起來。串中可使用幾個逸出序列,它們用來表示特殊的字元,見表2 - 1。每個序列以一個反斜線(“\”)開始,指出臨時不同於通常的字元解釋。注意NUL 位元組與NULL 值不同;NUL 為一個零值位元組,而NULL 為沒有值。