oracle增删改查基本语法(DDL/DML)整理
DDL:Data Definition Language(数据库定义语言)
DML:Data Manipulation Language(数据库操作语言)
一、表结构操作(create table、alter table、drop table)
1.创建表
create table tableName(
id number(6) not null primary key ,
class_name varchar2(8) default null,
create_date date
);
comment on column tableName.id is 'id'; #字段注释
comment on column tableName.class_name is '类名';
comment on column tableName.create_date is '创建日期';
2.修改表结构
alter table tableName add constraint id primary key; #增加约束,id设置为主键
----------------------------------------------------------------------------
alter table 表名 add constraint 约束名 check(字段名='男' or 字段名='女'); #增加约束,限制列的值(check为限制)
示例1:给表tableName的gender字段增加约束,约束名为con_gender,gender限制为'男'或'女'
alter table tableName add constraint con_gender check(gender='男' or gender='女');
示例2:给表tableName的age字段增加约束,约束名为con_age,age限制为18至60之间'
alter table tableName add constraint con_age check(age>=18 and age<=60)
-----------------------------------------------------------------------------
alter table 表名 modify 字段名及类型 default 默认值; #更改字段类型
示例:把表tb_user的字段username重新定义为number类型,最大长度为7,默认为0
alter table tb_user modify username number(7) default 0;
---------------------------------------------------------------------------------------
alter table 表名 add 列名及字段类型; #增加字段及类型
示例:表tb_user新增一个height字段为number类型,最大长度为3
alter table tb_user add height number(3);
-----------------------------------------------------------------------------------------
alter table 表名 drop column 字段名; #删除字段名
alter table 表名 drop constraint 约束名; #删除约束
alter table 表名 rename column 列名 to 列名 #修改字段名
rename oldTableName to newOldTableName #修改表名
3.删除表
drop table tableName; #删除表,删除的包含表结构定义、表数据,并释放表占用的空间
truncate table tableName; #删除表数据,保留表结构定义及空间
二、表数据操作(inser into、update、delete)
1.插入表数据:insert into
insert into tableName(column1,column2,column3) values(value1,value2,value3);
#表列column1,column2,column3插入值value1,value2,value3
insert into tableName values(value1,value2,value3);
#插入的数据与所有表列对应上时,可省略列名。
insert into newTableName select * from oldTableName;
#把老表中查出的数据插入到新表(新表与旧表表结构完全一致)
insert into newTableName(column1,column2,column3) select value1,value2,value3 from oldTableName;
#把老表中查出的数据插入到新表(新表与旧表表结构可以不一致)
2.修改表数据:update
update tableName set name='Mr Liu' where name='Ms Liu'; #把Mr Liu(刘先生)改成Ms Liu(刘女士)
slect * from tableName for update; #手动修改表数据
slect tb.rowid, tb.* from tableName tb; #手动修改表数据
3.删除表数据:delete from
delete from tableName; #删除表所有数据
delete from tableName tb where tb.name='MrLiu'; #删除名字为MrLiu的数据
三、复制表结构或者表数据
1.复制表数据:
create table newtable as select * from oldtable; #复制旧表结构及数据
insert into newtable select * from oldtable; #已经创建了新表newtable结构,只复制数据
注意:第一种方式只是复制了表结构,但是主键什么的并没有复制进去,所以用的时候要小心在意。
2.复制表结构:
create table newtable as select * from oldtable where 1=2; #只复制完全一样的表结构
3.复制表结构2:
create table newtable as select s.c1, s.c2 from oldtable s; #复制不一样的表结构
oracle增删改查基本语法(DDL/DML)整理的更多相关文章
- Oracle 增删改查
Oracle入门案例: 1.创建实体类Student 并重写ToString方法 package cn.happy.entity; public class Student { public Inte ...
- Java 数据库操作oracle增删改查,通用封装基于hashmap
pt1:首先安装oracle连接驱动 下载地址:https://pan.baidu.com/s/1jW_ofgU4eJmAn7Y2J5B46A 密码:epkz 1.将ojdbc6.jar导入项目中 ...
- oracle增删改查
=======================批量删除,只留前十条数据. delete from THIRD_PARTY_MERCHANT a where a.rowid in ( select ro ...
- Oracle增删改查sql语句
--创建表空间 create tablespace waterboss datafile 'd:\waterboss.dbf' size 100m autoextend on next 10m --创 ...
- mongodb增删改查基础语法
转载:https://blog.csdn.net/u012206617/article/details/91047239 1. use DataBaseName 切换/创建数据库use mydb 2. ...
- ORACLE增删改查以及case when的基本用法
1.创建table create table test01( id int not null primary key, name ) not null, gender ) not null, age ...
- MySQL数据库增删改查SQL语句(2018整理集合大全)
查看数据库 show databases; 使用数据库 use 数据库名; 创建数据库 CREATE DATABASE 数据库名; 删除数据库 DROP DATABASE 数据库名; 创建表 cre ...
- MVC——数据库增删改查(Razor)——Html语法
一.显示界面 .Models(模板) private MyDBDataContext _context = new MyDBDataContext(); public List<Info> ...
- sql server连接oracle并实现增删改查
需要一个软件ODAC112040Xcopy_64bit 我连接的oracle是11g r2 sqlserver 是 2016 软件下载 https://pan.baidu.com/s/1OpYmpR ...
随机推荐
- tiny4412 串口驱动分析九 --- shell终端
作者:彭东林 邮箱:pengdonglin137@163.com 开发板:tiny4412ADK+S700 4GB Flash 主机:Wind7 64位 虚拟机:Vmware+Ubuntu12_04 ...
- PAT Basic 1077 互评成绩计算 (20 分)
在浙大的计算机专业课中,经常有互评分组报告这个环节.一个组上台介绍自己的工作,其他组在台下为其表现评分.最后这个组的互评成绩是这样计算的:所有其他组的评分中,去掉一个最高分和一个最低分,剩下的分数取平 ...
- Ubuntu系统---配置OpenCV
Ubuntu系统---配置OpenCV 目录 一.Ubuntu下配OpenCV 二.Ubuntu下配python-opencv 说明 上述一.二两种方式,配置OpenCV还是有区别的.按个人已有知 ...
- Anaconda配置Python开发环境
Anaconda介绍 Anaconda 是在 linux.windows 和 mac os x 上执行 Python/R 数据分析和机器学习的最简单的方式并且它是开源的.它在全球拥有超过 1, 100 ...
- WPF绑定功能常用属性介绍
1.Mode 绑定中数据流的方向(enum BindingMode) 目标属性指的是控件的属性 (1)TwoWay 更改源属性或目标属性时,会自动更新另一方.适用于可编辑窗体 例:TextBox (2 ...
- java基础:多态过程中的动态绑定
重刷java-core的chapter05,P158 重读多态,感觉又不一样了. 记录一下对象方法执行过程: 1. 编译器查看对象声明类型和方法名,如class.fuction(param),cla ...
- jQuery——jQuery对象与DOM对象
1.jQuery对象与DOM对象的区别 通过jQuery方法包装后的对象,是一个类数组对象.它与DOM对象完全不同,唯一相似的是它们都能操作DOM. 通过jQuery处理DOM的操作,可以让开发者更专 ...
- Lua 学习之基础篇十<Lua 常见的语法规则>
下面讲一些lua 常见的用法和规则,可以为学习理解lua带来帮助,最后附上的部分是lua的基本操作,基本包含所有常用语法语句. 1. if判断 lua把 nil 和false 视为"假&qu ...
- kubectl 自动补全
kubectl 这个命令行工具非常重要,与之相关的命令也很多,我们也记不住那么多的命令,而且也会经常写错,所以命令自动补全是很有必要的,kubectl 工具本身就支持自动补全,只需简单设置一下即可. ...
- VMware WorkStations最小化安装&配置&卸载CentOS 7
所需软件: VMware WorkStations,CentOS 7镜像文件(可以在CentOS官网下载) 1.打开VMware WorkStations,点击创建虚拟机 2.选择典型,点击下一步 3 ...