百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

oracle: 创建表,主键自增长,注解,视图,序列

wptr33 2024-12-03 04:00 11 浏览


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

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

  • 1NF:列不可再分,也就是说字段必须具有单一的属性特征,不可再进行拆分。例如现在我们有一个字段,叫性别,此字段就是不可再进行拆分的字段,就满足第一范式
  • 2NF:表要具有唯一的主键列。第二范式要求数据库中每个表中的每行数据都要有唯一的区分标志。在oracle中我们一般用序列,在mysql中有主键自增长的函数实现。
  • 3NF:表中不能出现其他表中已经出现的非主键字段。第三范式一般是我们实际开发中经常不会去严格遵守的。在有的时候为了避免复杂的连表查询,我们会在表中写上冗余字段。

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的,视图分为简单视图和复杂视图,在视图中是可以进行复杂的连表查询的

相关推荐

为什么劝你不要买Switch OLED?(现在买switch oled划算吗)

那么在聊我们自己的观点前,还是先来看看这款任天堂SwitchOLED款式究竟带来了哪些变化吧。SwitchOLED已经把它最大的特点之一写到了名字里——OLED。这款产品改动最大的地方,就是在维...

新游戏、怀旧机!没有Switch新机的任天堂还能俘虏玩家们的心吗?丨C位

6月16日凌晨,日本电子游戏巨头任天堂在E3游戏展会上举行了发布会。翘首以盼的SwitchPro并未亮相,截止发稿,任天堂股价跌2.44%。但玩家们最为期待的《塞尔达:荒野之息2》将于2022年推出...

腾讯引进Nintendo Switch (OLED版)开启预售 多重满足您的娱乐需求

1月4日,腾讯引进NintendoSwitch(OLED版)开启预售,并将于1月11日正式发售。NintendoSwitch(OLED版)是NintendoSwitch的全新款式,配置色彩艳丽的...

股东大会上任天堂考虑移植更多WiiU和GC游戏到Switch

任天堂股东大会上有任天堂的忠实小股东玩家提议想在Switch玩到WiiU以及GC的经典游戏,对于这个问题,官方给了正面的回应。官方表示目前皮克敏等部分游戏已经可以在switch上玩了,今后会认真考虑玩...

《野狗子》M站均分低至60分!IGN仅给5分、VGC感觉像是PS3游戏

外山圭一郎工作室首部作品《野狗子》全球媒体口碑已解禁,总体评价一般,目前M站均分已降低至60分,21条评价,好评5条,中评14条,差评2条。IGN为其打出5分评价。《野狗子》的特色在于一些有趣的附身交...

《EA SPORTS FC 25》加入任天堂游戏试玩会,Switch版可免费体验

近日,EASPORTS宣布其最新力作《EASPORTSFC25》的Switch版本已正式加入任天堂游戏试玩会。即日起至3月2日,所有NintendoSwitchOnline订阅用户均可限时...

Double Kill!马里奥乐园+Switch能解任天堂焦虑吗?丨C位

近日,“超级任天堂世界”主题乐园在大阪环球影城开园,“超级马里奥之父”宫本茂现身揭幕仪式。任天堂近来喜事连连,2020年财年前九个月实现营收838亿元,贡献最大的Switch销量远超索尼PS5与微...

迷你主机、Switch好搭子:16寸4K超亮QLED CFORCE便携屏值得入手吗

一、迷你主机、Switch好搭子...

怎样查看Switch的“主机序列号信息”

小时候看到游戏机就走不动,现在玩游戏越来越方便了,比如Switch.今天讲讲怎样查看Switch的“主机序列号信息”。第一步:点击【设置】...

Switch版《EA SPORTS FC 25》容量相比前作缩水

备受期待的Switch版足球游戏《EASPORTSFC25》即将发布,根据任天堂官方网站的游戏信息显示,与前作《EASPORTSFC24》相比,游戏容量有所下降。在任天堂官方网站可以查到,...

switch双系统升级注意点(switch双系统升级注意点是什么)

升级系统有风险,建议只有实在想玩的游戏玩不了的时候再升级。1、针对双系统进行,单系统不适用。2、国行系统同pj系统的升级是分开的,互不干涉。国行系统进入后直接升级即可。3、升级之前,建议先做好各类备份...

《鬼泣4:特别版》游戏评测:全家老小齐上阵

游戏名称:鬼泣4:特别版英文名称:DevilMayCry?4SpecialEdition游戏类型:动作游戏ACT制作公司:CAPCOMCo.,Ltd.发行公司:CAPCOMCo.,L...

最好不要在超过35°C的环境温度里玩你的掌机

随着进入“初伏”,天气越发酷热,今年全球高温尤为严重。Valve对此发布了一个安全警告,告诉玩家SteamDeck可以在哪些温度下安全运行。Valve指出,SteamDeck的最佳工作环...

任天堂回应股东玩家 考虑Switch回溯游玩WiiU以及GC游戏

今日有任天堂的忠实小股东玩家提议想在Switch玩到WiiU以及GC的经典游戏,官方回应称正在考虑中,敬请期待。·当然,Switch回溯游玩WiiU以及GC游戏的方式有任天堂的在线服务直接游玩官方优...

Switch 2神秘C键用途曝光!或能连接初代NS手柄

直到近日,游戏圈内的风云人物、知名爆料人extas1s站了出来,带来一则令人颇感意外的消息。extas1s爆料称,玩家有望借助这个神秘的C按钮,实现初代Switch与Switch2...