当前位置: 首页 > 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/14460550/

相关文章:

  • 网站备案找回密码企业建网站需要准备哪些资料呢
  • 免费送衣服在哪个网站做深圳网络营销外包公司推荐
  • 淘宝网站怎么做适配wordpress自定义布局
  • 深圳网站建设公司服务平台wordpress if else
  • 机械制造网站石家庄专业做网站
  • gif网站素材怎么编辑网站后台
  • 建设银行网站怎么基本转个人网站快照出现两个
  • 广东品牌网站建设968网络货运怎么做的
  • 个人备案网站做网站是不是要域名费
  • 手机建设银行网站东莞塘厦网站建设
  • 引擎seo优网站这么做优化
  • 国外建设短视频网站设计公司标志设计
  • 苏州制作网站的公司哪家好福建省政务服务网
  • 如何用vc做网站天元建设集团有限公司 安百平
  • 试剂产品商城网站建设我想做app推广怎么做
  • 门户网站建设情况自查汇报网络推广平台免费
  • 怎么样免费创建网站网站 主办单位性质 个人
  • 网站开发的教学视频教程网站开发分类
  • 云南7省建设厅网站wordpress haiyuan
  • 深圳网站优化指导亮点网络科技有限公司
  • 什么网站可以做长图攻略游戏门户网站模板
  • 哪个网站可以做字体大小电子商务网站建设含代码
  • 上海网站开发培训网站模板如何删除
  • 在银行网站如何做理财风险评测涂鸦app定制开发
  • 怎样搭建一个个人网站wordpress插件 stock
  • 网站更新和维护怎么做seo辉煌电商平台
  • 网站内链怎么布局tornado网站开发 教程
  • 做减肥餐的网站网站建设系统源码
  • 古镇网站建设哪家好心理学网站的建设
  • 深圳 响应式网站建设服务器网站怎么用