Mysql 增加主键或者修改主键的sql语句操作
作者:橙子AQA 时间:2024-01-20 00:22:02
添加表字段
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`);
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。
来源:https://blog.csdn.net/qq_35211818/article/details/79709657
标签:Mysql,主键,sql
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
Python登录系统界面实现详解
2021-02-11 19:24:04
![](https://img.aspxhome.com/file/2023/5/135415_0s.png)
centos下安装mysql服务器的方法
2024-01-21 06:51:54
讲解MySQL中的事务特性
2024-01-25 19:37:13
selenium与xpath之获取指定位置的元素的实现
2022-01-14 12:02:35
![](https://img.aspxhome.com/file/2023/8/134528_0s.jpg)
python中 * 的用法详解
2023-06-22 20:05:43
AJAX 自学练习 无刷新提交并修改数据库数据并显示
2024-01-18 20:21:23
MySQL多表查询机制
2024-01-25 22:38:33
![](https://img.aspxhome.com/file/2023/3/69843_0s.png)
python网络编程学习笔记(10):webpy框架
2022-07-10 05:43:14
![](https://img.aspxhome.com/file/2023/4/121414_0s.jpg)
vscode中配置jupyter的详细步骤(彻底解决Failed to start the Kernel问题)
2022-06-21 06:56:26
![](https://img.aspxhome.com/file/2023/0/83870_0s.png)
页面软键盘汉字输入
2010-09-01 20:41:00
拿来就用!Python批量合并PDF的示例代码
2021-01-02 15:39:23
![](https://img.aspxhome.com/file/2023/7/78587_0s.jpg)
python网络爬虫selenium打开多窗口与切换页面的实现
2023-10-30 23:50:31
![](https://img.aspxhome.com/file/2023/7/133307_0s.png)
JS实现新建文件夹功能
2024-04-16 09:50:15
![](https://img.aspxhome.com/file/2023/2/136542_0s.gif)
Python实现简单的四则运算计算器
2022-12-29 20:44:08
Python读取环境变量的方法和自定义类分享
2022-11-13 23:47:08
Check In和Check Out的多人协作管理
2007-02-03 11:39:00
Python获取运行目录与当前脚本目录的方法
2023-12-19 13:17:59
设计与表达
2009-07-27 11:45:00
![](https://img.aspxhome.com/file/UploadPic/20097/27/0907_sheji_biaoda_01-84s.jpg)
python 实现朴素贝叶斯算法的示例
2023-12-09 12:59:11
SQL Server 2005 Express版企业管理器下载
2009-10-06 14:54:00