1:ddl语句
创建一张学生表

create table stu(
id number(6) not null,
name varchar2(20),
age number(3),
gender char(1) default 'm',
grade number(1),
class varchar2(20) constraint stu_class_fk foreign key references class(id),
email varchar2(50)
);

create table class(
id number(4),
name varchar2(30),
constraint class_id_pk primary key(id)
);

default 'm' 该字段默认是m,如果insert语句没有向该字段插入值,那么默认是m

2:约束类型五种:
not null 非空约束,就是在向表中插入数据时,必须给值。
unique 唯一性约束,插入数据时,该字段的值不能够重复
主键 primary key:非空约束,唯一性约束,逻辑上面有意义。
外键 foreign key:参考另外一张表的某个字段(该字段必须是主键),插入数据时,必须在被参考字段数据范围内。
如果被参考字段数据不存在,则插不进去。
被参考字段所在的表不能别删除,在参考表没有被删除前。
check

注:主键概念:能够唯一表示一行记录的字段

3:表级约束和字段级约束

字段级约束,只能作用于一个字段:
create table stu(
id number(6) constraint stu_id_uni unique, --给id字段唯一性约束
name varchar2(20)
);

表级约束,如果是两个字段组合约束:
create table stu(
id number(6),
name varchar2(20),
email varchar2(50),
constraint stu_uni unique(name,email) --给name和email这两个字段组合加约束
);

4:修改表结构 alter
--向表中添加一个字段
alter table stu add (addr varchar2(20));
--修改表中的字段
alter table stu modify (addr varchar2(50));
--删除表中的字段
alter table stu drop (addr);

5:修改表中的约束 constraint
alter table stu drop constraint stu_class_fk; --删除表中的外键约束
alter table stu add constraint stu_class_fk foreign key(class) references class(id);

6:修改表的名字
rename old_name to new_name;

7:oracle,数据字典表,当前用户下的所有表都在dictionary中
select * from dictionary;
只有两个字段:table_name comments

--用户表user_tables,该用户下所有的表都在这个表中
--用户视图user_view
--用户索引user_indexes
--用户约束user_constraint

8:创建索引index
索引可以提高查询效率,但是插入数据时效率降低,因为在插入数据的同时还要插入索引表
在给字段设置主键或者唯一性约束时,索引会自动创建。
create index idx_stu_id on stu(id); --创建索引
drop index idx_stu_id; --删除索引

缺点:
1:不轻易建索引,建大量索引会占用表空间。
2:降低修改数据的效率,插入数据时还要插入索引表。

9:视图view 虚表
概念:就是一张虚表,一条select语句、

create view v$_stu as select * from stu; --创建一张视图
drop view v$_stu; --删除一张视图

优点:
1:方便查询,简化查询。
2:保护表中相关数据不被查看,保护隐私。

不足:
维护成本升高,如果修改原来的表结构,那么视图中的数据也要做相应的修改。
修改视图中的数据,实际上修改的就是原表中的数据。

10:序列
create sequence seq1;
insert into stu values(seq1.nextval,'','');--插入索引,一般给主键添加值

create sequence seq2 start with 1 increment by 1; --从1开始,步长为1

mysql:auto increment;

oracle学习总结3的更多相关文章

  1. Oracle学习笔记三 SQL命令

    SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)  

  2. Oracle学习线路

    出自huyangg的博客,地址是:oracle学习路线图 1.sql.pl/sql(网上有很多的视频,可以做一个简单的入手,然后看几本书,多做实验)    作为oracle的基本功,需要大家对sql和 ...

  3. Oracle学习指南

    Oracle学习指南 你走的那天,我决定不落泪,迎着风撑着眼帘用力不眨眼 创建数据库.创建用户.创建表空间.创建表.插入数据..... 1.用系统用户登录,任选系统用户 代码: >>sql ...

  4. Oracle学习系列1-7

    Oracle学习系列1 两个服务必须启动: OracleOraDb10g*TNListener 和 OracleService*** 使用sqlplusw先进行环境的设置 set linesize 3 ...

  5. Oracle学习系列7

    Oracle学习系列7 ************************************************************************************ 关联表 ...

  6. Oracle学习系列6

    Oracle学习系列6 ************************************************************************************ 删除约 ...

  7. Oracle学习系列5

    Oracle学习系列5 ************************************************************************************ ,掌握 ...

  8. Oracle学习系列4

    Oracle学习系列4 ************************************************************************************ 数据库 ...

  9. Oracle学习系列3

    Oracle学习系列3 ************************************************************************************ 多表查 ...

  10. oracle学习笔记(一)用户管理

    --oracle学习第一天 --连接 @后面连接数据库实例,具体连接到那个数据库 conn scott/tiger@MYORA1; --修改密码 passw; --显示用户 show user; -- ...

随机推荐

  1. HDU4738 Caocao's Bridges 无向图的桥

    一眼题:找所有的桥,然后求最小权值 但是有很多坑点 1:如果本来不联通 输出0,(这个坑我知道) 2:但是还有一个坑,就是当整个连通,最小桥的权值是0时,也必须派一个人去,wa了无数遍(还是太年轻) ...

  2. selenium Webdriver 截图

    在使用Selenium 做自动化时,有的时候希望失败了进行截图,下面提供一个封装的截图方法,方便使用,代码如下: //只需要传入文件名字即可,而这个名字大家可以直接使用测试的方法名 public vo ...

  3. 你知道C/S和B/S两种架构有什么区别吗?

    C/S和B/S,是再普通不过的两种软件架构方式,都可以进行同样的业务处理,甚至也可以用相同的方式实现共同的逻辑.既然如此,为何还要区分彼此呢?那我们就来看看二者的区别和联系. 一.C/S 架构     ...

  4. hdu1150-Machine Schedule(最小点覆盖)

    二分图的最小顶点覆盖:用最少的点,让每条边都至少和其中一个点关联.     最大匹配数 = 最小点覆盖数(Konig 定理) 水题…… 突然发现我以前的匈牙利算法模版有问题……因为这里左边的点时1~n ...

  5. JS实现复制到剪贴板

    <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...

  6. 射频识别技术漫谈(7)——ID卡【worldsing笔记】

    ID(Identification)是识别的意思,ID卡就是识别卡.ID卡包含范围广泛,只要具有识别功能的卡片都可以叫ID卡,例如条码卡,磁卡都可以是ID卡,我们这儿说的当然是射频识别卡. 射频ID卡 ...

  7. Resharp非常实用的快捷键

    Alt+Home  定位到父类.父接口 Alt + End 定位到子类 Ctrl+T     快速在整个解决方案下搜索 类型.方法.文件夹 Alt+Ctrl+Spance  给出提示框 Shift+F ...

  8. VB二进制文件读写

    数组存取 存数组 Private Sub Command2_Click() Dim fileNumber As Integer Dim S9 As String Dim k As Integer Di ...

  9. SQLite使用教程8 Insert 语句

    http://www.runoob.com/sqlite/sqlite-insert.html SQLite Insert 语句 SQLite 的 INSERT INTO 语句用于向数据库的某个表中添 ...

  10. 利用openssl进行BASE64编码解码、md5/sha1摘要、AES/DES3加密解密

    国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html内部邀请码:C8E245J (不写邀请码,没有现金送)国内私 ...