plsql

plsql左侧窗口列表讲解

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/okhymok/article/details/79267636

 

1,recent objects 你最近访问或是使用过的对象。 就是一个记录,相当于的最近访问的内容列表。     2,recycle bin (1)、回收站启动和关闭 回收站默认是开启的.不过我们可以通过参数recyclebin来关闭和开启. 如果只是针对每个session可以通过alter session set recyclebin=off; 和 alter session set recyclebin=on;来关闭和开启 如果是针对所有session可以通过修改系统参数recyclebin来实现,不过这里要注意10g和11g有点不一样,它们的参数类型不同 10g可以用:alter system set recyclebin=off; 和alter system set recyclebin=on;来关闭和开启 11g可以用:alter system set recyclebin=off deferred; 和alter system set recyclebin=on deferred;来关闭和开启 (2)、查看回收站内容  select * from user_recyclebin;或select * from recyclebin;查看当前用户所drop的对象(里面有对象之前的名字和drop之后的名字) select * from dba_recyclebin;查看所有用户drop掉的对象 其实当一个对象drop后,并且开启了回收站功能.它并没有真正被删除,实际上只是修改了一下名字,我们用select * from user_objects where type= 'TABLE'还能查到.只是它的名字有点怪,例如BIN$qAUuckGyd3TgQKjAFAFTAg==$0,它的命名规范是BIN$unique_id$version  其中BIN代表RecycleBin, unique_id是数据库中该对象的唯一标志,26个字符长度 ,version表示该对象的版本号. (3)、还原回收站内容 假如有表test被drop,drop后的object_name是BIN$qAUuckGyd3TgQKjAFAFTAg==$0 可以用flashback table "BIN$qAUuckGyd3TgQKjAFAFTAg==$0"  to before drop ;(记得名字加双引号) 或者flashback table test  to before drop ;来还原.不过假如drop掉一个表test,再新建一个表test,然后再drop.那么flashback table test  to before drop只能还原最后被drop掉的表test.最先drop掉的表还原时会出错,因为表名不能重名.所以必须改名flashback table test  to before drop rename to test2 (4)、清空回收站 如果一次只清空一个表,可以用PURGE table  test 或PURGE table "BIN$qAUuckGyd3TgQKjAFAFTAg==$0"; 如果一次清空所有的可以用PURGE recyclebin 或者PURGE dba_recyclebin 还原时是只能一次还原一个表,不能像清空一样一次还原所有表 (5)、注意事项 如果表是在system表空间下面则不能使用回收站的功能,不知道为啥有这限制啊 如果表空间快满时系统会自动的去清空回收站中一部分内容,先清空最早drop的对象 3,Functions 函数 不多解释 4,procedures 存储过程,常用,这个刚开始学有点小复杂,其实是很简单的东西 定义:存储过程在Oracle中,可以在数据库中定义子程序,这种程序块称为存储过程 5,Packages oracle包 定义:简化应用设计、提高应用性能、实现信息隐藏、子程序重载。 我讲一下自己用到的东西,由于Oracle存储过程没有返回值,它的所有返回值都是通过out参数来替代的,我们在使用存储过程是,定义两个如下图的出参     下图 调用Packages     过程业务逻辑结束以后,输出   可以看到,它是把游标(可以理解为一个指针),作为一个out 参数来返回值的。   第二种 先create package,在里面声明procedure       然后再package bodies中写实现存储过程,这感觉跟写java类 然后去继承实现以下     6,types 可以自定义数据类型 7,types bodies 通packpages bodies 一个是类型,一个是你类型体 type, 看似简单 实则涉及到高级开发,有兴趣可以专门去研究一下 8,trigger 触发器 trigger和procedure,function类似,只不过它不能被显示调用,只能被某个事件触发然后Oracle自动去调用.常用的一般是针对一个表或视图创建一个trigger,然后对表或视图做某些操作时触发trigger.当然除此之外还有,schema,database级别的trigger     在对t_kh_yg 表进行插入以及修改操作时,改变对应t_kh 表数据的值 9,java sources 可以调用在函数中调用java类       Functions 代码 create or replace function md5encrypt(s varchar2) return varchar2 as language java name 'MD5Util.encrypt(java.lang.String) return java.lang.String'; 如果有这md5加密需求 SELECT  md5encrypt(123456) FROM dual ;  这样用方便了吧! 10,jobs 可以定时执行存储过程       11,Queue 高级队列 高级队列是oracle的一种高级应用,它主要是表和触发器之间的组合而成的一种应用。其主要作用是在各应用系统中进行消息传递。 目的: 利用高级队列来实现消息在两个不同数据库之间的异步传输,满足业务系统的改造需求。 (这个功能我是没有用过) 12,libraries oracle 库 (也没有用过) 百度了,网上资料比较少 13,directonries oracle目录 14,tables 表 不介绍了吧 15,view 视图 视图是基于一个表或多个表或视图的逻辑表,本身不包含数据,通过它可以对表里面的数据进行查询和修改。(不解释) 16,materialized viewOracle高级应用之物化视图(materialized view)(没有实用过) 17,sequence 索引 不解释 18,user 用户表空间 这个自己用就知道了 19,profiles 限制ORACLE用户 20,roles 授予权限或者角色 权限控制 21,synonyms Oracle的同义词(synonyms)从字面上理解就是别名的意思 22,database link 此功能可以在本库中操作其他数据库 23, tablespace 表空间 24,cluster 表簇 这个功能还真的没有用过
上一篇:GridView--scroolview嵌套listview和gridview


下一篇:plsql 连接 虚拟机Linux下的Oracle数据库 失败