1、整數類型
下表中指明了具體的整數類型,存儲消耗的字節數,最小最大取值范圍,unsigned代表不允許負數,則正整數的取值范圍擴大一倍

mysql> alter table temp1 modify id2 int(20) zerofill;
Query OK, 1 row affected (0.03 sec)
Records: 1 Duplicates: 0 Warnings: 0
mysql> select * from temp1;
+------+----------------------+
| id | id2 |
+------+----------------------+
| 10 | 00000000000000000010 |
+------+----------------------+
####zerofill 表示補零。
2、浮點類型
(1)、Decimal的使用方法舉例為decimal(5,2)
其中的5代表為精度,表示了可以使用多少位數字
其中的2代表小數點后面的小數位數
當不需要指定小數時,可以使用decimal(M),decimal(M,0)表示
M默認值為10 ,M的最大取值為65,D的最大取值為30,當D為0時可以用來存儲比BIGINT更大范圍的整數值
當指定unsigned,表示不允許負數
浮點類型中包含float和double兩種,與decimal相比是不精確類型
(2)、FLOAT[(M,D)] [UNSIGNED]中的M代表可以使用的數字位數,D則代表小數點后的小數位數
Unsigned(無)代表不允許使用負數
Float的取值范圍為-3.402823466E+38 to -1.175494351E-38, 0, and 1.175494351E-38 to 3.402823466E+38
(3)、DOUBLE[(M,D)] [UNSIGNED]中的M代表可以使用的數字位數,D則代表小數點后的小數位數
Double的取值范圍對比float要大,-1.7976931348623157E+308 to -2.2250738585072014E-308, 0, and 2.2250738585072014E-308 to 1.7976931348623157E+308
3、時間日期類型
(1)、Date類型用來表示僅日期,MySQL默認的日期格式為yyyy-mm-dd,取值范圍為1000-01-01到9999-12-31
(2)、Datetime類型用來表示日期和時間,MySQL默認的格式為yyyy-mm-dd hh:mi:ss,取值范圍為1000-01-01 00:00:00到9999-12-31 23:59:59
(3)、Timestamp類型也用來表示日期和時間,其取值范圍為1970-01-01 00:00:01到2038-01-19 03:14:07
Datetime和timestamp兩個類型都可以保存到微妙級別,即6位毫秒微妙精度,即1000-01-01 00:00:00.000000到9999-12-31 23:59:59.999999和1970-01-01 00:00:01.000000到2038-01-19 03:14:07.999999
非法的date,datetime,timestamp值將被轉換成0值,0000-00-00或者0000-00-00 00:00:00
(4)、Time類型用來僅表示時間,MySQL默認格式為HH:MM:SS,其取值范圍為-838:59:59到838:59:59,小時字段可以超過24是因為time類型不光代表小時,也可以代表持續時長中的小時
Time類型也可以包含6位的毫秒微秒精度,其取值范圍為-838:59:59.000000到838:59:59.000000
(5)、Year類型用來僅表示年份,MySQL默認格式為YYYY,其取值范圍為1901到2155,和0000
針對非法的year數據,則直接轉化為0000
**當在time,timestamp,datetime中指定含有毫秒微秒數值時,則用type_name(fsp)來表達,其中fsp可以取0到6之間的數值**
字符類型
字符類型包含char, varchar, binary, varbinary, blob, text, enum和set
1、Char和varchar可以通過char(M)和varchar(M)指定可以存儲的最大字符數,比如char(30)表示可以存儲最長30個字符
Char類型的長度一旦指定就固定了,其范圍可以是0到255,當被存儲時,未達到指定長度的則在值右邊填充空格,而獲取數據時則會把右側的空格去掉
Varchar類型是變長的類型,其范圍可以是0到65535,當存儲是未達到指定長度則不填充空格

Varchar類型用來存儲可變長字符串,是最常見的字符串數據類型,它比定長類型更節省空間,因為它僅使用必要的空間。
另外varchar需要使用1或2個額外字節記錄字符串的長度,如果列的最大長度小于等于255字節時,需要1個字節,否則需要2個字節。比如采用Latin1字符集,varchar(10)的列需要11個字節的存儲空間,而varchar(1000)列需要1002個字節的存儲空間。
varchar節省了存儲空間,所以對性能也有幫助。但由于行是變長的,在update時可能使行變得比原來更長,這就導致需要做額外的工作。如果一行占用的空間增長,并且物理數據頁內沒有更多空間存儲時,MyISAM會將行拆成不同的片段存儲,InnoDB需要分列頁來講行放到數據頁里。
char類型是定長,MySQL總是根據定義的字符串長度分配足夠的空間。當存儲char值時,MySQL會刪除所有的末尾空格
char適合存儲很短的字符串,或者所有值都接近同一個長度。對于經常變更的數據,char也比varchar更好,因為定長的char類型不容易產生碎片。而且對非常短的字符串,char不需要一個額外的字節記錄長度
Char類型值右邊的空格會被自動剔除,而varchar類型則不會
2、Binary和varbinary類型和char/varchar類似,只不過是存儲二進制字符
3、長字段
Blob和text類型被用來存儲大量的數據
Blob是用來存儲二進制的大量數據,其有四種類型,tinyblob、blob、mediumblob、longblob四種的區別是能存儲的數據長度有所不同
Text是用來存儲字符型的大量數據,其有四種類型, tinytext、text、mediumtext、longtext四種的區別是能存儲的數據長度有所不同
Blob和text的列字段不能含有默認值
4、枚舉類型
Enum枚舉類型是字符串類型,其值是從事先指定的一系列值中選出,適用在某列的取值范圍已經固定。
主要好處為MySQL在存儲此類數據時,直接轉化成數字存儲而不是字符串,可以節省空間,并且在表的.frm文件中存儲“數字-字符串”之間的對應關系。
另外枚舉類型的排序規則是按照存儲順序進行而不是按照值本身排序的
如果想要按照一般的排序規則進行排序,需要使用field()函數顯示指定排序規則
select size from shirts order by field(size,’large’,’medium’,’small’)
枚舉類型字段的取值的增加必須通過alter table命令
mysql> alter table shirts modify size ENUM('x-small', 'small', 'medium', 'large', 'x-large','xx-large');
Enum枚舉類型最多可以有65535個值
當插入數字到枚舉類型字段時,數字會被當做枚舉值的第幾個值而插入
Enum枚舉類型最多可以有65535個值
當插入數字到枚舉類型字段時,數字會被當做枚舉值的第幾個值而插入
5、集合類型
Set集合類型是字符類型,可以含有0個或多個值,其中的每個值都需要是在創建字段時指定的集合中
比如一個字段被指定為SET(‘one’, ‘two’) not null可以含有以下四種值
''
'one'
'two'
'one,two‘
Set集合最大可以有255個值。MySQL在存儲set集合時,同樣也是存儲為數字類型。
- 一、日常運維腳本
- 1.1 批量創建用戶并賦予sudo權限
- 1.2 批量主機建立互信
- 1.3create_images.sh
- 1.4monitor.sh
- 1.5ftp腳本
- 1.6格式化分區
- 1.7簡單的遠程執行腳本
- 二、常用服務使用
- 1 ceph (分布式文件系統)
- 1.1 ceph 簡介
- 1.2 準備環境
- 1.3 開始部署
- 1.4 cephfs掛載
- 1.5 RBD塊存儲
- 1.6 object 對象存儲
- 1.7 集群擴展
- 1.7.1 增加刪除MON
- 1.7.2 增加刪除OSD
- 1.7.3 刪除MDS
- 注意事項
- 遇到的問題
- 1.8ceph查找數據文件
- 1.9卸載并清理環境
- 2、mysql (數據庫)
- 2.1 搭建
- 2.2 使用教程
- 2.2.1 mysql基礎配置
- 2.2.1.1 用戶權限管理
- 2.2.1.2用戶資源限制
- 2.2.1.3 密碼管理
- 2.2.1.4用戶lock
- 2.2.2mysql語法詳解
- 2.2.1建庫、表語句
- 2.2.2.2 插入 insert
- 2.2.2.3更新 update
- 2.2.2.4刪除 delete
- 2.2.2.5查詢 select
- 2.2.6視圖 索引 view index
- 2.2.7 修改 alert
- 2.2.2.8清理 truncate drop
- 2.2.9重命名 rename
- 示例語句
- 2.2.3mysql常用函數
- 2.3.1 對比操作符統概
- 2.3.2對比操作符詳解
- 2.3.3邏輯操作符
- 2.2.4分配操作符
- 2.2.5流程控制函數
- 2.2.6字符串函數
- 2.2.7字符串對比函數
- 2.2.8數字函數
- 2.2.9日期和時間函數
- 2.2.10聚合/格式轉換函數
- 2.2.11 子查詢
- 示例語句
- 2.2.4 mysql 高級應用
- 2.2.4.1 存儲過程 函數
- 2.2.4.2流程控制
- 2.2.4.3游標
- 2.2.4.4觸發器
- 課堂練習
- 2.2.2.5 數據庫設計
- 2.2.5.1 數據類型
- 2.2.5.2存儲引擎
- 2.2.6Innodb內核
- 1、innodb事務和多版本控制
- 2、體系結構
- 3、InnoDB配置
- 4、buffer pool設置
- 5、其他配置
- innodb限制
- 2.7 字符集
- 2.8鎖機制和事務
- 2.8.1鎖機制
- 2.8.2事務
- 2.9分區
- 2.9.1 自動分區
- 2.10復制
- 2.11mysql搬移數據目錄
- 2.12組復制 GR
- 簡介
- 搭建
- 2.3日常運維
- 2.3.1定時任務
- 2.4mycat
- 2.4.1 報錯分析
- 2.4.2 修改字符集
- 2.11 mycat使用
- 2.5遇到問題
- 2.5.1 表名庫名忽略大小寫
- 3、PAAS平臺搭建
- 問題匯總
- 1、docker
- 2、日常運維
- 3.1 Kubernetes
- 3.1 kubernetes 高版本搭建
- 4、GlusterFS搭建
- 5、MooseFS搭建
- 5.1搭建
- 5.2運維
- 5.2.1 mfs日志解析
- 5.2.2清理mfs的垃圾數據
- 5.2.3元數據故障恢復
- 5.2.4 MFS優化
- 5.2.5 配置機架感知
- 5.2.6 客戶端工具集
- 6、集群切換命令
- 7、ntp服務
- 8、monggoDB
- 8.1搭建單機
- 2、搭建集群及分片
- 9、MariaDB Galera Cluster
- 9.1源碼安裝MariaDB
- 9.2galera cluster 優劣
- 9.3 rpm安裝mariadb
- 10 HAproxy1.7搭建
- 11、sysbench 搭建使用
- 0.5版本
- 12 percona-xtradb-cluster
- 13http服務相關
- 13.1 http狀態碼解析
- 14 zookeeper
- 14.1 zookeeper日志查看
- 14.2 配置解析
- 14.3 優化
- 15搭建私有pip源
- 16/var/log的日志文件解釋
- 15 ansible的搭建及使用
- 15.1 搭建
- 15.2 使用說明
- 16. 搭建本地yum源
- zookeeper
- 優化
- 四、開發語言
- 1、GO語言
- 1.1go簡介
- 1.1.1hello_world初識GO
- 1.1.2并發介紹
- 1.1.3 chan介紹
- 1.1.4多返回值
- 1.2go基礎
- 1.2.1數據類型
- 1.2.2 go基礎結構
- 1.2.3 const及變量介紹
- 1.2.3os和time介紹
- 1.2.4 字符串
- 1.2.5條件判斷
- 1.2.6 homework
- go--help
- 1.3 go基礎2
- 1.3.1 數組 array
- 1.3.2切片 slice
- 1.3.3 時間和日期
- 1.3.4指針類型
- 1.3.5函數
- 1.3.6可變參數
- 1.3.7 defer
- 1.3.8遞歸
- 1.9閉包
- 1.10 map
- 1.11 sort
- 1.12 struct 結構體
- 2.perl語言
- 2.1 安裝lib包
- 3 python
- 1.語言基礎
- 2、編程教學
- 2.1變量和序列
- 2.2 條件語句