MySQL – SQL语句增加字段/修改字段/修改类型/修改默认值[通俗易懂]

MySQL – SQL语句增加字段/修改字段/修改类型/修改默认值[通俗易懂]1.应用场景 有时[比如在Linux服务器下,或者借助数据库管理工具执行SQL],需要使用sql语句直接对数据表进行新建/修改表结构,填充/更新数据等. 好处:可以避免繁琐操作,遗漏,快捷方便,一步到位. 2.学习/操作 20190903新补充 1.添加字段,比如我在数据表中添加一个age字段,类型为int(11…

大家好,又见面了,我是你们的朋友全栈君。

1.应用场景

有时[比如在Linux服务器下]需要使用SQL语句直接对数据表进行新建/修改表结构, 填充/更新数据等.

或借助数据库管理工具执行SQL,但是这种方法,比较适合做微小的操作~

好处:

使用SQL去操作,可以避免繁琐, 遗漏, 快捷方便, 一步到位.

2.学习/操作

前言

1. 本文中有部分SQL没有采用大写,但是推荐关键字使用大写字~~

2. 在应用到生产环境之前,一定要在本地/测试环境做测试,确认无误才可以放到生产环境执行~~

新补充  // 20190903

1. 添加字段,比如我在数据表中添加一个 age 字段,类型为int(11)

ALTER TABLE player ADD (age int(11));

2. 修改字段名,将 age 字段改成player_age

ALTER TABLE player RENAME COLUMN age to player_age

3. 修改字段的数据类型,将player_age的数据类型设置为float(3,1)

ALTER TABLE player MODIFY (player_age float(3,1));

4. 删除字段, 删除刚才添加的player_age字段

ALTER TABLE player DROP COLUMN player_age;

—————————————————————–我是分割线—————————————————————-

1. 修改字段默认值

alter table 表名 drop constraint 约束名字   ——说明:删除表的字段的原有约束

alter table 表名 add constraint 约束名字 DEFAULT 默认值 for 字段名称 ——-说明:添加一个表的字段的约束并指定默认值

2. 修改字段名

语法:// 验证通过

ALTER TABLE <表名> CHANGE <字段名> <字段新名称> <字段的类型>

例子

ALTER TABLE `ue4_map` CHANGE  `levelpath` `filepath` VARCHAR(255);
ALTER TABLE `ue4_blueprint` CHANGE `strObjectPath` `filepath` VARCHAR(255);

Note

ALTER TABLE 表名 RENAME COLUMN A TO B;   // 验证没成功

3. 修改字段类型

ALTER TABLE 表名 ALTER COLUMN UnitPrice DECIMAL(18, 4) NOT NULL

4. 增加字段

ALTER TABLE 表名 ADD 字段 类型 NOT NULL DEFAULT 0

For example 

use kumu;

ALTER TABLE `user`

ADD `sig_livestream_notification` enum(‘0′,’1’) DEFAULT ‘1’ COMMENT ‘1:接收SIG的直播通知’ AFTER `livestream_notification`,

ADD `sig_timeline_like_notification` enum(‘0′,’1’) DEFAULT ‘1’ COMMENT ‘1:接收like 通知’ AFTER `timeline_like_notification`,

ADD `sig_timeline_comment_notification` enum(‘0′,’1’) DEFAULT ‘1’ COMMENT ‘1:接收评论通知’ AFTER `timeline_comment_notification`;

5. 增加 / 删除字段备注

Note

字段已经存在 ==> MODIFY,  不存在 ==> ADD

添加备注

/*oracle*/

comment on column 表名.列名 is ‘备注’;

/*mysql*/

ALTER TABLE 表名 MODIFY 字段名 类型 COMMENT ‘备注’;

删除备注

/*mysql*/

ALTER TABLE 表名 MODIFY  字段名 类型 COMMENT ”;

下面用法:

Alter table `db_jddts_jsmj_1_tdw`.`lg2_hero_baseattr`   — db_jddts_jsmj_1_tdw:数据库名
  add column `num` int(11) NOT NULL Auto_increment first,  — 添加字段,并且处于第一列
  add column `versionTime` varchar(11) NOT NULL after `num`, — 添加字段,处于num后面
  change `heroid` `heroid` int(11) NULL,  — 改变字段类型
  drop primary key, — 删除主键
  add primary key (`num`) — 添加主键

添加主键字段:

alter table `version` ADD  id int(11) not null auto_increment primary key COMMENT ‘主键’ first;

6. 复制表 使用关键字 LIKE   // 20200119

已经有user_login表, 现在要[水平分表]创建100个相同的表, 使用如下即可, 或者通过存储过程[TBD]

CREATE TABLE user_login0 LIKE user_login;
CREATE TABLE user_login1 LIKE user_login;
CREATE TABLE user_login2 LIKE user_login;
CREATE TABLE user_login3 LIKE user_login;
CREATE TABLE user_login4 LIKE user_login;
CREATE TABLE user_login5 LIKE user_login;
CREATE TABLE user_login6 LIKE user_login;
CREATE TABLE user_login7 LIKE user_login;
CREATE TABLE user_login8 LIKE user_login;
CREATE TABLE user_login9 LIKE user_login;
CREATE TABLE user_login10 LIKE user_login;

….

CREATE TABLE user_login99 LIKE user_login;

— 备注:

— 借助上面的序号可以借助Excel实现或者脚本来实现;

执行结果如下:

MySQL - SQL语句增加字段/修改字段/修改类型/修改默认值[通俗易懂]

7. Win10下,查看保存SQL脚本的地方:

可以看到之前保存的sql查询 C:\Users\xinfning\Documents\Navicat\MySQL\Servers   // 公司电脑

C:\Users\william_ning\Documents\Navicat\MySQL\Servers\xxxxx\database_name

Navicat

MySQL - SQL语句增加字段/修改字段/修改类型/修改默认值[通俗易懂]

硬盘

MySQL - SQL语句增加字段/修改字段/修改类型/修改默认值[通俗易懂]

8. 模板参考 —  Sublime 中编辑

— 1.修改test_1表 添加 hascount与note字段

ALTER TABLE test_1 ADD hascount INTEGER NOT NULL Default 0 COMMENT '总编制';

ALTER TABLE test_1 ADD note TEXT COMMENT '备注';

— 2.新增test_2表

DROP TABLE IF EXISTS `test_2`;


CREATE TABLE `test_2`  (
  `id` int(11) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT 'ID',
  `operate_time` varchar(25) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '操作时间',
  `operator_id` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '操作者id',
  `proname` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '项目名',
  `update_field` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '变更字段',
  `update_before` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '变更前',
  `update_after` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '变更后',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 146 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Compact;

— 3.新增test_3表

DROP TABLE IF EXISTS `test_3`;


CREATE TABLE `test_3`  (
  `id` int(11) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '主键id',
  `group_name` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '组名',
  `hascount` int(11) NULL DEFAULT NULL COMMENT '总编制',
  `note` text CHARACTER SET utf8 COLLATE utf8_general_ci NULL COMMENT '备注',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 2 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Compact;

后续补充

3.问题/补充

TBD

4.参考

TBD

后续补充

这里写图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/131644.html原文链接:https://javaforall.net

(0)
上一篇 2022年4月30日 上午7:20
下一篇 2022年4月30日 上午7:40


相关推荐

  • exec.ts 上篇 —— OpenClaw 安全执行 Shell 命令的三层隔离模型

    exec.ts 上篇 —— OpenClaw 安全执行 Shell 命令的三层隔离模型

    2026年3月14日
    2
  • jdk1.7 hashmap扩容_Java并发实现原理:JDK源码剖析

    jdk1.7 hashmap扩容_Java并发实现原理:JDK源码剖析HashMap简介:HashMap在底层数据结构上采用了数组+链表+红黑树,通过散列映射来存储键值对数据因为在查询上使用散列码(通过键生成一个数字作为数组下标,这个数字就是hashcode)所以在查询上的访问速度比较快,HashMap最多允许一对键值对的Key为Null,允许多对键值对的value为Null。它是非线程安全的。在排序上面是无序的。HashMap的主要成员变量…

    2026年2月7日
    5
  • 二进制异或逻辑运算的规则是_异或运算相同为1不同为0

    二进制异或逻辑运算的规则是_异或运算相同为1不同为0用^代表事件相反一、与有0出0;全1出1ABF=AB000010100111二、或有1出1;全0出0ABF=A+B000011101111三、非有1出0;有0出1。AF=^A01

    2022年10月12日
    4
  • 苹果SE(fpga cpld)

    ModelsimSE-6410.4破解安装过程百度云链接:https://pan.baidu.com/s/1ONbjNLajFKzHDJ9bs4gz6Q密码:by0p压缩包解压密码:Lily_9 ①执行软件的正常安装程序.exe,点点我同意神马的….(需要重启一次)②在软件安装目录中找到mgls64.dll文件,右键文件属性取消只读属性。mgls64.dll文件的默认路径…

    2022年4月10日
    43
  • python交互式和文件式区别_Python交互式编程

    python交互式和文件式区别_Python交互式编程Python 之 ipython notebook matplotlib 安装使用交互式编程不需要创建脚本文件 是通过 Python 解释器的交互模式进来编写代码 linux 上你只需要在命令行中输入 Python 命令即可启动交互式编程 Window 上在安装 Python 时已经已经安装了默认的交互式编程客户端备注 中文编码 usr bin python coding UTF 8 以

    2026年3月19日
    2
  • php汉字占几个字节,php一个汉字几个字节

    php汉字占几个字节,php一个汉字几个字节字符的简介 在 js 中 中文占两个字符 英文占一个字符 在 php 中 不同编码下不相同 在 GBK GB2312 编码下一个中文占 2 个字符 UTF 8 unicode 编码下一个中文占 3 个字符 推荐 PHP 教程 php 字节和字符 php 在 UTF 8 编码下 一个汉字占 3 个字节 gbk 编码下只占 2 个字节 z f 字符 字符是可使用多种不同字符方案或代码页来表示的抽象实体 例如 UnicodeUTF 16

    2026年3月19日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号