mysql 5.7 新特性中線上in-place 修改欄位的大小
VARCHAR 欄位的大小能夠透過 ALTER TABLE,命令,以in-place 的方式修改, 例如 :
ALTER TABLE t1 ALGORITHM=INPLACE, CHANGE COLUMN c1 c1 VARCHAR(255);
This is true as long as the number of length bytes required by a VARCHAR column remains the same.只要修改欄位後欄位varchar所佔位元組數和原先的相同就能實現,例如對於 VARCHAR 值在 0到 255,只需要一個bytes. 對於 VARCHAR 的值是 256 bytes 或者大於256 需要兩個位元組.這樣的話,透過 in-place ALTER TABLE 只支援0到255 之間的修改,或者說256 以及大於256之間修改.in-place alter table 不支援小於256的varchar值變更為大於256的值。因為在這種情況下儲存的位元組會從1個位元組變為兩個位元組。只能通algorithm=copy的方式修改,例如將varchar (255)的值修改到256 in-place alter would 會返回一個錯誤
ALTER TABLE t1 ALGORITHM=INPLACE, CHANGE COLUMN c1 c1 VARCHAR(256);
ERROR 0A000: ALGORITHM=INPLACE is not supported. Reason: Cannot change
column type INPLACE. Try ALGORITHM=COPY.
這裡需要著重說明的一點是需要針對不同的字符集來對應如果是英文 0-255 隨便修改如果是其它字符集那麼就需要注意了因為不同字符集佔儲存位不同這裡拿中文做演示。
CREATE TABLE `t1` (
`name` varchar(10) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8
insert into t1 values ('hu')
commit;
mysql> ALTER TABLE t1 ALGORITHM=INPLACE, CHANGE COLUMN name name VARCHAR(100);
ERROR 1846 (0A000): ALGORITHM=INPLACE is not supported. Reason: Cannot change column type INPLACE. Try ALGORITHM=COPY.
mysql> ALTER TABLE t1 ALGORITHM=INPLACE, CHANGE COLUMN name name VARCHAR(86);
ERROR 1846 (0A000): ALGORITHM=INPLACE is not supported. Reason: Cannot change column type INPLACE. Try ALGORITHM=COPY.
mysql>
ALTER TABLE t1 ALGORITHM=INPLACE, CHANGE COLUMN c1 c1 VARCHAR(255);
This is true as long as the number of length bytes required by a VARCHAR column remains the same.只要修改欄位後欄位varchar所佔位元組數和原先的相同就能實現,例如對於 VARCHAR 值在 0到 255,只需要一個bytes. 對於 VARCHAR 的值是 256 bytes 或者大於256 需要兩個位元組.這樣的話,透過 in-place ALTER TABLE 只支援0到255 之間的修改,或者說256 以及大於256之間修改.in-place alter table 不支援小於256的varchar值變更為大於256的值。因為在這種情況下儲存的位元組會從1個位元組變為兩個位元組。只能通algorithm=copy的方式修改,例如將varchar (255)的值修改到256 in-place alter would 會返回一個錯誤
ALTER TABLE t1 ALGORITHM=INPLACE, CHANGE COLUMN c1 c1 VARCHAR(256);
ERROR 0A000: ALGORITHM=INPLACE is not supported. Reason: Cannot change
column type INPLACE. Try ALGORITHM=COPY.
這裡需要著重說明的一點是需要針對不同的字符集來對應如果是英文 0-255 隨便修改如果是其它字符集那麼就需要注意了因為不同字符集佔儲存位不同這裡拿中文做演示。
CREATE TABLE `t1` (
`name` varchar(10) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8
insert into t1 values ('hu')
commit;
mysql> ALTER TABLE t1 ALGORITHM=INPLACE, CHANGE COLUMN name name VARCHAR(100);
ERROR 1846 (0A000): ALGORITHM=INPLACE is not supported. Reason: Cannot change column type INPLACE. Try ALGORITHM=COPY.
mysql> ALTER TABLE t1 ALGORITHM=INPLACE, CHANGE COLUMN name name VARCHAR(86);
ERROR 1846 (0A000): ALGORITHM=INPLACE is not supported. Reason: Cannot change column type INPLACE. Try ALGORITHM=COPY.
mysql>
mysql> ALTER TABLE t1 ALGORITHM=INPLACE, CHANGE COLUMN name name VARCHAR(85);
Query OK, 0 rows affected (0.00 sec)
Records: 0 Duplicates: 0 Warnings: 0
修改為100和86 就報錯修改為85就沒問題 官方文件不是說0-255 只要儲存的位元沒變就可以嗎? 為啥這裡不行呢?
其實官方文件是對的! 因為英文沒錯,但是換成其他字符集的話 儲存佔位不同。
一箇中文字符集佔位UTF8 是三個bit
85*3=255 所以修改為85 可以修改為86 就超過了255 了只能透過copy 的方式了。
Query OK, 0 rows affected (0.00 sec)
Records: 0 Duplicates: 0 Warnings: 0
修改為100和86 就報錯修改為85就沒問題 官方文件不是說0-255 只要儲存的位元沒變就可以嗎? 為啥這裡不行呢?
其實官方文件是對的! 因為英文沒錯,但是換成其他字符集的話 儲存佔位不同。
一箇中文字符集佔位UTF8 是三個bit
85*3=255 所以修改為85 可以修改為86 就超過了255 了只能透過copy 的方式了。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/26764973/viewspace-2136468/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- MySQL 5.7新特性之線上收縮undo表空間MySql
- MySQL5.7密碼欄位變更MySql密碼
- MySQL 5.6使用pt-online-schema-change線上修改大表欄位長度MySql
- MySQL線上新增欄位的幾種方案介紹MySql
- MySQL 5.7 新特性大全和未來展望MySql
- #MySQL# mysql5.7新特性之半同步複製MySql
- MySQL5.7新特性之備份工具mysqlpump的使用MySql
- mysql修改表欄位學習筆記MySql筆記
- mysql資料庫新增和修改欄位MySql資料庫
- MySQL5.7 InnoDB線上DDL操作MySql
- MySQL 5.6, 5.7, 8.0版本的新特性彙總大全MySql
- MySQL中修改一個資料庫下包含有某個相同欄位的所有表的欄位長度MySql資料庫
- MySQL 中 JSON 欄位的使用技巧MySqlJSON
- MySQL中JSON欄位的使用技巧MySqlJSON
- MySQL5.7 group by新特性報錯1055的解決辦法MySql
- MySQL 5.7使用pt-online-schema-change對大表加欄位MySql
- Oracle12C新特性_不可見欄位(二)Oracle
- python獲取、修改mysql資料庫欄位屬性PythonMySql資料庫
- laravel sync()同步時修改中間表欄位Laravel
- mysql 字串型別的數值欄位按照數值的大小進行排序MySql字串型別排序
- oracle 修改表欄位的長度Oracle
- sql語句修改欄位型別和增加欄位SQL型別
- MySQL 8 新特性之持久化全域性變數的修改MySql持久化變數
- MySQL:count(*) count(欄位) 實現上區別MySql
- MySQL 5.7 datetime和timestamp欄位設定default 0 插入資料包錯MySql
- mysql修改某個欄位(替換關鍵字內容)MySql
- MYSQL5.7 ROOT密碼修改教程MySql密碼
- MySQL欄位的取值範圍MySql
- 包括clob segment 大欄位 表的大小統計
- MySQL 欄位約束MySql
- MySQL欄位新增註釋,但不改變欄位的型別MySql型別
- MySQL 5.7配置SSL連線MySql
- MySQL 5.7 新特性 共享臨時表空間及臨時表改進MySql
- MySQL中TEXT與BLOB欄位型別的區別MySql型別
- MySQL - 分組連線欄位函式GROUP_CONCAT的使用MySql函式
- mysql和mongodb替換欄位中某字元MySqlMongoDB字元
- [升級需要用到的] mysql更新表 增加、刪除、修改表欄位MySql
- mysql5.1的新特性MySql
- MySQL如何檢視新增修改表以及欄位註釋資訊MySql