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

修改表结构

目录

修改表结构

创建数据表插入数据

修改已有列

修改 member 表的 name 列的定义

为表增加列

增加一个 address 列,这个列上不设置默认值

增加一个 sex 列,这个列上设置默认值

删除表中的列

删除 sex 列


 Oracle从入门到总裁:​​​​​​https://blog.csdn.net/weixin_67859959/article/details/135209645

修改表结构

当已经正常建立一张数据表,但后来发现,表出现了少列,或者表列设计不合理,或者表列多了等情况

为此才有了对象的修改操作

但是从开发来说,并不提倡数据表的修改操作

如果要修改数据表,首先需要有一张表

在实际的开发中,为了方便数据库的使用,设计人员往往会给出一个数据库的脚本

这个脚本的后缀一般是“.sql”

开发人员可以利用这个脚本对数据库进行快速恢复

删除原有的数据表

创建新的数据表

创建测试数据

进行事务提交

创建数据表插入数据

-- 删除数据表
drop table member purge;
-- 清空回收站
purge recyclebin;
-- 创建数据表
create table member(mid  number,name  varchar2(20)
);
-- 测试数据
insert into member(mid,name) values(1,'张三');
insert into member(mid,name) values(1,'李四');
-- 提交事务
commit;
SQL> -- 删除数据表
SQL> drop table member purge;表已删除。SQL> -- 清空回收站
SQL> purge recyclebin;回收站已清空。SQL> -- 创建数据表
SQL> create table member(2  mid  number,3      name  varchar2(20)4  );表已创建。SQL> -- 测试数据
SQL> insert into member(mid,name) values(1,'张三');已创建 1 行。SQL> insert into member(mid,name) values(1,'李四');已创建 1 行。SQL> -- 提交事务
SQL> commit;提交完成。

下面就基于这个脚本实现数据表的修改操作

修改已有列

例如,现在在 name 字段上没有设置默认值,这样,当增加的新数据不指定 name 的时候,内容就是 null,所以希望可以有默认值

SQL> insert into member(mid) values(3);已创建 1 行。

修改 member 表的 name 列的定义

SQL> alter table member modify(name varchar2(30) default '无名氏');表已更改。

为表增加列

如果发现表中的列不足,那么就需要为其增加新的列

alter table 表名称 add( 列名称 类型 [default 默认值 ], 列名称 类型 [default 默认值 ],...)

增加一个 address 列,这个列上不设置默认值

SQL> alter table member add(address varchar2(30));表已更改。

上面代码修改数据表 member,增加了一个字段 address

增加一个 sex 列,这个列上设置默认值

SQL> alter table member add(sex varchar2(10) default '男');表已更改。

上面代码修改数据表 member,增加了 sex 字段,同时设置默认值

删除表中的列

任何情况下,删除这种操作都是极其危险的

alter table 表名称 drop column 列名称 ;

删除 sex 列

SQL> alter table member drop column sex;表已更改。

以上的操作,知道就行了,建议尽量不要使用

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

相关文章:

  • Rust 语言中的 into() 方法
  • MinIO权限提升漏洞CVE-2024-24747详细解决办法
  • “我快无聊死了”用英语怎么说?柯桥英语口语学习,成人零基础学外语
  • JS ATM练习案例(复习循环知识)
  • Android 二维码相关(一)
  • 利用tree命令自动保存文件层级结构
  • C++初阶:内存管理
  • vue和react的diff算法源码
  • Coordinate Attention(CVPR 2021)
  • 计算机网络-第4章 网络层(2)
  • 重学SpringBoot3-WebMvcAutoConfiguration类
  • 探索数据结构:深入了解顺序表的奥秘
  • 苍穹外卖学习-----2024/03/010---redis,店铺营业状态设置
  • RUST 每日一省:发布到crates.io
  • String类及其常用方法
  • 1094. 拼车
  • Docker进阶:深入了解容器数据卷
  • 升级版本彻底解决bootstrap-table-fixed-columns固定列后行对不齐问题
  • 打破边界:深入探索STUN在实现无缝NAT穿越和WebRTC通信中的核心作用
  • 浅谈 前端的动态绑定属性
  • Sklearn支持向量机
  • 【Lazy ORM】 小工具 acw 本地客户端 你负责点击页面,他负责输出代码
  • 《详解:鸿蒙NEXT开发核心技术》
  • 快速排序 刷题笔记
  • DAY by DAY 史上最全的Linux常用命令汇总----man
  • 十六、接口隔离原则、反射、依赖注入
  • Docker 进阶
  • 科研学习|论文解读——一种修正评分偏差并精细聚类中心的协同过滤推荐算法
  • 云计算项目十一:构建完整的日志分析平台
  • 2.经典项目-海量用户即使通讯系统