当前位置: 首页 > news >正文

广东佛山今日最新通告东莞网络优化公司

广东佛山今日最新通告,东莞网络优化公司,如何网络推广运营,中天银都建设集团网站1、视图的创建与使用 在所有进行的SQL语句之中,查询是最复杂的操作,而且查询还和具体的开发要求有关,那么在开发过程之中,程序员完成的并不是是和数据库的所有内容,而更多的是应该考虑到程序的设计结构。可以没有一个项…

1、视图的创建与使用
在所有进行的SQL语句之中,查询是最复杂的操作,而且查询还和具体的开发要求有关,那么在开发过程之中,程序员完成的并不是是和数据库的所有内容,而更多的是应该考虑到程序的设计结构。可以没有一个项目里边不会包含有复杂查询,那么程序员如何从复杂查询中解脱出来呢?

所以在这种情况下就提出了视图的概念。利用视图可以实现复杂SQL语句封装操作

所以视图的创建需要使用如下语法完成:

create [or replace] view 视图名称 as 子查询 

1.1 范例1:创建视图

范例1: 创建视图,下面这条语句的作用就是希望将10部门的所有雇员信息保存在视图之中

create view myview as select * from emp where deptno=10;

注意:在Orcale 10g及之前的版本,scott用户是可以直接进行视图创建的,但是从Oracle 10g r2版本开始,如果想要创建视图,那么就需要单独分配创建视图的权限

1.2 范例2:查询视图

select * from myview;

发现查询视图与之前直接使用select查询结果是完全相同的,所以视图就包装了SQL语句,而开发者可以通过视图简单地查询到所需要的数据

于是下面可以继续利用视图包装一个复杂的SQL

drop view myview;
create view myview
    as
select d.deptno,d.dname,d.loc,temp.count
from dept d,(select deptno,count(*) count
             from emp
             group by deptno) temp
where d.deptno=temp.deptno(+);

由于myview视图名称已经被占用了,所以理论上应该先删除,而后再创建一个新的视图。可以是删除和创建之间有可能产生间隔。所以在实际之中,由于视图使用频率较高,而且直接与开发有关系,那么一般情况下不会选择删除后再重新创建,而是选择进行视图的替换。利用新的查询替换掉旧的查询。

create or replace view myview
    as
select d.deptno,d.dname,d.loc,temp.count
from dept d,(select deptno,count(*) count
             from emp
             group by deptno) temp
where d.deptno=temp.deptno(+);

1.3 范例3:更新视图

实际上视图中只是包含有查询语句的临时数据,并不是真是存在的,可以在默认情况下创建的视图是可以直接进行修改操作的

create or replace view myview 
    as 
select * from emp where deptno=20;

更新视图中数据的部门编号(视图的存在条件)

update myview set deptno=30 where empno=7369;

发现此时更新了视图,结果导致emp表中的内容也发生了变化。所以为了保证视图的创建条件不能够被更新,则可以在创建视图的时候使用withcheck option子句

回滚一下 回复以前数据

rollback

接着在之前视图的基础上加上withcheck option 子句

create or replace view myview 
    as 
select * from emp where deptno=20
with check option;

此时使用了withcheck option 子句可以保证视图的创建条件不被更新,如果使用了更新,则将出现如下的错误

1.4 范例4: 修改其他字段

update myview set sal=80000 where empno=7369;

 

此时的操作的成功了,发现视图更新时,改变的是数据表中的数据,那么这样的做法同样也是不合理的。就好比给你发的一张工资条,你不满意,改成了80000,然后数据库的数据就变了,那多神奇啊

所以一般在创建视图的时候,由于里面都属于映射的数据,那么本质上就不建议其进行修改,最好的视图就是创建一个只读视图。使用with read only 子句完成

create or replace view myview 
    as 
select * from emp where deptno=20
with read only;

http://www.mmbaike.com/news/29635.html

相关文章:

  • vs2017 做c 网站自助建站系统
  • 网站备案号怎么看软文推广哪个平台好
  • 怎么判断网站有没有做百度商桥培训报名
  • 北京智联招聘官方网站做家政3322免费域名注册
  • 网站现在一般做多大尺寸北京网站优化托管
  • 专门做qq小工具的网站站长工具之家seo查询
  • 域名跟空间都有了怎么做网站百度最新推广产品
  • 网站项目如何做需求分析在线磁力搜索神器
  • 适合代码新手做的网站无限制搜索引擎排名
  • 企业网站托管注意事项网站推广软件有哪些
  • 怎么用织梦做本地网站公关公司排名
  • 网站常用颜色优化营商环境的意义
  • 婚纱网站策划书seo实战密码第三版
  • 什么网站会更有浏览量开发定制软件公司
  • 做网站最主要是什么河南网站优化公司哪家好
  • 中国开头的网站怎么做营销方案案例
  • 返利导购网站建设需求文档东莞网络推广系统
  • 宁波建设seo优化步骤
  • 张家界工程建设信息网站宁波seo如何做推广平台
  • 合肥专业的房产网站建设seo怎么快速提高排名
  • 网站开发语言有哪些百度快速排名工具
  • 微商招商网站源码打广告的免费软件
  • 广州优化网站建设网络营销讲师
  • 武汉软件开发外包seo词库排行
  • 做搬家广告哪家网站有优百度竞价推广属于什么广告
  • 凤翔做网站合肥今日头条新闻
  • 网站是先解析后备案吗cpa广告联盟
  • wordpress禁止访问模版页面淘宝怎样优化关键词
  • 泉州做网站建设搜索引擎关键词怎么优化
  • 鹤岗北京网站建设深圳最新政策消息