当前位置: 首页 > news >正文

修改表字段属性,SQL总结

MYSQl

varchar转为mediumtext

ALTER TABLE table_name MODIFY COLUMN column_name mediumtext;

 

ALTER TABLE table_name MODIFY COLUMN column_name varchar(255)

 

1. 修改字段的数据类型

使用 MODIFY COLUMN 可以改变字段的数据类型、长度、默认值或注释,但不会更改字段名称。

ALTER TABLE table_name MODIFY COLUMN column_name new_data_type [constraint];

示例:将 age 字段的数据类型从 INT(4) 修改为 TINYINT(3)

ALTER TABLE employees MODIFY COLUMN age TINYINT(3) NOT NULL COMMENT '年龄';

2. 修改字段的名称及属性

使用 CHANGE COLUMN 可以同时更改字段名称及其属性。

ALTER TABLE table_name CHANGE old_column_name new_column_name new_data_type [constraint];

示例:将 name 字段重命名为 student_name,并将其数据类型改为 VARCHAR(100)

ALTER TABLE students CHANGE name student_name VARCHAR(100) NOT NULL COMMENT '学生姓名';

3. 修改字段的默认值

可以通过 MODIFY COLUMNCHANGE COLUMN 来修改字段的默认值。

ALTER TABLE table_name MODIFY COLUMN column_name data_type DEFAULT default_value;

示例:将 salary 字段的默认值设置为 0

ALTER TABLE employees MODIFY COLUMN salary DECIMAL(10, 2) DEFAULT 0;

4. 添加或删除字段的非空约束

  • 添加非空约束

ALTER TABLE table_name MODIFY COLUMN column_name data_type NOT NULL;

示例:将 name 字段设置为非空。

ALTER TABLE employees MODIFY COLUMN name VARCHAR(50) NOT NULL;

  • 删除非空约束

ALTER TABLE table_name MODIFY COLUMN column_name data_type NULL;

示例:将 name 字段设置为可空。

ALTER TABLE employees MODIFY COLUMN name VARCHAR(50) NULL;

ORACLE

NVARCHAR2 转为NCLOB

  • 新增临时字段为NCLOB
ALTER TABLE COMMON_DATA_AUTOMATIC_CONFIG ADD  TEMP  CLOB;
  • 将需要修改的字段的值设置给临时字段
UPDATE COMMON_DATA_AUTOMATIC_CONFIG SET TEMP = PARAMETERS_VALUE;
  • 删除需要修改的字段
ALTER TABLE COMMON_DATA_AUTOMATIC_CONFIG DROP COLUMN PARAMETERS_VALUE;
  • 修改临时字段的名字为需要修改字段名
ALTER TABLE COMMON_DATA_AUTOMATIC_CONFIG RENAME COLUMN TEMP to PARAMETERS_VALUE;

1. 重命名列

ALTER TABLE table_name RENAME COLUMN old_column_name TO new_column_name;

示例:

ALTER TABLE employees RENAME COLUMN first_name TO given_name;

2. 修改列的数据类型

ALTER TABLE table_name MODIFY (column_name datatype);

示例:

ALTER TABLE employees MODIFY (salary NUMBER(10, 2));

3. 添加新列

ALTER TABLE table_name ADD column_name datatype;

示例:

ALTER TABLE employees ADD bonus NUMBER(10, 2);

4. 删除列

ALTER TABLE table_name DROP COLUMN column_name;

示例:

ALTER TABLE employees DROP COLUMN bonus;

5. 修改列的默认值

ALTER TABLE table_name MODIFY (column_name datatype DEFAULT default_value);

示例:

ALTER TABLE employees MODIFY (hire_date DATE DEFAULT SYSDATE);

6. 修改列的约束

a. 添加约束

ALTER TABLE table_name ADD CONSTRAINT constraint_name condition;

示例:

ALTER TABLE employees ADD CONSTRAINT chk_salary CHECK (salary > 0);

b. 删除约束

ALTER TABLE table_name DROP CONSTRAINT constraint_name;

示例:

ALTER TABLE employees DROP CONSTRAINT chk_salary;

 

KES

varchar转为text

ALTER TABLE common_data_automatic_config MODIFY COLUMN parameters_value  TEXT

1. 修改字段的数据类型

使用 ALTER TABLE 语句修改列的数据类型:

ALTER TABLE table_name MODIFY COLUMN column_name new_data_type;

例如,将 name 列的数据类型从 VARCHAR2(50) 改为 NCLOB

ALTER TABLE example_table MODIFY COLUMN name NCLOB;

2. 修改字段的默认值

使用 ALTER TABLE 语句修改列的默认值:

ALTER TABLE table_name MODIFY COLUMN column_name DEFAULT default_value;

例如,将 salary 列的默认值设置为 0

ALTER TABLE employees MODIFY COLUMN salary DEFAULT 0;

3. 删除字段的默认值

如果需要删除字段的默认值,可以使用以下命令:

ALTER TABLE table_name MODIFY COLUMN column_name DEFAULT NULL;

例如,将 salary 列的默认值设置为 NULL

ALTER TABLE employees MODIFY COLUMN salary DEFAULT NULL;

4. 修改字段的非空约束

添加或删除字段的非空约束:

  • 添加非空约束

ALTER TABLE table_name MODIFY COLUMN column_name NOT NULL;

例如,将 name 列设置为非空:

ALTER TABLE employees MODIFY COLUMN name NOT NULL;

  • 删除非空约束

ALTER TABLE table_name MODIFY COLUMN column_name NULL;

例如,将 name 列设置为可空:

ALTER TABLE employees MODIFY COLUMN name NULL;

5. 重命名字段

使用 RENAME COLUMN 子句重命名字段:

ALTER TABLE table_name RENAME COLUMN old_column_name TO new_column_name;

例如,将 name 列重命名为 full_name

ALTER TABLE employees RENAME COLUMN name TO full_name;

6. 添加新列

使用 ADD 子句添加新的列:

ALTER TABLE table_name ADD column_name data_type [constraint];

例如,添加一个名为 birthdate 的日期列:

ALTER TABLE employees ADD birthdate DATE;

7. 删除列

使用 DROP COLUMN 子句删除列:

ALTER TABLE table_name DROP COLUMN column_name;

例如,删除 address 列:

ALTER TABLE employees DROP COLUMN address;

http://www.lryc.cn/news/512377.html

相关文章:

  • go-xorm连接
  • Excel 面试 04 查找函数 XLOOKUP
  • Flannel和Calico之对比(Comparison between Flannel and Calico)
  • Spring Boot + Redisson 封装分布式锁
  • QWEN2 模型架构配置;GGUF的概念:实现量化存储
  • window如何将powershell以管理员身份添加到右键菜单?(按住Shift键显示)
  • spring中使用@Validated,什么是JSR 303数据校验,spring boot中怎么使用数据校验
  • 实际部署Dify可能遇到的问题:忘记密码、开启HTTPS、知识库文档上传的大小限制和数量限制
  • mugen
  • CannotRetrieveUpdates alert in disconnected OCP 4 cluster解决
  • 计算机网络 (16)数字链路层的几个共同问题
  • 细说STM32F407单片机通过IIC读写EEPROM 24C02
  • 【AimRT】现代机器人通信中间件 AimRT
  • Unity 读Excel,读取xlsx文件解决方案
  • R基于贝叶斯加法回归树BART、MCMC的DLNM分布滞后非线性模型分析母婴PM2.5暴露与出生体重数据及GAM模型对比、关键窗口识别
  • 【信息系统项目管理师】高分论文:论信息系统项目的沟通管理(信息管理服务一体化平台)
  • 物联网工厂可视化监控平台:为智能制造打造的可视化大屏
  • 3、redis的高可用
  • 数据结构--顺序表(详解)
  • Day62 图论part11
  • git clone 超时
  • WPF编程excel表格操作
  • Day10补代码随想录 理论基础|232.用栈实现队列|225.用队列实现栈|20.有效的括号|1047.删除字符串中的所有相邻重复项
  • 【Devops】什么是Devops?(Development+Operations)和运维的区别?
  • 基于NodeMCU的物联网电灯控制系统设计
  • Linux驱动开发 IIC I2C驱动 编写APP访问EEPROM AT24C02
  • Linux应用软件编程-多任务处理(线程)
  • VITUREMEIG | AR眼镜 算力增程
  • Jenkins管理多版本python环境
  • Flutter富文本实现学习