mysql 문법은 개발할때만 필요하기 때문에 항상 까먹는다...
DB운영 같은걸 한다면 안까먹겠지만 개발자이다보니...
배끼는것만 잘하면 장땡
14.2.2 ALTER TABLE
Syntax
ALTER [IGNORE] TABLE tbl_name alter_specification [, alter_specification] ... alter_specification: ADD [COLUMN] column_definition [FIRST | AFTER col_name ] | ADD [COLUMN] (column_definition,...) | ADD INDEX [index_name] [index_type] (index_col_name,...) | ADD [CONSTRAINT [symbol]] PRIMARY KEY [index_type] (index_col_name,...) | ADD [CONSTRAINT [symbol]] UNIQUE [index_name] [index_type] (index_col_name,...) | ADD [FULLTEXT|SPATIAL] [index_name] (index_col_name,...) | ADD [CONSTRAINT [symbol]] FOREIGN KEY [index_name] (index_col_name,...) [reference_definition] | ALTER [COLUMN] col_name {SET DEFAULT literal | DROP DEFAULT} | CHANGE [COLUMN] old_col_name column_definition [FIRST|AFTER col_name] | MODIFY [COLUMN] column_definition [FIRST | AFTER col_name] | DROP [COLUMN] col_name | DROP PRIMARY KEY | DROP INDEX index_name | DROP FOREIGN KEY fk_symbol | DISABLE KEYS | ENABLE KEYS | RENAME [TO] new_tbl_name | ORDER BY col_name | CONVERT TO CHARACTER SET charset_name [COLLATE collation_name] | [DEFAULT] CHARACTER SET charset_name [COLLATE collation_name] | DISCARD TABLESPACE | IMPORT TABLESPACE | table_options
ALTER TABLE
allows you to change the structure of an existing table. For example, you can add or delete columns, create or destroy indexes, change the type of existing columns, or rename columns or the table itself. You can also change the comment for the table and type of the table.
The syntax for many of the allowable alterations is similar to clauses of the CREATE TABLE
statement. See section 14.2.5 CREATE TABLE
Syntax.
If you use ALTER TABLE
to change a column specification but DESCRIBE tbl_name
indicates that your column was not changed, it is possible that MySQL ignored your modification for one of the reasons described in section 14.2.5.1 Silent Column Specification Changes. For example, if you try to change a VARCHAR
column to CHAR
, MySQL will still use VARCHAR
if the table contains other variable-length columns.
ALTER TABLE
works by making a temporary copy of the original table. The alteration is performed on the copy, then the original table is deleted and the new one is renamed. While ALTER TABLE
is executing, the original table is readable by other clients. Updates and writes to the table are stalled until the new table is ready, then are automatically redirected to the new table without any failed updates.
Note that if you use any other option to ALTER TABLE
than RENAME
, MySQL always creates a temporary table, even if the data wouldn't strictly need to be copied (such as when you change the name of a column). We plan to fix this in the future, but because ALTER TABLE
is not a statement that is normally used frequently, this isn't high on our TODO list. For MyISAM
tables, you can speed up the index re-creation operation (which is the slowest part of the alteration process) by setting the myisam_sort_buffer_size
system variable to a high value.
- To use
ALTER TABLE
, you needALTER
,INSERT
, andCREATE
privileges for the table. IGNORE
is a MySQL extension to standard SQL. It controls howALTER TABLE
works if there are duplicates on unique keys in the new table. IfIGNORE
isn't specified, the copy is aborted and rolled back if duplicate-key errors occur. IfIGNORE
is specified, then for rows with duplicates on a unique key, only the first row is used. The others are deleted.- You can issue multiple
ADD
,ALTER
,DROP
, andCHANGE
clauses in a singleALTER TABLE
statement. This is a MySQL extension to standard SQL, which allows only one of each clause perALTER TABLE
statement. For example, to drop multiple columns in a single statement:mysql> ALTER TABLE t2 DROP COLUMN c, DROP COLUMN d;
CHANGE col_name
,DROP col_name
, andDROP INDEX
are MySQL extensions to standard SQL.MODIFY
is an Oracle extension toALTER TABLE
.- The word
COLUMN
is purely optional and can be omitted. - If you use
ALTER TABLE tbl_name RENAME TO new_tbl_name
without any other options, MySQL simply renames any files that correspond to the tabletbl_name
. There is no need to create a temporary table. (You can also use theRENAME TABLE
statement to rename tables. See section 14.2.9RENAME TABLE
Syntax.) column_definition
clauses use the same syntax forADD
andCHANGE
as forCREATE TABLE
. Note that this syntax includes the column name, not just the column type. See section 14.2.5CREATE TABLE
Syntax.- You can rename a column using a
CHANGE old_col_name column_definition
clause. To do so, specify the old and new column names and the type that the column currently has. For example, to rename anINTEGER
column froma
tob
, you can do this:mysql> ALTER TABLE t1 CHANGE a b INTEGER;
If you want to change a column's type but not the name,CHANGE
syntax still requires an old and new column name, even if they are the same. For example:mysql> ALTER TABLE t1 CHANGE b b BIGINT NOT NULL;
However, as of MySQL 3.22.16a, you can also useMODIFY
to change a column's type without renaming it:mysql> ALTER TABLE t1 MODIFY b BIGINT NOT NULL;
- If you use
CHANGE
orMODIFY
to shorten a column for which an index exists on part of the column (for example, if you have an index on the first 10 characters of aVARCHAR
column), you cannot make the column shorter than the number of characters that are indexed. - When you change a column type using
CHANGE
orMODIFY
, MySQL tries to convert existing column values to the new type as well as possible. - In MySQL 3.22 or later, you can use
FIRST
orAFTER col_name
to add a column at a specific position within a table row. The default is to add the column last. From MySQL 4.0.1 on, you can also useFIRST
andAFTER
inCHANGE
orMODIFY
operations. ALTER COLUMN
specifies a new default value for a column or removes the old default value. If the old default is removed and the column can beNULL
, the new default isNULL
. If the column cannot beNULL
, MySQL assigns a default value, as described in section 14.2.5CREATE TABLE
Syntax.DROP INDEX
removes an index. This is a MySQL extension to standard SQL. See section 14.2.7DROP INDEX
Syntax.- If columns are dropped from a table, the columns are also removed from any index of which they are a part. If all columns that make up an index are dropped, the index is dropped as well.
- If a table contains only one column, the column cannot be dropped. If what you intend is to remove the table, use
DROP TABLE
instead. DROP PRIMARY KEY
drops the primary index. (Prior to MySQL 4.1.2, if no primary index exists,DROP PRIMARY KEY
drops the firstUNIQUE
index in the table. MySQL marks the firstUNIQUE
key as thePRIMARY KEY
if noPRIMARY KEY
was specified explicitly.) If you add aUNIQUE INDEX
orPRIMARY KEY
to a table, it is stored before any non-unique index so that MySQL can detect duplicate keys as early as possible.ORDER BY
allows you to create the new table with the rows in a specific order. Note that the table will not remain in this order after inserts and deletes. This option is mainly useful when you know that you are mostly going to query the rows in a certain order; by using this option after big changes to the table, you might be able to get higher performance. In some cases, it might make sorting easier for MySQL if the table is in order by the column that you want to order it by later.- If you use
ALTER TABLE
on aMyISAM
table, all non-unique indexes are created in a separate batch (as forREPAIR TABLE
). This should makeALTER TABLE
much faster when you have many indexes. As of MySQL 4.0, this feature can be activated explicitly.ALTER TABLE ... DISABLE KEYS
tells MySQL to stop updating non-unique indexes for aMyISAM
table.ALTER TABLE ... ENABLE KEYS
then should be used to re-create missing indexes. MySQL does this with a special algorithm that is much faster than inserting keys one by one, so disabling keys before performing bulk insert operations should give a considerable speedup. UsingALTER TABLE ... DISABLE KEYS
will require theINDEX
privilege in addition to the privileges mentioned earlier. - The
FOREIGN KEY
andREFERENCES
clauses are supported by theInnoDB
storage engine, which implementsADD [CONSTRAINT [symbol]] FOREIGN KEY (...) REFERENCES ... (...)
. See section 16.7.4FOREIGN KEY
Constraints. For other storage engines, the clauses are parsed but ignored. TheCHECK
clause is parsed but ignored by all storage engines. See section 14.2.5CREATE TABLE
Syntax. The reason for accepting but ignoring syntax clauses is for compatibility, to make it easier to port code from other SQL servers, and to run applications that create tables with references. See section 1.8.5 MySQL Differences from Standard SQL. - Starting from MySQL 4.0.13,
InnoDB
supports the use ofALTER TABLE
to drop foreign keys:ALTER TABLE yourtablename DROP FOREIGN KEY fk_symbol;
For more information, see section 16.7.4FOREIGN KEY
Constraints. ALTER TABLE
ignores theDATA DIRECTORY
andINDEX DIRECTORY
table options.- From MySQL 4.1.2 on, if you want to change all character columns (
CHAR
,VARCHAR
,TEXT
) to a new character set, use a statement like this:ALTER TABLE tbl_name CONVERT TO CHARACTER SET charset_name;
This is useful, for example, after upgrading from MySQL 4.0.x to 4.1.x. See section 11.10 Upgrading Character Sets from MySQL 4.0. Warning: The preceding operation will convert column values between the character sets. This is not what you want if you have a column in one character set (likelatin1
) but the stored values actually use some other, incompatible character set (likeutf8
). In this case, you have to do the following for each such column:ALTER TABLE t1 CHANGE c1 c1 BLOB; ALTER TABLE t1 CHANGE c1 c1 TEXT CHARACTER SET utf8;
The reason this works is that there is no conversion when you convert to or fromBLOB
columns. To change only the default character set for a table, use this statement:ALTER TABLE tbl_name DEFAULT CHARACTER SET charset_name;
The wordDEFAULT
is optional. The default character set is the character set that is used if you don't specify the character set for a new column you add to a table (for example, withALTER TABLE ... ADD column
). Warning: From MySQL 4.1.2 and up,ALTER TABLE ... DEFAULT CHARACTER SET
andALTER TABLE ... CHARACTER SET
are equivalent and change only the default table character set. In MySQL 4.1 releases before 4.1.2,ALTER TABLE ... DEFAULT CHARACTER SET
changes the default character set, butALTER TABLE ... CHARACTER SET
(withoutDEFAULT
) changes the default character set and also converts all columns to the new character set. - For an
InnoDB
table that is created with its own tablespace in an `.ibd' file, that file can be discarded and imported. To discard the `.ibd' file, use this statement:ALTER TABLE tbl_name DISCARD TABLESPACE;
This deletes the current `.ibd' file, so be sure that you have a backup first. Attempting to access the table while the tablespace file is discarded results in an error. To import the backup `.ibd' file back into the table, copy it into the database directory, then issue this statement:ALTER TABLE tbl_name IMPORT TABLESPACE;
See section 16.7.6 Using Per-Table Tablespaces. - With the
mysql_info()
C API function, you can find out how many records were copied, and (whenIGNORE
is used) how many records were deleted due to duplication of unique key values. See section 21.2.3.30mysql_info()
.
Here are some examples that show uses of ALTER TABLE
. Begin with a table t1
that is created as shown here:
mysql> CREATE TABLE t1 (a INTEGER,b CHAR(10));
To rename the table from t1
to t2
:
mysql> ALTER TABLE t1 RENAME t2;
To change column a
from INTEGER
to TINYINT NOT NULL
(leaving the name the same), and to change column b
from CHAR(10)
to CHAR(20)
as well as renaming it from b
to c
:
mysql> ALTER TABLE t2 MODIFY a TINYINT NOT NULL, CHANGE b c CHAR(20);
To add a new TIMESTAMP
column named d
:
mysql> ALTER TABLE t2 ADD d TIMESTAMP;
To add indexes on column d
and on column a
:
mysql> ALTER TABLE t2 ADD INDEX (d), ADD INDEX (a);
To remove column c
:
mysql> ALTER TABLE t2 DROP COLUMN c;
To add a new AUTO_INCREMENT
integer column named c
:
mysql> ALTER TABLE t2 ADD c INT UNSIGNED NOT NULL AUTO_INCREMENT, -> ADD PRIMARY KEY (c);
Note that we indexed c
(as a PRIMARY KEY
), because AUTO_INCREMENT
columns must be indexed, and also that we declare c
as NOT NULL
, because primary key columns cannot be NULL
.
When you add an AUTO_INCREMENT
column, column values are filled in with sequence numbers for you automatically. For MyISAM
tables, you can set the first sequence number by executing SET INSERT_ID=value
before ALTER TABLE
or by using the AUTO_INCREMENT=value
table option. See section 14.5.3.1 SET
Syntax.
With MyISAM
tables, if you don't change the AUTO_INCREMENT
column, the sequence number will not be affected. If you drop an AUTO_INCREMENT
column and then add another AUTO_INCREMENT
column, the numbers are resequenced beginning with 1.
See section A.7.1 Problems with ALTER TABLE
.
User Comments
IF you want to change a SET or ENUM column you may
not want to use the ALTER TABLE ... MODIFY
syntax.
It tries to keep the actual string values and not
the integer representation of the values, even
though they are stored as integers.
For example, if you just want to make a change in
spelling of the values in your enum column or your
set column, consider doing it like this:
ALTER TABLE table ADD new_column ...;
UPDATE table SET new_column = old_column + 0;
ALTER TABLE table DROP old_column;
You can use Alter Table to optimise a table without locking out selects (only writes), by altering a column to be the same as it's current definition. This is better than using repair table which obtains a read/write lock.
1 row in set (0.00 sec)E.g.
mysql> describe Temp_Table;
mysql> alter table Temp_Table change column ID ID int unsigned;
This will cause mysql to re-create the table and thus remove any deleted space.
This is useful for 24/7 databases where you don't want to completely lock a table.
while adding primary key constraint on null allowable integer column, mysql assigns default value 0 iff one NULL value exists on that column else alter table will fail with error "Duplicate entry '0' for key 1"
If you use ALTER TABLE to add a new column and set a DEFAULT value for the new column, then this value will be assigned to all the existing records.
So if you have a table with 100 records in, then use the following statement:
ALTER TABLE me.my_table
ADD COLUMN new_column INT NOT NULL DEFAULT 0;
then all the existing records will now have the value '0' in this new column 'new_column'.
In other words, you do not need to run the following UPDATE statement:
UPDATE me.my_table SET new_column = 0;
Hope this helps someone!
Mark Sweeting
http://www.sweeting.org/mark/
Add your own comment.