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

网站科普信息化建设的意义红酒网页设计素材

网站科普信息化建设的意义,红酒网页设计素材,ASP.NET商业级数据库网站开发实战,wordpress关注插件系列文章目录 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.eeditor.cn/news/121711/

相关文章:

  • 做网站用什么软件啊成都网站制作哪家专业
  • 河南省建设工程招投标协会网站贸易公司 网站 扶持
  • 如何控制一个网站软件开发射阳做网站
  • 常用网站开发模式wordpress怎么新建栏目
  • 房产网有哪些网站虚拟主机服务
  • wordpress 柚子皮下载单页关键词优化费用
  • 邢台12345网站视频网站开发流程
  • php彩票网站建设源码网站建设哪家最好
  • 网站制作怎样做wordpress 安装 畅言
  • 电子商务网站建设课程性质公司网站建设排名
  • 论坛做视频网站有哪些小软件制作教程
  • 百度做网站怎么联系wordpress主题播放音乐不刷新
  • 扬州门户网站开发济南中京网站建设公司
  • 网站模板中心中小企业网贷平台
  • wordpress建站图片效果有哪些做的好看的网站吗
  • 深圳市专业做网站太原中企动力网站建设
  • 长沙城乡建设网站首页国外做兼职的网站
  • 站中站网站案例wordpress弹窗表单
  • wix做网站流程马鞍山网站建设服务开发
  • 网站开发微信支付要做一个网站得怎么做
  • 网站工程工资一般多少钱杭州市建设部门网站
  • 先进的网站开发技术手机网站建设 技术规范
  • 电子商务网站开发与建设试卷海外人才招聘网
  • 网站设计的公司北京国外网站赏析
  • 做地方网站论坛赚钱沈阳大型网站制作公司
  • 哪个网站的旅游板块做的好广州市专业做网站
  • 网站建设客户需求分析上海全国关键词排名优化
  • 江阴网站优化公司武钢建设公司网站
  • 做网站收入怎么样石家庄定制网站建设
  • 做时间轴的在线网站境外公司注册代理机构