♣ 题目部分 在Oracle中,如何并发地收集统计信息? ♣ 答案部分 对于大表的统计信息收集可以通过DEGREE参数使得扫描大表的时候进行并行扫描,从而加快扫描速度,缩短了收集统计信息的时间。...可以通过以下SQL语句查询数据库是否启用了CONCURRENT收集统计信息,默认为FALSE,表示没有开启并发收集统计信息: SELECT DBMS_STATS.GET_PREFS('CONCURRENT...在大多数情况下,DBMS_STATS程序会给每个对象分配一个JOB;但如果对象(表或者分区)的大小太小,为了节省资源,Oracle会合并多个表和分区在一个JOB中执行。...即使是该用户具有了DBA角色,也还是需要显式授权上述权限。...& 说明: 有关并发地收集统计信息的更多内容可以参考我的BLOG:http://blog.itpub.net/26736162/viewspace-2134312/ 本文选自《Oracle程序员面试笔试宝典
Contracts的设计与实现 Service的设计与实现 Idempotent模式的探索 ClientProxy的设计与实现 服务门面Facade的设计与实现 客户端访问 什么是服务层 服务层位于表示层和业务层之间...,他提供一个接口来定义应用程序的边界以及可供客户端使用的操作,在服务层向客户端描绘的门面后,它将业务逻辑、验证和工作流封装起来并协调业务实体的持久化和和检索工作——《ASP.NET设计模式》 接下来...按开头所说的那样,服务接口位于表示层和业务层之间,它封装了业务领域逻辑,协调事物和响应,并将API定义成一组可供客户端访问的粗粒度方法,构建的解决方案大致如下: 解决方案: ?...如果找到匹配响应则从MessageResponseHistory对象中检索出响应返回给客户端,以确保在客户端重复调用该服务时不会出现预料之外的问题。...Web应用程序只使用这两个类来显示从服务门面获取的数据。
用户与角色是多对多的关系, 一个角色可以被赋予给多个用户,一个用户也可以拥有多个角色; 查询不拥有某角色的所有用户, 如果用leftjoin查询,会造成重复的记录: 举例错误的做法: select...`role_id` is null )防止结果缺失,但会有重复的记录出现!...如果一个用户, 被赋予了角色(id为6ce3c030-a2e0-11e9-8bdc-495ad65d4804) 该用户又被赋予了另一个角色(id为其他值) 那么这个查询中会查出该用户, 违背了我们的需求...and system_user_role.role_id = '6ce3c030-a2e0-11e9-8bdc-495ad65d4804' ); 这个做法用到了not exists子查询 注意:这样的子查询是可以设置与父查询的关联条件的...(where system_user.id = system_user_role.user_id) 这种查询比(not in)查询要快的多!
大多数 Linux 发行版在默认配置下已经足够快了。但是,我们仍然可以借助一些额外的应用程序和方法让它们启动更快一点。其中一个可用的这种应用程序就是 Preload。...简而言之,一旦安装了 Preload,你使用较为频繁的应用程序将可能加载的更快。 在这篇详细的教程中,我们将去了解如何安装和使用 Preload,以改善应用程序在 Linux 中的启动时间。...在 Linux 中使用 Preload 改善应用程序启动时间 Preload 可以在 AUR 上找到。...从现在开始,Preload 将监视频繁使用的应用程序,并将它们的二进制文件和库添加到内存中,以使它的启动速度更快。...你只有在每天都在大量的重新加载应用程序时,才能看到真正的差别。因此,Preload 最适合开发人员和测试人员,他们每天都打开和关闭应用程序好多次。
♣ 题目部分 在Oracle中,如何修改RAC中的主机名? ♣ 答案部分 RAC中的主机名主要有公网对应的主机名、VIP对应的主机名、SCAN对应的主机名和私有主机名。...(一)公网主机名 集群公网对应的主机名是在安装时输入的,并且被记录在OCR中。这个主机名在安装之后是不能修改的。...(二)VIP主机名 集群的VIP对应的主机名是可以被修改的,修改步骤如下所示: 首先停止数据库和相关的VIP资源: srvctl stop db -d lhrac srvctl stop vip -n...修改SCAN的端口号的命令如下所示: srvctl modify scan_listener -p 1522 (四)私有主机名 在11.2 oracle clusterware之前的版本,私有主机名被记录在...但是,在Oracle 11.2 Grid结构中,私有主机名不再被记录在OCR中,并且不存在依赖关系,所以它可以在/etc/hosts文件中任意更改。
♣ 题目部分 在Oracle中,如何获取trace文件的路径?...♣ 答案部分 跟踪文件(Trace File)一般位于“user_dump_dest”参数所指定的目录中,具体路径可以通过以下几种方式查询获得。...T.THREAD#) = V.VALUE)) I, (SELECT VALUE FROM V$PARAMETER WHERE NAME = 'user_dump_dest') D; 创建公共同义词的命令如下所示...: CREATE OR REPLACE PUBLIC SYNONYM SYN_TRACENAME_LHR FOR VW_SQL_TRACE_NAME_LHR; 查询同义词或视图都可以得到当前会话的trace...27 15:05 /oracle/app/oracle/diag/rdbms/lhrdb/lhrdb/trace/lhrdb_ora_19660944.trc & 说明: 有关获取trace文件的更多内容可以参考我的
♣ 题目部分 在Oracle中,如何监控索引的使用状况?...♣ 答案部分 在开发应用程序时,可能会建立很多索引,那么这些索引的使用到底怎么样,是否有些索引一直都没有用到过,在这种情况下就需要对这些索引进行监控,以便确定它们的使用情况,并为是否可以清除它们给出依据...通过一段时间的监控,就可以确定哪些是无用的索引。...,分析索引的使用情况 可以从视图DBA_HIST_SQL_PLAN中获取到数据库中所有索引的扫描次数情况,然后根据扫描次数和开发人员沟通是否需要保留索引。...从图中可以看到有一个3.6G大的索引在13号到22号从没使用过,接下来,可以继续查询该索引是否是联合索引,创建是否合理,分析为何不走该索引,从而判断是否可以删除索引。
在计算机中,一般用IEEE浮点近似表示任意一个实数,那么它实际上又是如何表示的呢? 下面的表达式里,i的值是多少,为什么?如果你不确定答案,那么你应该好好看看本文。...在单精度浮点格式(c语言的float)中,s,exp和frac字段分别为1位,8位和23位,而双精度浮点格式(c语言中的double)中,s,exp和frac字段分别为1位,11位和52位。...它所表示的值分布地接近于0.0,该属性成为逐渐溢出。 情况3:特殊值 有两种 阶码全为1,小数域全为0。...到0.0000004之间的其他数也是不能通过单精度浮点数精确表示的,更不幸地是,这之间的数,甚至只能精确到第6位。...浮点数在内存中的存储 了解了这么多,我们来看一下一个小数究竟是如何在内存中存储的。以float f = 8.5f为例。其二进制表示为 ?
♣ 题目部分 在Oracle中,如何获取用户的权限?...♣ 答案部分 若要获取一个用户的角色、系统权限、对象权限以及列权限,则可以通过以上介绍的数据字典视图来获取也可以通过DBMS_METADATA.GET_GRANTED_DDL来获取。...若使用SYS用户创建了如下的用户LHRSYS并赋予相应的权限: CREATE USER LHRSYS IDENTIFIED BY LHRSYS; GRANT UPDATE (ENAME,SAL) ON...可以直接运行EXEC_SQL列来创建用户并赋予相应的权限。...另外还可以通过exp或expdp来获取用户的权限,这里不再演示。
♣ 题目部分 在Oracle中,如何提高DML语句的效率? ♣ 答案部分 若是批量处理海量数据的话通常都是很复杂及缓慢的,方法也很多,但是通常的概念是:分批删除,逐次提交。...避免在更新的过程中涉及到索引的维护。 ④ 批量更新,每更新一些记录后及时进行提交动作,避免大量占用回滚段和或临时表空间。 ⑤ 可以创建一个临时的大的表空间用来应对这些更新动作。 ⑥ 加大排序缓冲区。...⑦ 如果更新的数据量接近整个表,那么就不应该使用索引而应该采用全表扫描。 ⑧ 如果服务器有多个CPU,那么可以采用PARELLEL Hint,可以大幅度地提高效率。...(例如:外键约束),则选择标准的UPDATE语句,速度最快,稳定性最好,并返回影响条数。...以上这些方法都是抛砖引玉,数据库优化没有最好的方法,只有最合适的方法。
♣ 题目部分 在Oracle中,如何确定坏块的对象名?...,仅仅坏块上的数据无法被查询或读取,其余正常块的数据依旧可以使用。...⑤ 在缺省情况下,存在坏块的数据文件无法成功备份,也会导致自动备份脚本失败。...& 说明: 有关数据块的恢复的内容可以参考我的BLOG:http://blog.itpub.net/26736162/viewspace-2139709/ 有关NOLOGGING引起的坏块的内容可以参考我的...,若有侵权或不当之处还请谅解 ● 版权所有,欢迎分享本文,转载请保留出处 ● QQ:646634621 QQ群:230161599、618766405 ● 微信:lhrbestxh ● 微信公众号:DB
♣ 题目部分 在Oracle中,如何定时清理INACTIVE状态的会话?...♣ 答案部分 一般情况下,少量的INACTVIE会话对数据库并没有什么影响,但是,如果由于程序设计等某些原因导致数据库出现大量的会话长时间处于INACTIVE状态,那么将会导致大量的系统资源被消耗,造成会话数超过系统...直接KILL掉INACTIVE的会话。V$SESSION视图中的LAST_CALL_ET字段表示用户最后一条语句执行完毕后到sysdate的时间,单位为秒。...每次用户执行一个新的语句后,该字段复位为0,重新开始记数。可以通过该字段来获得一个连接用户最后一次操作数据库后的空闲时间。推荐使用这种方法来释放INACTIVE状态的会话。...=> SYSDATE, COMMENTS => '删除--每60分钟检查一次'); END; / & 说明: 有关如何定时清理
♣ 题目部分 在Oracle中,如何预估即将创建索引的大小? ♣ 答案部分 如果当前表大小是1TB,那么在某一列上创建索引的话索引大概占用多大的空间?...利用DBMS_SPACE.CREATE_TABLE_COST可以获得将要创建的表的大小。...说明:USED_BYTES代表实际使用的字节数,而ALLOCATED代表申请的字节数。...第二种办法:Oracle 11g新特性:NOTE RAISED WHEN EXPLAIN PLAN FOR CREATE INDEX 这是一个非常实用的小特性,在Oracle 11gR2中使用EXPLAIN...& 说明: 有关如何预估即将创建索引的大小可以参考我的BLOG:http://blog.itpub.net/26736162/viewspace-1381160/ 本文选自《Oracle程序员面试笔试宝典
♣ 题目部分 在Oracle中,如何得到真实的执行计划?...♣ 答案部分 在Oracle数据库中判断得到的执行计划是否准确,就是看目标SQL是否被真正执行过,真正执行过的SQL所对应的执行计划就是准确的,反之则有可能不准,因此,通过10046事件及如下的几种方式得到的执行计划是最准确的...(特别是在使用了绑定变量的情况下)。...在收集统计信息时,一个与缓存的游标是否失效的很重要的参数为NO_INVALIDATE。在重新收集统计信息时,可以指定NO_INVALIDATE选项。...如果取值为FALSE,那么表示将统计信息对象相关的所有Cursor全部失效,目标SQL语句在下次执行时就会使用硬解析。
♣ 题目部分 在Oracle中,如何获取集群的名称(Cluster name)?...♣ 答案部分 集群名称信息是记录在OCR中的,因此可以通过转储OCR的方法来获得集群名称,另外,也可以使用cemutlo工具直接查看集群名称信息,如下所示: [root@raclhr-11gR2-N1...vendor_info> [root@raclhr-11gR2-N1 ~]# cemutlo -n raclhr-cluster 其实在$CRS_HOME/cdata/CLUSTER_NAME/目录中也可以看到...CLUSTER_NAME,这个目录是用作OCR备份的。
♣ 题目部分 在Oracle中,如何查询RMAN的配置信息? ♣ 答案部分 通过视图V$RMAN_CONFIGURATION可以查询其配置信息或在RMAN中使用SHOW ALL命令查看。...target database control file instead of recovery catalog RMAN configuration parameters for database with db_unique_name
介绍 在部署基于Rails的Web应用程序时,简单设计的应用程序服务器可以在几分钟内启动并运行。...在这篇教程中,我们将介绍如何组装多层部署安装来托管基于Rails的Ruby Web应用程序。对于这种安排,我们将使用在Nginx后台运行的功能强大,灵活且非常成功的Unicorn应用服务器。...Web应用程序部署,服务器及其角色 在部署Web应用程序时,通常涉及多个应用程序,分层设置并相互协作。...在本文中,我们选择的应用服务器是Unicorn。Unicorn是一个卓越的应用服务器,它包含你的Rails应用程序来处理传入的请求,最好是在它们被前端HTTP服务器(如Nginx)过滤和发送之后。...注意:要使用Unicorn简单地测试应用程序,您可以在应用程序目录中运行unicorn_rails。 Nginx 接下来,我们需要告诉Nginx如何与Unicorn交流。
关于Redeye Redeye是一款功能强大的渗透测试数据管理辅助工具,该工具专为渗透测试人员设计和开发,旨在帮助广大渗透测试专家以一种高效的形式管理渗透测试活动中的各种数据信息。...工具概览 服务器端面板将显示所有添加的服务器基础信息,其中包括所有者用户、打开的端口和是否已被入侵: 进入服务器之后,将显示一个编辑面板,你可以在其中添加目标服务器上发现的新用户、安全漏洞和相关的文件数据等...: 用户面板包含了从所有服务器上发现的全部用户,用户信息通过权限等级和类型进行分类,用户的详细信息可以通过将鼠标悬停在用户名上以进行修改: 文件面板将显示当前渗透测试活动中相关的全部文件,团队成员可以上传或下载这些文件...: 攻击向量面板将显示所有已发现的攻击向量,并提供严重性、合理性和安全风险图: 预报告面板中包含了当前渗透测试活动中的所有屏幕截图: 图表面板中包含了渗透测试过程中涉及到的全部用户和服务器,以及它们之间的关系信息...RedeyeVirtualEnv/bin/activate pip3 install -r requirements.txt 最后,执行数据库脚本和工具脚本即可: python3 RedDB/db.py
♣ 题目部分 在Oracle中,如何查看和下载BLOB类型的数据? ♣ 答案部分 BLOB类型的数据存储的是二进制文件,例如pdf、jpg或mp4视频格式文件等。...另外,可以使用以下代码插入BLOB类型的文件到Oracle数据库中: drop table IMAGE_LOB; CREATE TABLE IMAGE_LOB ( T_ID VARCHAR2 (5...SELECT * FROM image_lob;` 可以使用以下代码导出数据库中的BLOB文件: DECLARE l_file utl_file.file_type; --l_lob...,这里导出的文件都是jpg格式的,如果存储的是pdf或其它格式的文件,那么在导出完成后只需要将文件的后缀名修改掉即可,并不会损坏文件。...Oracle中的lob字段采用独立的Lob Segment来存储,因此表的大小不能只查看DBA_SEGMENTS视图,还需要和DBA_LOBS视图结合来查看。
♣ 题目部分 在Oracle中,如何在Windows下查看Oracle的进程?...♣ 答案部分 由于Windows采用的是单进程多线程的模式,因此,Oracle一旦启动,在任务管理器里只能看到一个ORACLE.EXE的进程。...如果想要查看Oracle的各个后台进程(Linux系统下的称谓),例如PMON、SMON、DBWn、LGWR、CKPT等,那么可以通过如下几个步骤实现: ?...这里就可以看见Oracle的进程名称了。 ? 本文选自《Oracle程序员面试笔试宝典》,作者:李华荣。
领取专属 10元无门槛券
手把手带您无忧上云