- 军军小站|张军博客
拥有Oracle标签的文章
Oracle

oracle中sql语句的优化

oracle中sql语句的优化一、执行顺序及优化细则1.表名顺序优化(1)基础表放下面,当两表进行关联时数据量少的表的表名放右边表或视图:Student_info(30000条数据)Description_info(30条数据)select*fromdescription_infodi,student_infosi--学生信息表wheresi.student_id=di.lookup_code(+)anddi.lookup_type(+)='STUDENT

系统 2019-08-12 01:54:30 2177

Oracle

oracle当需要commit

今天oracle的SQLplus运行该删除和查询操作,然后PL/SQL还运行查询。相同的句子,结果是不一样的。我郁闷很大,然后,突然想到这可能对双方造成由数据不一致,为什么不一致呢。就是没用commit,在网上查了一下,大概是这样说的:DML语言,比方update,delete,insert等改动表中数据的须要commit;DDL语言,比方create,drop等改变表结构的。就不须要写commit(由于内部隐藏了commit);DDL数据定义语言:cre

系统 2019-08-12 01:52:45 2177

Oracle

学习Oracle日记(六)

①ORACLE层次查询--(递归语句)--(查询树状结构)select×fromtablestartwithtable.col1='001'--根结点的限定语句,当然可以放宽限定条件,以取得多个根结点,实际就是多棵树。connectbyproircol1=parent_id---上一条语句中的col1=本条记录的parent_id扫描树结构表时,需要依此访问树结构的每个节点,一个节点只能访问一次,其访问的步骤如下:第一步:从根节点开始;第二步:访问该节点;

系统 2019-08-12 01:52:37 2177

Oracle

oracle 分页sql 分段查数据和分段求和 sql语句

自己搞报表,数据量比较海的时候就不能一次性查询出来,要分段才可以,我们采用rownum伪列进行查询,伪列有个特点只能从1开始,想实现x>10andx<20不能按照常规的那种一条sql搞定,必须要双层嵌套才可以的,这个算是个经验吧,同理,求和sum(某列)的时候,如果想查找从第100行到第200行的数据某列之和的时候,你也要嵌套一下,betweenand是不行的...1.最佳oracle分页sql1oracle分页sql分段查数据和分段求和sql语句和jav

系统 2019-08-12 01:52:23 2177

Oracle

Oracle: 使用execute immediate,当列名需要动

Iwritethispostisjusttomakeasummaryofapointmetthisweek.写得不好的话,请园子里的朋友们多提意见。这个星期的工作遇到需要给Pakage加一个function,这个function需要动态组织Sql,以实现不同的logic.Inoracle,weknowthat:EXECUTEIMMEDIATE代替了以前Oracle8i中DBMS_SQLpackage包.它解析并马上执行动态的SQL语句或非运行时创建的PL/

系统 2019-08-12 01:52:16 2177

Oracle

Oracle分析函数手册

Oracle从8.1.6开始提供分析函数,分析函数用于计算基于组的某种聚合值,它和聚合函数的不同之处是对于每个组返回多行,而聚合函数对于每个组只返回一行。下面例子中使用的表来自Oracle自带的HR用户下的表,如果没有安装该用户,可以在SYS用户下运行$ORACLE_HOME/demo/schema/human_resources/hr_main.sql来创建。除本文内容外,你还可参考:ROLLUP与CUBEhttp://xsb.itpub.net/pos

系统 2019-08-12 01:52:10 2177

Oracle

Oracle与DB2数据类型的对应

本文转自:http://www.bitscn.com/oracle/install/200604/16541.html首先,通过下表介绍ORACLE与DB2/400数据类型之间的对应关系,是一对多的关系,具体采用哪种对应关系,应具体问题具体分析。注意事项:DATEandTIMEOracle中的DATE含有年、月、日、时、分、秒,它和DB2/400中的DATE不相互对应,DB2/400中的DATE只有年、月、日,TIME类型含有时、分、秒,因此日期和时间类型

系统 2019-08-12 01:51:27 2177

Oracle

Oracle and Perl installation conflict

今天刚开始学习perl语言,安装了ActivePerl-5.8.8.822-MSWin32-x86-280952.msi,安装后perl是5.8.8,而之前安装的oracle10g的perl版本是5.8.3,所以在运行perldoc-u-fatan2命令时,报错如下:解决方法:1、将oracle10g目录E:\oracle\product\10.2.0\db_1\perl\5.8.3\lib\Pod下的Perldoc.pm和Perldoc.pod替换为5.

系统 2019-08-29 22:37:11 2176

Oracle

Oracle 游标(cursor) 说明

一.Cursor说明Oracle里的cursor分为两种:一种是sharedcursor,一种是sessioncursor。1.1Sharedcursor说明sharedcursor就是指缓存在librarycache(SGA下的SharedPool)里的一种librarycacheobject,说白了就是指缓存在librarycache里的sql和匿名pl/sql。它们是Oracle缓存在librarycache中的几十种librarycacheobje

系统 2019-08-12 09:30:33 2176

Oracle

Oracle客户端工具连接数据库服务器问题汇总

经常遇到PL/SQLDeveloper等依赖Client的工具无法连接Oracle数据库服务器的问题。至今也没完全理清楚,先发个帖总结一下目前的方法,后面会不断完善。方法一:重启Oracle服务器端相关服务,包括...TNSListener,所用的数据库实例的服务。可直接在Windows的“服务”中重启。或者(可使用的命令):lsnrctlstoplsnrctlstartlsnrctlreloadsqlplus/assysdba;startup;这个方法试

系统 2019-08-12 01:55:31 2176

Oracle

oracle pl/sql中创建视图

模式:createorreplaceview视图名as...举例:createorreplaceviewvw_rightpeople(rightpeopletypename,rightpeopletype,rightpeopleid,organizetypeno,parentorganizeno,idno,idtype,rightpeoplename,rightpeopleproperty,chairman,resopertype,resstatus,bi

系统 2019-08-12 01:54:54 2176

Oracle

恢复服务里oracle启动实例项

服务里oracle启动实例项不见了:在CMD命令里oradim-new-sidtest(test是数据库实例名即oracle_sid)用connectsys/bitservice@testassysdba;链接上sqlplus,输入命令startup;服务里oracle启动实例项回来了!其实在CMD命令里输出oradim-new-sidtest,服务里oracle启动实例项已经显示,且显示为已启动,但是链接报错,重启服务后仍然报错。startup后,链接正

系统 2019-08-12 01:54:50 2176

Oracle

Oracle Class6. PL/SQL 简介(数据类型,逻辑比较

------------------------2013-5-14------------------------oracle数据类型Scalar:char(n),nchar(n)varchar2(n)nvarchar2(n)datetimestamprawblob,clobnclob,bfilelong,longrawrowid,urowidCollection:varraytableRelationshiprefPL/SQL代表ProceduralLa

系统 2019-08-12 01:53:40 2176

Oracle

学习Oracle日记(五)

①where子句里面根据传入参数决定使用哪一个条件SQL>select1fromdualwheredecode(1,1,1,0)=1;SQL>select1fromdualwhere(casewhen1=1then1else0end)=1;②排序使用什么排序有三种方式1.使用别名作为排序字段2.使用表达式作为排序字段3.使用字段位置作为排序字段SELECTPCOILS_ID,P.WEIGHT,P.LENGTH,P.WIDTHFROMPRODCOILSPOR

系统 2019-08-12 01:52:38 2176

Oracle

oracle 11g安装客户端后使用ps/sql连接提示TNS

最近由于项目的要求,要使用oracle11gR2数据库,在安装时都没有出什么问题,可以使用sqlplussystem/123连接数据库,但是在安装完之后,使用sqlplussystem/123连接数据库时,提示TNS适配器错误。使用度娘查了一下,答案都是ctrl+C和ctrl+V的,试了之后没有效果,最后看到有人提示修改系统环境变量中数据库目录和客户端目录的位置,小试了一下,奇迹终于出现了。安装oracle客户端后,在环境变量中,客户端的路径C:\app\

系统 2019-08-12 01:32:55 2176