㈠ mysql大表添加欄位超市怎麼處理
mysql大表添加欄位超市處理方法。
①創建一個臨時的新表,首先復制舊表的結構(包含索引);
②給新表加上新增的欄位;
③把舊表的數據復制過來;
④刪除舊表,重命名新表的名字為舊表的名字。
㈡ MySQL命令行中給表添加一個欄位(欄位名、是否為空、默認值)
先看一下最簡單的例子,在test中,添加一個欄位,欄位名為birth,類型為date類型。
mysql>
alter
table
test
add
column
birth
date;
Query
OK,
0
rows
affected
(0.36
sec)
Records:
0
Duplicates:
0
Warnings:
0
查詢一下數據,看看結果:
mysql>
select
*
from
test;
+------+--------+----------------------------------+------------+-------+
|
t_id
|
t_name
|
t_password
|
t_birth
|
birth
|
+------+--------+----------------------------------+------------+-------+
|
1
|
name1
|
|
NULL
|
NULL
|
|
2
|
name2
|
|
2013-01-01
|
NULL
|
+------+--------+----------------------------------+------------+-------+
2
rows
in
set
(0.00
sec)
從上面結果可以看出,插入的birth欄位,默認值為空。我們再來試一下,添加一個birth1欄位,設置它不允許為空。
mysql>
alter
table
test
add
column
birth1
date
not
null;
Query
OK,
0
rows
affected
(0.16
sec)
Records:
0
Duplicates:
0
Warnings:
0
居然執行成功了!?意外了!我原來以為,這個語句不會成功的,因為我沒有給他指定一個默認值。我們來看看數據:
mysql>
select
*
from
test;
+------+--------+----------------------------------+------------+-------+------------+
|
t_id
|
t_name
|
t_password
|
t_birth
|
birth
|
birth1
|
+------+--------+----------------------------------+------------+-------+------------+
|
1
|
name1
|
|
NULL
|
NULL
|
0000-00-00
|
|
2
|
name2
|
|
2013-01-01
|
NULL
|
0000-00-00
|
+------+--------+----------------------------------+------------+-------+------------+
2
rows
in
set
(0.00
sec)
哦,明白了,系統自動將date類型的值,設置了一個默認值:0000-00-00。下面我來直接指定一個默認值看看:
mysql>
alter
table
test
add
column
birth2
date
default
'2013-1-1';
Query
OK,
0
rows
affected
(0.28
sec)
Records:
0
Duplicates:
0
Warnings:
0
mysql>
select
*
from
test;
+------+--------+----------------------------------+------------+-------+------------+------------+
|
t_id
|
t_name
|
t_password
|
t_birth
|
birth
|
birth1
|
birth2
|
+------+--------+----------------------------------+------------+-------+------------+------------+
|
1
|
name1
|
|
NULL
|
NULL
|
0000-00-00
|
2013-01-01
|
|
2
|
name2
|
|
2013-01-01
|
NULL
|
0000-00-00
|
2013-01-01
|
+------+--------+----------------------------------+------------+-------+------------+------------+
2
rows
in
set
(0.00
sec)
看到沒,將增加的birth2欄位,就有一個默認值了,而且這個默認值是我們手工指定的。
關於MySQL中給表添加一個欄位,本文就介紹這么多,希望對大家有所幫助,謝謝!
㈢ 怎麼給表添加欄位MYSql的
給表添加欄位的命令如下:
alter
table
tableName
add
newColumn
varchar(8)
comment
'新添加的欄位'
注意:
1、在這句語句中需要注意的是,comment為注釋,就像在java中//作用是一樣的。
2、comment後需要加單引號將注釋引起來。
㈣ mysql 添加欄位語句
select @num:=count(*) from information_schema.columns where table_schema='庫名' and table_name='表名' and COLUMN_NAME='列名';
if @num <=0 then
alter table 表名 add 新增的欄位名 數據類型定義;
end if;
㈤ MySQL在已存在的表中增加一個新欄位
這樣會默認在表的最後增加一個auth欄位,如果你想在開頭添加,你可以這樣寫:
在中間增加:
語法:
以上,如有紕漏,歡迎指正。
㈥ 怎麼給mysql的表添加欄位
給表添加欄位的命令如下:
alter table tableName add newColumn varchar(8) comment '新添加的欄位'
注意:
1、在這句語句中需要注意的是,comment為注釋,就像在java中//作用是一樣的。
2、comment後需要加單引號將注釋引起來。
㈦ 怎麼給mysql數據表添加欄位
傳統情況
我們先回顧一下,在沒有 "立刻加列" 功能時,加列操作是怎麼完成的。我們也藉此來熟悉一下本期的圖例:
擴展思考題:是否能設計其他的數據格式,取代instant標志位和"列數"欄位,使得 加列/刪列 操作都能 "立刻完成" ?(提示:考慮 加列- 刪列- 再加列 的情況)
使用限制
在了解原理之後,我們來看看"立刻加列"的使用限制,就很容易能理解其中的前兩項:
"立刻加列"的加列位置只能在表的最後,而不能加在其他列之間
在元數據中,只記錄了 數據行 應有多少列,而沒有記錄 這些列 應出現的位置。所以無法實現指定列的位置
"立刻加列"不能添加主鍵列
加列 不能涉及聚簇索引的變更,否則就變成了 "重建" 操作,不是 "立刻" 完成了
"立刻加列"不支持壓縮的表格式
按照 WL 的說法:"COMPRESSED is no need to supported"(沒必要支持不怎麼用的格式)
總結回顧
我們總結一下上面的討論:
"立刻加列" 之所以高效的原因是:
在執行 "立刻加列" 時,不變更數據行的結構
讀取 "舊" 數據時,"偽造"新增的列,使結果正確
寫入 "新" 數據時,使用了新的數據格式(增加了instant 標志位和 "列數" 欄位),以區分新舊數據
讀取 "新" 數據時,可以如實讀取數據
"立刻加列"的 "偽造" 手法,不能一直維持下去。當發生與 "立刻加列" 操作不兼容的 DDL時,表數據就會發生重建
回到之前遺留的兩個問題:
"立刻加列" 是如何工作的 ?
我們已經解答了這個問題
所謂 "立刻加列" 是否完全不影響業務,是否是真正的 "立刻" 完成 ?
可以看到:就算是 "立刻加列",也需要變更 數據字典,那麼 該上的鎖還是逃不掉的。也就是說 這里的 "立刻" 指的是 "不變更數據行的結構",而並非指 "零成本地完成任務"