oracle代码创建表(oracle)

首页常识更新时间:2022-12-27 17:49:41

以前项目主要是用是MySql,现在的项目切换到oracle,在项目组已经几个月了,感觉还是需要系统的学习整理下oracle,主要是整理学习plsql语句,买了本比较畅销的PL/SQL的书籍(oracle pl/sql 从入门到精通),通过对此书的阅读,根据此书的目录结构,对自己感觉需要的知识的做个整理

数据库三范式,这个感觉是很多人都知道的,但是貌似在实际项目中我们经常又不会严格遵守的东西

SQL语言主要有两大类

  1. DML:数据库操作语言,主要用于数据库的增删改查操作
  2. 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_staff increment by 1 --每次加1 start with 1 --开始于1 nomaxvalue --不设置最大值 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_name AS SELECT查询 [WITH READ ONLY CONSTRAINT]

语法解析:

  1. OR REPLACE:如果视图已经存在,则替换旧视图。
  2. FORCE:即使基表不存在,也可以创建该视图,但是该视图不能正常使用,当基表创建成功后,视图才能正常使用。
  3. NOFORCE:如果基表不存在,无法创建视图,该项是默认选项。
  4. 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的,视图分为简单视图和复杂视图,在视图中是可以进行复杂的连表查询的

,
展开阅读全文
推荐内容
热门内容
热门文章

© 2007-2022 http://www.anhuiqq.cn,All Rights Reserved.