create or replace procedure proc_SALARY(v_EMPCODE varchar2) Is
v_workoingdays salary_detailsworkingdays%type;
v_salary salary_detailssalary%type;
begin
select salary into v_salary from salary_details where EMPCODE = v_EMPCODE;
v_salary = v_salary 095;
dbms_outputput_line(v_salary);
exception
when no_data_found then
dbms_outputput_line('未找到相应员工');
end;
begin
proc_SALARY('1');
end;如下方法Windows XP Vista Win7中安装Oracle客户端1从Oracle官方下载“Instant Client Package”的软件,较好的实现了Oracle客户端绿化的解决方案。 下载地址为:/technology/software/tech/oci/instantclient/htdocs/winsofthtml 可下载的程序包有: 下载程序包: instantclient-basic-win32-1110x0zip (目前有版本: 111060 和 111070) 或 instantclient-basic-win32-1020xzip (目前有版本: 10203 和 10204) 或 instantclient-basic-win32-10105-20060419zip2解压到安装目录,例如:D:\ORA10 下,然后在这个目录下建立network/admin 两层文件夹,然后在admin内建立 tnsnamesora文件, 输入格式如下: ZTRIOA_192168017 =(DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 192168017)(PORT = 1521)) ) (CONNECT_DATA = (SID = ZTRIOA)(SERVER = DEDICATED)) ) 这里根据自己的实际情况进行修改,注意中间的空格问题,如果空格多了或少了都会出现错误的。3配置系统的环境变量 在 Path 变量值最前面写上: D:\ORA10; 并新建变量:变量名为:oracle_home 变量值为:D:\ORA10 4安装 PLSQL Developer 71或其它版本吧。注意安装时不要安装在带“(x86)”的目录内,容易出错。5运行“PLSQL Developer”吧,连接一下试试,正常情况下就可以连接成功了。处理PLSQL Developer连接后出现乱码情况问题描述:使用Oracle绿色版客户端连接到其它Oracle数据库后,查询出来的信息出现乱码情况。解决方法:6打开 PLSQL Developer 安装目录下,看到有PLSQLDevexe的目录, 在PLSQL Developer文件夹内新建“PLSql_runbat”文件,在该文件中输入下面内容:---------------------------------------------------------------------------------------------set nls_lang=SIMPLIFIED CHINESE_CHINAZHS16GBKPLSQLDevexe---------------------------------------------------------------------------------------------7每次启动时请使用"PLSql_runbat"文件进行启动PLSQL Developer工具,否则出现乱码。8结束,祝君好运!运行不成功的检查方法:1连接不成功,请查网络和服务器防火墙之类的。2打开“PLSQL Developer”后,点“取消”,进入到PLSQL Developer软件的 Tools/preferences窗口内,再进入 Oracle/Connection中,修改内容如下: Oracle Home 中输入:D:\ORA10 OCI library 中输入:D:\ORA10\ocidll 再连接的试试吧。/ 下面信息来自网络/方法一---------------------------------------------------------------------------------------------------------我们项目中主要使用Oracle数据库,但每次重装自己的系统之后,都必须安装100多兆Oracle客户端工具,而项目组中多数人需要的仅仅只是用PL/SQL Developer 或TODA之类工具连接Oracle功能而已,既浪费时间又浪费磁盘。今天忽发奇想,有没有办法弄一个绿色版的Oracle出来呢?经过参考网上相关资料及自己的N(N>10)次试验,终于搞出来一个山寨版的Oracle客户端(见附件)。已经做成自解压安装包,下载后把扩展名改为exe然后执行一下,然后用 PL/SQL Developer连接数据库试试,如果连不上,那就重启一下 *** 作系统再试。另外,今天也因这而学到了如何通过注册来配置系统环境变量和用户环境变量,呵呵。今天网上搜到了Oracle官方的解决方案:Oracle官方提供了名为“Instant Client Package”的软件,较好的实现了Oracle客户端绿化的解决方案。首先从:/technology/software/tech/oci/instantclient/htdocs/winsofthtml下载程序包:instantclient-basic-win32-1110x0zip (目前有版本: 111060 和 111070)或instantclient-basic-win32-1020xzip (目前有版本: 10203 和 10204)或instantclient-basic-win32-10105-20060419zip然后解压到一个目录,例如:c:\ora92,然后在这个目录下建立NETWORK文件夹,接着再这个文件夹下再建立ADMIN文件夹,然后在ADMIN内建立tnsnamesora文件,格式如下:yourDataBaseName = (DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = yourhostIp )(PORT = 1521)) ) (CONNECT_DATA = (SERVICE_NAME = yourSID ) ) )例如:# TNSNAMESORA Network Configuration File: C:\oracle\ora90\NETWORK\ADMIN\tnsnamesora# Generated by Oracle configuration toolsXMDS = (DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 1452416181)(PORT = 1521)) ) (CONNECT_DATA = (SERVICE_NAME = XMDS) ) )这里根据自己的实际情况配置。接着打开PL/SQL,在“Tools-->perference”里面设置OCI Library和Oracle_home,我的设置是Oracle_home=c:\orac9iOCI Library=c:\ora9i\ocidll,。上面的配置工作完成后,还需要做一点来解决中文乱码的问题:写一个批处理PLSql_runbat放到Pplsqldeveloper安装目录下,内容如下:set nls_lang=SIMPLIFIED CHINESE_CHINAZHS16GBKPLSQLDevexe这个脚本的作用是告诉PLSqlDev服务器端的字符集,以便于在客户端进行正确处理,如果服务端字符集不是ZHS16GBK,则上面的脚本文件也要相应改动,常用几个中文字符集如下:set nls_lang=simplified chinese_chinazhs16cgb231280 set nls_lang=simplified chinese_chinaZHS16GBK set nls_lang=simplified chinese_chinaUtf8 #########另外,网上有些说法是不同版本的包支持不同的Oracle服务器版本:instantclient-basic-win32-1110x0zip -这个是支持Oracle 9i 以上的版(不包括Oracle9i)instantclient-basic-win32-1020xzip -这个是支持Oracle8i 和Oracle9i 的。但在官网上我还没看到相关说明,我自己也没作测试,如果谁做过测试,不妨告知一下。-----------------------------------------------------------------------------------------方法二1下载Oracle Client Package 从/technology/software/tech/oci/instantclient/htdocs/winsofthtml下载Instant Client Package – Basic包( 标注:All files required to run OCI, OCCI, and JDBC-OCI applications)这里下载的是Version 111072本地保存Oracle Client Package:创建文件夹,比如oracle_client,将下载的文件加压缩到此文件夹里(笔者目录: D:\oracle_client\instantclient_10_2)3在当前目录下,新建立两个文件,sqlnetora和tnsnamesora然后再手动配置sqlnetora和tnsnamesora比如这里是:sqlnetora文件内容:SQLNETAUTHENTICATION_SERVICES= (NTS)NAMESDIRECTORY_PATH= (TNSNAMES, EZCONNECT)tnsnamesora文件内容(斜体表示需要替换的内容):orcl=(DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 1921681103)(PORT = 1521)) ) (CONNECT_DATA = (SERVICE_NAME = orcl) )) 4配置环境变量变量名: TNS_ADMIN变量值: D:\oracle_client\instantclient_10_2否则出现:ORA-12154: TNS:could not resolve the connect identifier specified错误如果之前安装了Oracle 又卸载,会遗留NLS_LANG=NA的键值输入RegEdit打开注册表HKEY_LOCAL_MACHINE/SOFTWARE/ORACLE在右面找到NLS_LANG=NA并删除掉否则会报ORA-12705: Cannot access NLS data files or invalid 错误5安装pl/sql软件(过程略)6配置pl/sql的Oracle连接参数:选择pl/sql的工具/首选项(too/ preference/)里的连接,在右面设置Oracle主目录名(即安装目录)和OCI库Oracle主目录名: D:\oracle_client\instantclient_10_2OCI库: D:\oracle_client\instantclient_10_2\ocidll7登陆pl/sql测试成功方法三-------------------------------------------------------------------------------Windows下Oracle 10G Client安装 1在Oracle官方网站/technology/software/tech/oci/instantclient/htdocs/winsofthtml下载instantclient-basic-win32-10203-20061115zip (34,469,920 bytes) 2解压到C:\oraclient目录下,包括以下几个文件: classes12jar ocijdbc10dll ojdbc14jar oraocci10dll ocidll ociw32dll orannzsbb10dll oraociei10dll 3建立C:\oraclien\network\admin目录,在C:\oraclien\network\admin目录下建立tnsnamesora文件 4在环境参数Path增加C:\oraclien;注意, C:\oraclien;一定要是在Path环境参数的最前面,如果不是,当应用程序连接oracle时将报找不到ocidll的错误 5安装完成 错误:ORA-12705: Cannot access NLS data files or invalid 免安装Oracle客户端使用PL/SQL,TOAD FOR oracle等管理器连接Oracle9i ,10g 众所周知,Oralce的客户端几百兆太大,网上也有许多DIR的处理。这里的处理使用官方提供ORALCE工具包Instant Client Package! 下载地址:/technology/software/tech/oci/instantclient/htdocs/winsofthtml 1:下载这个,Instant Client Package - Basic包。然后解压到任意目录比如:F:\oracleClient ,在这个目录下建立NETWORK文件夹,接着再这个文件夹下再建立ADMIN文件夹,然后服务上已经建立tnsnamesora文件到这个目录,并修改IP; 2:修改环境变量增加Oracle_home=F:\oracleClient;修改Path环境变量增加F:\oracleClient; 3启动PL/SQL,出现ORALCE logon 按取消Calcel,打开PL/SQL-》Perference里面设置OCI Library和Oracle_home, 我的设置是OCI Library=F:\oracleClient \ocidll,Oracle_home=F:\oracleClient 。退出重新登陆。登陆提示如果出现Oracle Instant Client 出现 ORA-12705: Cannot access NLS data files or invalid environment specified 错误。修改如下: 如果是Windows平台,注册表里 \HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE 查找键 NLS_LANG,这个键由Oracle标准客户端安装创建, 值是 NA 。 这个导致了 ORA-12705错误。解决方法就是修改NA为SIMPLIFIED CHINESE_CHINAZHS16GBK。 Linux下 如果环境变量 NLS_LANG 值是NA 会引起 ORA-12705 错误,解决方法是修改set NLS_LANG=SIMPLIFIED CHINESE_CHINAZHS16GBK视图的名称 和 存储过程包体名称别一样 换换试试
还有 函数不能像这样调用啊
你这样调用 只能是用procedure 不能用函数方法 具体你自己调试编译一下吧 编译成功应该就O了。。
create or replace package fs_view_param is
procedure get_value return varchar2;
procedure set_value(ps_time in varchar2);
end fs_view_param;
create or replace package body fs_view_param is
m_v varchar2(6);
procedure set_value(ps_time in varchar2) is
begin
m_v := ps_time;
end;
procedure get_value return varchar2 is
begin
return m_v;
end;
end fs_view_param;这不可能,更新编译package时,需要在这整个包上申请锁,如果是正在运行的package,你可能申请不到这个锁。如果这是一个被频繁调用的package,可能你就完不成这个任务。为了保证一致性,oracle不允许你这么做有些大型项目开发使用的数据库是Oracle,一般来说装服务端对配置要求过高,Oracle客户端无需安装也可使用,解决办法如下:下载一个oracle免安装的客户端版本,下载好后解压如下图所示。安装PL/SQL Developer配置一下首选项里面的路径,如下图所示,即可。选择配置变量,如下图所示,注意一点ORACLE_HOME的值为你下载的文件存放的路径。找到名称为reg-path的文件,打开,配置下注册路径信息,如下图所示。修改instantclient_11_2\NETWORK\ADMIN下的tnsnamesora文件中。对应的ORACLE数据库IP地址和端口。选择运行reg-path,oracle_setup这两个文件,完成注册过程,这样之后就能够正常的使用了。1、10G的Linux版一般都是先安装10201再打补丁升级的,现在最新的补丁是10205。
链接: s/1NGwPcjymjGgs8GdunY0L1A 密码quay
2、Windows的有10204的安装包。
/s/1hqznCsG
3、11G有Linux和Windows的11204安装包。
s/1bnc1ReZ
4、另外10g的dmp导入11g时候,可以用linux命令sed命令修改一下版本就可以
例如sed -i 's/V100201/V110201/g' admp
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)