热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

[每日一题]OCP1z0-047:2013-07-29视图??别名

[每日一题]OCP1z0-047:2013-07-29视图??别名好,接下来我们来做测试,先登录到oe用户,查相关的表。[html]gyj@OCM>connoe/oeConnected.oe@OCM>selecttable_namefromtabs;TABLE_NAME----...
[每日一题]OCP1z0-047 :2013-07-29视图??别名
 

 
好,接下来我们来做测试,先登录到oe用户,查相关的表。
 
[html
gyj@OCM> conn oe/oe  
Connected.  
oe@OCM> select table_name from tabs;  
  
TABLE_NAME  
------------------------------  
PRODUCT_REF_LIST_NESTEDTAB  
SUBCATEGORY_REF_LIST_NESTEDTAB  
PROMOTIONS  
ORDERS  
PRODUCT_DESCRIPTIONS  
WAREHOUSES  
PRODUCT_INFORMATION  
ORDER_ITEMS  
CUSTOMERS  
INVENTORIES  
  
10 rows selected.  
 
一、答案A,很明显是错的,视图的字段与表的字段的个数不一样,操作如下报错:
 
 
[html] 
oe@OCM> CREATE OR REPLACE VIEW ord_vu(order_id,order_date)   
  2  AS SELECT o.order_id,o.order_date,COUNT(i.line_item_id) "NO OF ITEMS" FROM orders o JOIN order_items i ON(o.order_id=i.order_id)  
  3  GROUP BY o.order_id,o.order_date;  
CREATE OR REPLACE VIEW ord_vu(order_id,order_date)  
                              *  
ERROR at line 1:  
ORA-01730: invalid number of column names specified  
  
在CREATE OR REPLACE VIEW ord_vu(order_id,order_date,ct)添加一列CT,操作如下就没问题:  
  
oe@OCM> CREATE OR REPLACE VIEW ord_vu(order_id,order_date,ct)   
  2  AS SELECT o.order_id,o.order_date,COUNT(i.line_item_id) "NO OF ITEMS" FROM orders o JOIN order_items i ON(o.order_id=i.order_id)  
  3  GROUP BY o.order_id,o.order_date;  
  
View created.  
 
 
二、答案B是正确的,把视图定义的列名去掉,视图默认这些列名来自select中的显示的列,操作如下:
 
[html] 
oe@OCM> CREATE OR REPLACE VIEW ord_vu   
  2  AS SELECT o.order_id,o.order_date,COUNT(i.line_item_id) "NO OF ITEMS" FROM orders o JOIN order_items i ON(o.order_id=i.order_id)  
  3  GROUP BY o.order_id,o.order_date;  
  
View created.  
  
oe@OCM> select * from ord_vu;  
  
  ORDER_ID ORDER_DATE                                                                  NO OF ITEMS  
---------- --------------------------------------------------------------------------- -----------  
      2354 15-JUL-08 08.18.23.234567 AM                                                         13  
      2361 14-NOV-07 05.34.21.986210 AM                                                          9  
      2363 24-OCT-07 07.49.56.346122 AM                                                          9  
      2367 28-JUN-08 11.53.32.335522 AM                                                          8  
省略结果。。。。。。。。。。。。。。。  
 
 
 
三、答案C是错的,在创建视图时,对这种使用各种函数,或运算表达式的列,一定要起别名,如没有别名视图创建就会失败,操作如下:
 
 
[html] 
oe@OCM> CREATE OR REPLACE VIEW ord_vu   
  2  AS SELECT o.order_id,o.order_date,COUNT(i.line_item_id) FROM orders o JOIN order_items i ON(o.order_id=i.order_id)  
  3  GROUP BY o.order_id,o.order_date;  
AS SELECT o.order_id,o.order_date,COUNT(i.line_item_id) FROM orders o JOIN order_items i ON(o.order_id=i.order_id)  
                                  *  
ERROR at line 2:  
ORA-00998: must name this expression with a column alias  
  
把上面的视图改成如下:  
oe@OCM> CREATE OR REPLACE VIEW ord_vu   
  2  AS SELECT o.order_id,o.order_date,COUNT(i.line_item_id)  CT FROM orders o JOIN order_items i ON(o.order_id=i.order_id)  
  3  GROUP BY o.order_id,o.order_date;  
  
View created.  
 
 
四、答案D也是错的,错误与答案C一个问题
 
 
[html] 
oe@OCM> CREATE OR REPLACE VIEW ord_vu   
  2  AS SELECT o.order_id,o.order_date,COUNT(i.line_item_id)||'NO OF ITEMS' FROM orders o JOIN order_items i ON(o.order_id=i.order_id)  
  3  GROUP BY o.order_id,o.order_date  
  4  WITH CHECK OPTION;  
AS SELECT o.order_id,o.order_date,COUNT(i.line_item_id)||'NO OF ITEMS' FROM orders o JOIN order_items i ON(o.order_id=i.order_id)  
                                                        *  
ERROR at line 2:  
ORA-00998: must name this expression with a column alias  
  
 把上面的视图改成如下:  
oe@OCM> CREATE OR REPLACE VIEW ord_vu   
  2  AS SELECT o.order_id,o.order_date,COUNT(i.line_item_id)||'NO OF ITEMS' CT FROM orders o JOIN order_items i ON(o.order_id=i.order_id)  
  3  GROUP BY o.order_id,o.order_date  
  4  WITH CHECK OPTION;  
  
View created.  
 
 
正确答案:B
 
结总:
在创建视图时,对这种使用各种函数,或运算表达式的列,一定要起别名,如没有别名视图创建就会失败。
定义视图的列名可以省略,来自SELECT定义中的列名,如果定义视图的列名不省略,那个列的个数与SELECT定义中的列的个数要一致。
 

推荐阅读
  • H5技术实现经典游戏《贪吃蛇》
    本文将分享一个使用HTML5技术实现的经典小游戏——《贪吃蛇》。通过H5技术,我们将探讨如何构建这款游戏的两种主要玩法:积分闯关和无尽模式。 ... [详细]
  • 在尝试加载支持推送通知的iOS应用程序的Ad Hoc构建时,遇到了‘no valid aps-environment entitlement found for application’的错误提示。本文将探讨此错误的原因及多种可能的解决方案。 ... [详细]
  • 在1995年,Simon Plouffe 发现了一种特殊的求和方法来表示某些常数。两年后,Bailey 和 Borwein 在他们的论文中发表了这一发现,这种方法被命名为 Bailey-Borwein-Plouffe (BBP) 公式。该问题要求计算圆周率 π 的第 n 个十六进制数字。 ... [详细]
  • 长期从事ABAP开发工作的专业人士,在面对行业新趋势时,往往需要重新审视自己的发展方向。本文探讨了几位资深专家对ABAP未来走向的看法,以及开发者应如何调整技能以适应新的技术环境。 ... [详细]
  • 本文探讨了如何通过优化 DOM 操作来提升 JavaScript 的性能,包括使用 `createElement` 函数、动画元素、理解重绘事件及处理鼠标滚动事件等关键主题。 ... [详细]
  • 本文介绍了SIP(Session Initiation Protocol,会话发起协议)的基本概念、功能、消息格式及其实现机制。SIP是一种在IP网络上用于建立、管理和终止多媒体通信会话的应用层协议。 ... [详细]
  • 二维码的实现与应用
    本文介绍了二维码的基本概念、分类及其优缺点,并详细描述了如何使用Java编程语言结合第三方库(如ZXing和qrcode.jar)来实现二维码的生成与解析。 ... [详细]
  • 问题描述现在,不管开发一个多大的系统(至少我现在的部门是这样的),都会带一个日志功能;在实际开发过程中 ... [详细]
  • 本文详细探讨了Linux系统中的文件权限设置,包括常见的755、700等权限模式,以及这些权限在实际应用中的具体含义和作用。 ... [详细]
  • 一、Advice执行顺序二、Advice在同一个Aspect中三、Advice在不同的Aspect中一、Advice执行顺序如果多个Advice和同一个JointPoint连接& ... [详细]
  • 知识图谱与图神经网络在金融科技中的应用探讨
    本文详细介绍了融慧金科AI Lab负责人张凯博士在2020爱分析·中国人工智能高峰论坛上的演讲,探讨了知识图谱与图神经网络模型如何在金融科技领域发挥重要作用。 ... [详细]
  • CRZ.im:一款极简的网址缩短服务及其安装指南
    本文介绍了一款名为CRZ.im的极简网址缩短服务,该服务采用PHP和SQLite开发,体积小巧,约10KB。本文还提供了详细的安装步骤,包括环境配置、域名解析及Nginx伪静态设置。 ... [详细]
  • 华为与红帽联手,加速开源电信软件革新
    华为与红帽携手合作,旨在加速开源电信软件的发展,以满足大型电信运营商对灵活网络解决方案的需求。 ... [详细]
  • Irish budget airline Ryanair announced plans to significantly increase its route network from Frankfurt Airport, marking a direct challenge to Lufthansa, Germany's leading carrier. ... [详细]
  • 本文深入探讨了Go语言中的接口型函数,通过实例分析其灵活性和强大功能,帮助开发者更好地理解和运用这一特性。 ... [详细]
author-avatar
he2134
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有