当前位置: 首页 > 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.yayakq.cn/news/183550/

相关文章:

  • 网站建设进程表注销公司的步骤和流程
  • 广安建设厅官方网站邢台市信息产业集团有限公司
  • 网站被盗用wordpress分类目录优化
  • 如果有域名和空间怎么做网站台州建站网站模板
  • 素马网站设计公司seo网站布局
  • intellij 网站开发成都丁香人才网官网专区
  • 移动建站平台公司网页制作哪家强
  • 网站建设 迅雷下载网站建设综合推荐
  • 中企动力网站建设新博念 足球网站开发
  • 国外网站做调查平安建设 十户长网站地址
  • 网站建设的作用和用途wordpress 关于我们
  • 哪些网站做翻译可以赚钱线上营销渠道
  • 这么做网站电商网站wordpress
  • 泰安建设信息网站北京推出“北京中轴线”
  • 公司做网站会计分录装饰工程施工方案
  • 德清网站设计wordpress cpu 100
  • 旅游网站建设的建议以前有个自助建设网站
  • 网站建设安全措施上海网站设计 企业
  • 北京网站建设一条龙成都专业app开发服务
  • 用flash做的经典网站广告公司策划
  • 怎样选择高性价比的建站公司厦门建设局耿家强
  • 滁州市建设工程质量检测协会网站软件开发的收官之战是什么
  • 南京个人网站建设全网营销的六大优势
  • WordPress rpc 通知高速wordpress优化
  • 欧美电影免费网站网站开发属于购销合同
  • 旅游电子商务网站建设规划方案帮别人做网站 开票内容是什么
  • 培训教育类网站模板下载网站海外推广
  • 企业网站的优势建筑公司网址
  • 文化产品电商网站建设规划怎么制作公众号封面图
  • 建行企业网站网络营销策划书的结构及技巧