oracle学习总结3
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的更多相关文章
- Oracle学习笔记三 SQL命令
SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)
- Oracle学习线路
出自huyangg的博客,地址是:oracle学习路线图 1.sql.pl/sql(网上有很多的视频,可以做一个简单的入手,然后看几本书,多做实验) 作为oracle的基本功,需要大家对sql和 ...
- Oracle学习指南
Oracle学习指南 你走的那天,我决定不落泪,迎着风撑着眼帘用力不眨眼 创建数据库.创建用户.创建表空间.创建表.插入数据..... 1.用系统用户登录,任选系统用户 代码: >>sql ...
- Oracle学习系列1-7
Oracle学习系列1 两个服务必须启动: OracleOraDb10g*TNListener 和 OracleService*** 使用sqlplusw先进行环境的设置 set linesize 3 ...
- Oracle学习系列7
Oracle学习系列7 ************************************************************************************ 关联表 ...
- Oracle学习系列6
Oracle学习系列6 ************************************************************************************ 删除约 ...
- Oracle学习系列5
Oracle学习系列5 ************************************************************************************ ,掌握 ...
- Oracle学习系列4
Oracle学习系列4 ************************************************************************************ 数据库 ...
- Oracle学习系列3
Oracle学习系列3 ************************************************************************************ 多表查 ...
- oracle学习笔记(一)用户管理
--oracle学习第一天 --连接 @后面连接数据库实例,具体连接到那个数据库 conn scott/tiger@MYORA1; --修改密码 passw; --显示用户 show user; -- ...
随机推荐
- C#发送简单的HTTP POST请求给传统的ASP网页。
设计思路 创建HTTPWebRequest类的一个实例,设置这个对象的Method属性为"POST",ContentType属性为"application/x-/www- ...
- 单元测试工具之Xunit
在.NET开发中的单元测试工具之——xUnit.Net 原始出处 http://zhoufoxcn.blog.51cto.com/792419/1172320 在上一篇<在.NET开发中的单元 ...
- SQL竖表转横表 / 横表转竖表
竖表转横表 竖表结构: Name Course Grade 张三 语文 75 张三 数学 80 张三 英语 90 李四 语文 95 李四 数学 55 转换后横表结构: Name 语文 数学 英语 张三 ...
- 【转载】解析提高PHP执行效率的50个技巧
1.用单引号代替双引号来包含字符串,这样做会更快一些.因为PHP会在双引号包围的字符串中搜寻变量, 单引号则不会,注意:只有echo能这么做,它是一种可以把多个字符串当作参数的”函数”(译注:PHP手 ...
- 清空具有外键约束的表时报ERROR 1701(42000)的解决办法
ERROR 1701 (42000): Cannot truncate a table referenced in a foreign key constraint (`furion`.`tbl_fr ...
- 如何搭建ss服务器
由于是Red Hat系统,缺少epel包,需要先安装该包才能安装python-pip,命令如下: rpm -iUvh http://dl.fedoraproject.org/pub/epel/7/x8 ...
- [OC Foundation框架 - 12] NSNumber
1.概念 NSArray,NSDictionary只能放OC对象,不能放入基本数据类型 必须使用包装类NSNumber,把基本数据类型包装成OC对象 不支持自动包装解包 void number() ...
- 转载MSDN 在ASP.NET 中执行 URL 重写
转载文章原网址 http://msdn.microsoft.com/zh-cn/library/ms972974.aspx 摘要:介绍如何使用 Microsoft ASP.NET 执行动态 URL 重 ...
- hql查询技巧
要擅于利用对象之间映射的集合去查与其关联的对象,而不是直接在dao层重新写查询的方法,其实,hibernate正是对复杂查询的一种解放,既然有现成的东西,何必再去闭门造车,而且造出来的还是个旧车. 查 ...
- 制作第三方SDK静态库、.framework
静态库和动态库的存在形式 静态库: .a 和 .framework 动态库: .dylib 和 .framework 静态库和动态库的使用区别: 静态库:链接时,静态库会被完整地复制 到 可执行文件中 ...