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

网站科普信息化建设的意义营销咨询师招聘

网站科普信息化建设的意义,营销咨询师招聘,企业网站模板源代码,网站开发可选择方案有哪些系列文章目录 Oracle PL/SQL基础语法学习12#xff1a;短路求值 Oracle PL/SQL基础语法学习13#xff1a;比较运算符 Oracle PL/SQL基础语法学习14#xff1a;BOOLEAN表达式 文章目录 系列文章目录前言Oracle PL/SQL基础语法学习15#xff1a;静态表达式Static Expression…系列文章目录 Oracle PL/SQL基础语法学习12短路求值 Oracle PL/SQL基础语法学习13比较运算符 Oracle PL/SQL基础语法学习14BOOLEAN表达式 文章目录 系列文章目录前言Oracle PL/SQL基础语法学习15静态表达式Static Expressions静态表达式介绍静态常量 官方文档Static Constants静态常量代码例关于AUTHID DEFINER 和AUTHID CURRENT_USER 参考连接总结 【免责声明】文章仅供学习交流观点代表个人与任何公司无关。 编辑|SQL和数据库技术(ID:SQLplusDB) 前言 PL/SQL是Oracle数据库中的一种嵌入式语言其功能强大可以进行存储过程和函数的编写帮助开发者快速高效地处理数据库操作。 最好的学习是实践加上看官方文档。官方文档中的代码例更是精华和重点所在。 IT行业如此编程如此Oracle PL/SQL的学习更是如此。 本系列将以《Database PL/SQL Language Reference》的PL/SQL代码例为主线进行介绍。 Oracle PL/SQL基础语法学习15静态表达式 Static Expressions静态表达式介绍 静态表达式是一个在PL/SQL语言中用于描述一个特定值的表达式。 这个表达式在编译时可以确定其值的表达式即它不包括字符比较、变量或函数调用在运行时是不可改变的常常在PL/SQL中用于初始化变量、常量、参数等。 在PL/SQL中静态表达式可以使用常量、字面量、枚举类型等可以使用任意组合来描述目标值。 静态常量 在一个包规范中声明静态常量的语法是 constant_name CONSTANT data_type : static_expression; 静态表达式的类型必须与data_type相同BOOLEAN或PLS_INTEGER。 静态常量必须始终作为package_name.constant_name被引用即使是在package_name包的主体中。 官方文档Static Constants静态常量代码例 CREATE PACKAGE my_debug ISdebug CONSTANT BOOLEAN : TRUE;trace CONSTANT BOOLEAN : TRUE; END my_debug; /CREATE PROCEDURE my_proc1 AUTHID DEFINER IS BEGIN$IF my_debug.debug $THENDBMS_OUTPUT.put_line(Debugging ON);$ELSEDBMS_OUTPUT.put_line(Debugging OFF);$END END my_proc1; /CREATE PROCEDURE my_proc2 AUTHID DEFINER IS BEGIN$IF my_debug.trace $THENDBMS_OUTPUT.put_line(Tracing ON);$ELSEDBMS_OUTPUT.put_line(Tracing OFF);$END END my_proc2; /这段PL/SQL代码创建了一个名为my_debug的包其中包含两个静态常量debug和trace类型为BOOLEAN并在其值上分别定义为TRUE用于控制多个PL/SQL单元中的调试和跟踪。 接着创建了两个存储过程my_proc1和my_proc2它们都具有AUTHID DEFINER权限也就是使用它们的用户必须拥有它们的owner授予的权限。这两个存储过程中都使用了条件编译语句IF/THEN/ELSE/END通过判断my_debug包中的debug和trace常量的值来输出相应的信息。IF指令用于测试编译时常量的值如果值为TRUE则执行THEN指定的代码块否则执行$ELSE指定的代码块。这种条件编译语句通常用于开发和调试过程中在编译时根据一些条件选择性地编译特定的代码块以提高代码的可读性和效率。 过程my_proc1仅使用debug而过程my_proc2仅使用trace但两个过程都依赖于该包。但重新编译的代码可能并不会有所不同。例如如果您只更改debug的值为FALSE然后重新编译这两个过程那么my_proc1的编译代码会改变但my_proc2的编译代码不会改变。 关于AUTHID DEFINER 和AUTHID CURRENT_USER AUTHID参数用于定义执行函数体时使用哪个用户的权限。 AUTHID { CURRENT_USER|DEFINER}当创建具有 AUTHID CURRENT_USER 权限的存储过程、函数或包时其将在调用它的用户的权限上下文中运行。 例 CREATE OR REPLACE PROCEDURE TEST_AUTHID1 AUTHID CURRENT_USER IS BEGINEXECUTE IMMEDIATE select * from table1; END TEST_AUTHID1 ; /该代码创建了名为 TEST_AUTHID 的存储过程该存储过程以当前用户的上下文权限来运行即 AUTHID CURRENT_USER。在存储过程的主体中使用 EXECUTE IMMEDIATE 语句来执行了一个 SQL 查询查询的是名为 table1 的表的所有数据。 由于存储过程是以当前用户的权限来运行的因此只有当前用户具有足够的权限才能执行该查询。如果当前用户没有对表 table1 的访问权限则该查询将失败并抛出异常。 当创建具有 AUTHID DEFINER 权限的存储过程、函数或包时它将以其所属用户创建者的权限上下文中运行。 例 CREATE OR REPLACE PROCEDURE TEST_AUTHID2 AUTHID DEFINER IS BEGINEXECUTE IMMEDIATE select * from table1; END TEST_AUTHID2 ; /该代码创建了名为 TEST_AUTHID2 的存储过程该存储过程以定义者 AUTHID 的权限来运行。在存储过程的主体中使用 EXECUTE IMMEDIATE 语句来执行了一个 SQL 查询查询的是名为 table1 的表的所有数据。 由于该存储过程是以定义者的权限来运行的即创建该存储过程的用户/角色/授权程序的权限上下文中运行。因此只要该定义者具有访问表 table1 的权限无论调用该存储过程的用户具有何种权限该查询都会成功执行。 但是如果定义者在创建存储过程时已经不存在或者权限被撤销则该存储过程无法成功执行。 参考 8.14 Invoker’s Rights and Definer’s Rights (AUTHID Property) Definer’s Rights and Invoker’s Rights (AUTHID clause) 参考连接 Database PL/SQL Language Reference 总结 静态表达式是PL/SQL编程中一个重要的概念它可以用于定义和初始化变量、参数和常量等。常量表达式、字面量表达式和枚举类型表达式是常用的静态表达式类型。AUTHID参数可以用于定义执行函数体时使用哪个用户的权限。
http://www.hkea.cn/news/14371650/

相关文章:

  • 做网站教程下载梧州网站推广外包服务
  • 如何制作网站二维码在浏览器上建设网站
  • 怎样做服装网站手机网站和微信网站的区别
  • 网站开发需求调研有没有电脑做兼职的网站
  • 长春网站推广方式微帮本地推广平台
  • 商业网站建设案例笔记拼多多申请注册店铺
  • 企业网站推广的线上渠道有哪些wordpress文字颜色
  • 邵阳企业网站建设怎么下载文件
  • 网站运营的案例建设部网站申请表无法打印
  • 福永镇网站建设网站建设大公司
  • 建立主题网站的知识点个人网站备案没有座机
  • 中国空间站最新进展东莞搭建网站要多少钱
  • 网页设计素材站做基金的网站哪个好
  • vs和php哪个做网站好南京家装口碑排名前十
  • 大淘客网站怎么做网页服务器价格
  • 南京app网站开发公司大型网站团队人数
  • 如何做企业网站界面好的做网站架构的书
  • 绵阳力嘉信息网站建设公司南宁网站建设电话咨询
  • 网站部兼容是什么原因wordpress 360权重
  • 漯河 网站建设网站建设服务面试题
  • asp网站链接access无锡外贸网站建设
  • 网站在百度的标头不对网络营销项目
  • 男人与女人做视频网站网站开放培训
  • 移动端网站咋做做微信的微网站
  • 山东省建设管理信息网站嘉定公司网站设计
  • 做网站数据分析架构专业做调查的网站
  • 广州网站设计成功刻微信公众号1000阅读量多少钱
  • 乡镇网站建设自查报告长沙网站开发智
  • 推荐大良网站建设做网做网站建设的网站
  • 网站设计什么样风格会高端些域名注册最好的网站