mysql新增主键列_Mysql 增加主键或者修改主键的sql语句操作

本文介绍了在MySQL中如何添加、修改和删除主键列的SQL语句,包括添加表字段、修改字段类型、修改字段名称、删除字段、添加唯一键以及调整主键。还提供了一个示例过程来演示如何根据条件动态更新主键,并补充了关于修改主键自增和新增联合主键的内容。
摘要由CSDN通过智能技术生成

添加表字段

alter table table1 add transactor varchar(10) not Null;

alter table table1 add id int unsigned not Null auto_increment primary key

修改某个表的字段类型及指定为空或非空

alter table 表名称 change 字段名称 字段名称 字段类型 [是否允许非空];

alter table 表名称 modify 字段名称 字段类型 [是否允许非空];

alter table 表名称 modify 字段名称 字段类型 [是否允许非空];

修改某个表的字段名称及指定为空或非空

alter table 表名称 change 字段原名称 字段新名称 字段类型 [是否允许非空

删除某一字段

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语句块如下

mailbox 表新增字段

DROP PROCEDURE IF EXISTS mailbox_column_update;

CREATE PROCEDURE mailbox_column_update() BEGIN

-- 新增删除标志列

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,则修改字段长度

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;

-- 如果不存在主键列,则设置双主键

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);

-- 如果只存在一个主键列

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;

补充:mysql 修改主键自增,新增联合主键

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`);

以上为个人经验,希望能给大家一个参考,也希望大家多多支持站圈网。如有错误或未考虑完全的地方,望不吝赐教。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值