oracle(01): 创建表,主键自增长,注解,视图,序列
来源:互联网 发布:海知智能 编辑:程序博客网 时间:2024/06/01 07:54
以前项目主要是用是MySql,现在的项目切换到oracle,在项目组已经几个月了,感觉还是需要系统的学习整理下oracle,主要是整理学习plsql语句,买了本比较畅销的PL/SQL的书籍(oracle pl/sql 从入门到精通),通过对此书的阅读,根据此书的目录结构,对自己感觉需要的知识的做个整理
数据库三范式,这个感觉是很多人都知道的,但是貌似在实际项目中我们经常又不会严格遵守的东西
- 1NF:列不可再分,也就是说字段必须具有单一的属性特征,不可再进行拆分。例如现在我们有一个字段,叫性别,此字段就是不可再进行拆分的字段,就满足第一范式
- 2NF:表要具有唯一的主键列。第二范式要求数据库中每个表中的每行数据都要有唯一的区分标志。在oracle中我们一般用序列,在mysql中有主键自增长的函数实现。
- 3NF:表中不能出现其他表中已经出现的非主键字段。第三范式一般是我们实际开发中经常不会去严格遵守的。在有的时候为了避免复杂的连表查询,我们会在表中写上冗余字段。
SQL语言主要有两大类
- DML:数据库操作语言,主要用于数据库的增删改查操作
- DDL:数据库定义语言,主要用于创建或修改表,定义视图,存储过程等。
其实还有一种叫DCL,数据库控制语言,主要是DB再进行使用,不太了解。
这里说到表和视图,也说下他们的区别,我有很长一段时间其实也并没有搞清楚,简单的说是表是物理上存在的,视图是依赖于表存在的
区别:
1、视图是已经编译好的sql语句。而表不是
2、视图没有实际的物理记录。而表有。
3、表是内容,视图是窗口
4、表只用物理空间而视图不占用物理空间,视图只是逻辑概念的存在,表可以及时四对它进行修改,但视图只能有创建的语句来修改
5、表是内模式,试图是外模式
6、视图是查看数据表的一种方法,可以查询数据表中某些字段构成的数据,只是一些SQL语句的集合。从安全的角度说,视图可以不给用户接触数据表,从而不知道表结构。
7、表属于全局模式中的表,是实表;视图属于局部模式的表,是虚表。
8、视图的建立和删除只影响视图本身,不影响对应的基本表。
联系:视图(view)是在基本表之上建立的表,它的结构(即所定义的列)和内容(即所有数据行)都来自基本表,它依据基本表存在而存在。一个视图可以对应一个基本表,也可以对应多个基本表。视图是基本表的抽象和在逻辑意义上建立的新关系
--创建员工表create table t_staff(id number(20) not null,name varchar2(20),age varchar(10),sex varchar(3));--定义主键alter table t_staff add constraint sf_id primary key(id);--插入注解comment on column t_staff.id is '主键';comment on column t_staff.name is '姓名';comment on column t_staff.age is '年龄';comment on column t_staff.sex is '性别';--创建自增长序列create sequence seq_t_staffincrement by 1 --每次加1start with 1 --开始于1nomaxvalue --不设置最大值minvalue 1--最小值1,可以设置nominvalue 无最小值nocycle --不循环nocache --不缓存--插入数据insert into t_staff(id,name,age,sex) values (seq_t_staff.nextval,'张三','20','男');insert into t_staff(id,name,age,sex) values (seq_t_staff.nextval,'田七','20','女');insert into t_staff(id,name,age,sex) values (seq_t_staff.nextval,'李四','21','男');
正常情况下我们一般是通过sql语句进行查询
select * from t_staff;
我们也可以通过创建一个视图,通过视图进行查询,视图也有视图的好处,列如不把表结构暴露出去等
创建视图的语法
CREATE [OR REPLACE] [{FORCE|NOFORCE}] VIEW view_nameASSELECT查询[WITH READ ONLY CONSTRAINT]
语法解析:
OR REPLACE:如果视图已经存在,则替换旧视图。
FORCE:即使基表不存在,也可以创建该视图,但是该视图不能正常使用,当基表创建成功后,视图才能正常使用。
NOFORCE:如果基表不存在,无法创建视图,该项是默认选项。
WITH READ ONLY:默认可以通过视图对基表执行增删改操作,但是有很多在基表上的限制(比如:基表中某列不能为空,但是该列没有出现在视图中,则不能通过视图执行insert操作),WITH READ ONLY说明视图是只读视图,不能通过该视图进行增删改操作。现实开发中,基本上不通过视图对表中的数据进行增删改操作。
--创建视图create or replace view staff_view as select name,age,sex from t_staff with read only;--查询select * from staff_view;--删除视图drop view staff_view;
这里创建视图的时候我隐藏去了id字段,那么通过视图查询是查询不到id的,视图分为简单视图和复杂视图,在视图中是可以进行复杂的连表查询的
下一节:http://blog.csdn.net/Harry_ZH_Wang/article/details/77826036
- oracle(01): 创建表,主键自增长,注解,视图,序列
- oracle实现自增长序列(主键)
- Oracle创建表和自增长主键
- <四>Oracle创建sequence序列,实现主键自增长
- oracle创建自增长主键
- oracle创建主键自增长
- Oracle创建自增长主键
- oracle创建表并添加主键,设置主键自增长
- oracle使用序列和触发器使表主键自增长
- oracle数据库表用序列实现主键自增长
- oracle实现自增长序列(主键)
- Oracle学习:表的创建与主键自增长
- oracle中创建表主键id依据sequence自增长
- oracle 创建表sql语句,主键,自增长
- oracle中创建表主键id依据sequence自增长
- oracle主键自增长
- oracle 自增长主键
- oracle 自增长主键
- 次小生成树 prim和kruskal
- BeautifulSoup库入门级方法
- bzoj 1634: [Usaco2007 Jan]Protecting the Flowers 护花(贪心排序)
- 背包九讲系列2——混合背包、二维费用背包、分组背包
- [JS] JS递归常见问题
- oracle(01): 创建表,主键自增长,注解,视图,序列
- 中缀表达式转后缀表达式(又称逆波兰式)
- Convert Sorted List to Binary Search Tree
- 清除匿名定时器
- CodeForces 136 A.Presents(水~)
- tensorflow1.3.0安装注意
- StampedLock的简单用法
- 谈谈刚被西数吞并的闪存公司——Tegile System
- java实现二叉树,以及二叉树的遍历和先序和后序求解