Mysql 增加主鍵或者修改主鍵的sql語(yǔ)句操作
alter table table1 add transactor varchar(10) not Null;alter table table1 add id int unsigned not Null auto_increment primary key修改某個(gè)表的字段類(lèi)型及指定為空或非空
alter table 表名稱(chēng) change 字段名稱(chēng) 字段名稱(chēng) 字段類(lèi)型 [是否允許非空];
alter table 表名稱(chēng) modify 字段名稱(chēng) 字段類(lèi)型 [是否允許非空];
alter table 表名稱(chēng) modify 字段名稱(chēng) 字段類(lèi)型 [是否允許非空];
修改某個(gè)表的字段名稱(chēng)及指定為空或非空alter table 表名稱(chēng) change 字段原名稱(chēng) 字段新名稱(chēng) 字段類(lèi)型 [是否允許非空
刪除某一字段ALTER TABLE mytable DROP 字段 名;添加唯一鍵
ALTER TABLE `test2` ADD UNIQUE ( `userid`)修改主鍵
ALTER TABLE `test2` DROP PRIMARY KEY ,ADD PRIMARY KEY ( `id` )增加索引
ALTER TABLE `test2` ADD INDEX ( `id` )ALTER TABLE `category ` MODIFY COLUMN `id` int(11) NOT NULL AUTO_INCREMENT FIRST ,ADD PRIMARY KEY (`id`);修改主鍵的sql語(yǔ)句塊如下
mailbox 表新增字段
DROP PROCEDURE IF EXISTS mailbox_column_update;CREATE PROCEDURE mailbox_column_update() BEGIN -- 新增刪除標(biāo)志列 IF NOT EXISTS(SELECT 1 FROM information_schema.COLUMNS WHERE TABLE_SCHEMA=’cbs’ AND table_name=’mailbox’ AND COLUMN_NAME=’delete_flag’) THEN ALTER TABLE mailbox ADD delete_flag int DEFAULT 2 NOT NULL; END IF; -- 新增刪除日期列 IF NOT EXISTS(SELECT 1 FROM information_schema.COLUMNS WHERE TABLE_SCHEMA=’cbs’ AND table_name=’mailbox’ AND COLUMN_NAME=’delete_date’) THEN ALTER TABLE mailbox ADD delete_date int DEFAULT 0 NOT NULL; END IF; -- 如果存在字段account_mail,則修改字段長(zhǎng)度 IF EXISTS(SELECT 1 FROM information_schema.COLUMNS WHERE TABLE_SCHEMA=’cbs’ AND table_name=’mailbox’ AND COLUMN_NAME=’email_account’) THEN alter table mailbox modify column email_account varchar(320); END IF; -- 如果不存在主鍵列,則設(shè)置雙主鍵 IF ((SELECT count(*) FROM information_schema.KEY_COLUMN_USAGE WHERE TABLE_SCHEMA =’cbs’ AND table_name=’mailbox’ AND CONSTRAINT_NAME =’PRIMARY’ AND (COLUMN_NAME =’email_account’ OR COLUMN_NAME = ’company_id’))=0)THEN ALTER TABLE mailbox ADD primary key (company_id,email_account); -- 如果只存在一個(gè)主鍵列 ELSEIF ((SELECT count(*) FROM information_schema.KEY_COLUMN_USAGE WHERE TABLE_SCHEMA =’cbs’ AND table_name=’mailbox’ AND CONSTRAINT_NAME =’PRIMARY’ AND (COLUMN_NAME =’email_account’ OR COLUMN_NAME = ’company_id’))<2)THEN ALTER TABLE mailbox DROP PRIMARY KEY,ADD primary key (company_id,email_account); END IF; END;CALL mailbox_column_update();DROP PROCEDURE IF EXISTS mailbox_column_update;
補(bǔ)充:mysql 修改主鍵自增,新增聯(lián)合主鍵
ALTER TABLE `onduty_history`MODIFY COLUMN `id` int(11) NOT NULL AUTO_INCREMENT FIRST ,MODIFY COLUMN `name` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `id`,MODIFY COLUMN `onduty_date` datetime NOT NULL AFTER `name`,ADD UNIQUE KEY (`id`),ADD PRIMARY KEY (`name`, `onduty_date`);
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章:
1. 數(shù)據(jù)庫(kù)相關(guān)的幾個(gè)技能:ACCESS轉(zhuǎn)SQL2. MySQL性能壓力基準(zhǔn)測(cè)試工具sysbench的使用簡(jiǎn)介3. Oracle 11g透明數(shù)據(jù)加密安全特性解析4. MySQL 性能、監(jiān)控與災(zāi)難恢復(fù)5. Mysql故障排除:Starting MySQL. ERROR! Manager of pid-file quit without updating file6. 兩個(gè)有用的oracle數(shù)據(jù)庫(kù)運(yùn)算:intersect和minus運(yùn)算7. mysql innodb的重要組件匯總8. MySQL基礎(chǔ)教程2 —— 數(shù)據(jù)類(lèi)型之日期和時(shí)間類(lèi)型9. 快速刪除ORACLE重復(fù)記錄10. DB2新手使用的一些小筆記:新建實(shí)例、數(shù)據(jù)庫(kù)路徑不存在、客戶(hù)端連接 .
