一、oracle监听启动后,立即停止。

      TNS-12545: 因目标主机或对象不存在,连接失败。
      TNS-12560: TNS: 协议适配器错误。
      TNS-00515: 因目标主机或对象不存在,连接失败。
      32-bit Windows Error: 1004: Unknown error。
      不再监听: (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(PIPENAME=//./pipe/EXTPROC0ipc)))。
      原因是我安装了oracle之后,又修改了主机名。
      解决方法:
      1.直接修改listener.ora
      路径是: oracle安装目录/product/10.2.0/db_1/NETWORK/ADMIN/listener.ora.
      修改HOST 为主机名或者IP.
      2.通过 Net Manager,在 监听程序/LISTENER 下直接修改主机即可
    ORA-12514 TNS 监听程序当前无法识别连接描述符中请求服务的解决方法
    出现情况:
    第一天正确安装oracle11G及完成配置PL/SQL,正确运行生产环境。夜间计算机关机,第二天重新启机,无法正常运行生产环境,提示ORA-12514错误。检查PL/SQL连接也提示ORA-12514错误。
    解决问题:
    1、检查oracle启动服务项
    点击计算机右键,选择“管理”,如下图:
    或者运行services.msc
    image.png
    到“服务和应用程序”下点击“服务”项,双击其进入,如下图:
    4075.png
    启动所有关于oracle的服务项,如下图:
    4074.png
    重新连接PL/SQL,依旧报错ORA-12514。
    2、考虑监听文件是否正确配置
    到oracle11g安装目录下,找到监听文件“listener.ora”。
    4072.png
    打开“listener.ora”文件,添加或修改SID_NAME名称为数据库实例名,如下图:
    或者直接在SID_LIST下添加个SID_DESC的组
    (SID_DESC =
    (SID_NAME = orcl)—orcl是数据库实例名
    (ORACLE_HOME = D:\app\Administrator\product\11.2.0\dbhome_1) —oracle_home是数据库安装路径
    )
    4077.png
    3、重启数据库服务器
    启动数据库,检查状态,如下图:
    4076.png
    至此,重新连接PL/SQL恢复正常,重新运行生产环境,恢复正常。
    总结:
    出现ORA-12514问题,一般为数据库监听相关设置出现问题,解决思路如下:
    1、重启oracle相关“服务”,重新进行连接尝试,若未解决进行下一步;
    2、正确设置listener.ora文件,添加相应的实例名,重启数据库服务器,检查各项服务是否启动,尝试连接,若仍未解决进行下一步;
    3、对oracle客户端的Net Cofiguration Assistant正确添加或重新配置实例名,重启数据库服务器,检查各服务项是否启动,尝试连接(由于作者进行前两部后问题解决,因此此步未做详细介绍,可查阅网络其它资料)。


    二.错误码及解决办法

      1.ORA:-12545:因目标主机和对象不存在,连接失败。
      错误代码ORA-12545表示网络连接串(即tnsnames.ora文件中的HOST处)中使用的机器名和IP地址不存在,重新修改和重新连接即可。
      2.ORA-12651:TNS:没有监听器。
      该信息说明所要连接的服务器没有启动监听进程Listener(该进程为Oracle服务器上操作系统进程,监听进程没有启动时,服务器可以正常进行,但是客户端不能与服务器产生连接。这时可以在服务器使用操作系统命令lsnrctl正常起启动监听进程)。
      3.ORA-00600:internal error code,arguments:[num],[?],[?],[?],[?] 。
      产生原因:这种错误通常为ORACLE的内部错误,只对OSS和ORACLE开发有用。ORA-600的错误经常伴随跟踪文件的状态转储(系统状态和进程状态),系统状态存储将包括ORACLE RDBMS持有的当前对象的信息,进程状态转储则将显示特殊进程持有的对象,当进程符合了某错误条件时,经常是由于一些信息取自它持有的一个块,如果我们知道这些错误进程持有的块,就容易跟踪问题的来源。

      解决方法:一般来说出现这个错误我们本身是无法解决的,只有从提高系统本身各方面来解决这个内部问题,如增加硬件设备,调整系统性能,使用OPS(当然OPS从某种意义上说并不是一种好的解决方式)等。ORA-600错误的第一个变量用于标记代码中错误的位置(代码中的每个部分的第一变量都不一样),从第二个到第五个变量显示附加信息,告诉OSS代码在哪里出现了错误

      4.ORA-12560 协议适配器错误:
      有关ORA-12560: TNS:协议适配器错误的问题
      ①.检查Terminal Service, 远程桌面是不是起因。
      ②.环境变量set oracle_sid=需要的服务名。
      ③.listener.ora, tnsnames.ora等内机器名或者IP地址是否正确。
      ④.netstat –a检查端口是否被占用。
      ⑤.检查注册表HKEY_LOCAL_MACHINE/Software/Oracle/Home0新增字符串USE_SHARED_SOCKET=TRUE, 重新启动服务。
      5.ORA-28595: Invalid DLL Path 调用外部DLL出错
      原因:A setting in Oracle’s LISTENER.ORA file on the server hosting the RDBMS is missing.

      解决办法:
      (1).Locate the active LISTENER.ORA file on the server. By default, it will be on the Oracle RDBMS drive in the path ../ora92/network/admin.
      (2).Inspect the file and locate all entries associated with “SID_DESC”. Each such entry should have the following option associated with it:(ENVS = “EXTPROC_DLLS=ANY”)
      (3).Add the above line to any entry where it is missing.
      (4).Restart the Oracle Listener Service (or reboot the server which will in turn restart Oracle).
      例子:

      The example LISTENER.ORA file below shows a valid configuration for the server named “WOODY” (using TCP/IP on Port 1521) with the correct ENVS entries highlighted:
      # LISTENER.ORA Network Configuration File: C:/oracle/ora92/network/admin/listener.ora
      # Generated by Oracle configuration tools.
      LISTENER = (DESCRIPTION_LIST = (DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC0)) ) (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = woody)(PORT = 1521)) ) ) ) SID_LIST_LISTENER = (SID_LIST = (SID_DESC = (SID_NAME = PLSExtProc) (ORACLE_HOME = C:/oracle/ora92) (PROGRAM = extproc) (ENVS = “EXTPROC_DLLS=ANY”) ) (SID_DESC = (GLOBAL_DBNAME = WOODY) (ORACLE_HOME = C:/oracle/ora92) (SID_NAME = WOODY) (ENVS = “EXTPROC_DLLS=ANY”) ) )

      6.在控制面板中启动服务,出现以下错误:

      服务:在本地计算机无法启动OracleOraDb10g_home1TNSListener 服务。
      错误3:系统找不到指定的路径。
      查看属性发现,OracleOraDb10g_home1TNSListener 服务的可执行文件的路径为空。
      解决办法:

      开始—>运行REGEDIT —>进入注册表找到HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/OracleOraDb10g_home1TNSListener
      发现ImagePath关键值没有了,新建一个名为ImagePath的可扩充字符串值,编辑字符串的数值数据为:Oracle安装路径/BIN/TNSLSNR

      7.错误描述:本地计算机上的OracleOraDb10g_home1TNSListener服务启动后又停止了。一些服务自动停止,如果它们没有什么可做的,例如 “性能日志和警报 “服务。
      解决办法:C:/oracle/product/10.2.0/db_1/NETWORK/ADMIN/listener.ora把这这文件里的内容改下 HOST=你的计算机名字。

    监听问题
    错误一:注册表使用了优化软件被删除了相关项。
    错误二:网络环境发生改变。(如:计算机名称改变)
    关于NOT IN的查询
    如果在使用IN操作符,查询的范围中存在了null,不影响查询,如果使用的是NOT IN操作符,如果查询范围之中有了null,则不会有任何查询结果返回。
    触发器问题
    1.触发器不接受参数
    2.一个表最多可有12个触发器,同一时间,同一事件,同一类型的触发器只能有一个
    3.在触发器执行部分只能执行DML语句
    截取字段长度
    substr设置负数,表示从末尾开始截取
    数字函数
    Round(列,保留的位数)四舍五入操作
    Trunc(列,保留的位数)舍弃指定位置
    Mod(数字1,数字2)取模,取余数
    AS和IS的区别
    在存储过程(PROCEDURE)和函数(FUNCTION)中没有区别;
    在视图(VIEW)中只能用AS不能用IS;
    在游标(CURSOR)中只能用IS不能用AS。
    Oracle存储过程
    Oracle 的存储过程里没有declare的语法,如果要定义变量,后面直接跟is。
    触发器和plsql块定义变量用declare。
    分组函数可以在没有分组的时候单独使用,但是不能出现其他的查询字段;

    PL/SQL NULL值表示缺少或未知的数据,它不是一个整数,字符,或任何其他特定的数据类型。需要注意的是NULL不是一样的空数据串或空字符值’\0’。NULL可以被分配,但它不能与任何东西等同,包括其本身。

    PL/SQL变量必须在声明部分或包作为一个全局变量声明。当声明一个变量,PL/SQL的变量值分配内存并由变量名称标识存储位置。

    OracleORA-12560协议适配器错误
    1.监听程序正常启动
    2.Oracle数据库实例服务正常运行
    3.修改注册表默认SID为存在的Oracle数据库

    一、当Oracle有多个实例时,执行conn /as
    sysdba出错

    使用以下命令设置默认实例

    set
    oracl_sid=XXX(XXX为希望设为默认的实例SID)
    注:该命令在命令行下执行,并非sqlplus中。
    二、dba的密码遗忘,无法以dba账号(sys或system)登陆
    1)以本地用户身份进入sqlplus(前提:确保本地系统用户在oracle的DBA group中)
    sqlplus /nolog
    2)以dba身份登录
    conn /as sysdba
    3)修改dba sys或system的密码(新密码为123456)
    alter user sys identified by
    123456;


    三、Oracle用户密码过期
    使用sqlplus登陆oracle数据库时提示“ORA-28002: 7 天之后口令将过期” 或提示 密码过期。

    【原因/触发因素】
    由于oracle11g中默认在default概要文件中设置“PASSWORD_LIFE_TIME=180天”所导致。
    处理方法及步骤:
    1、查看用户的proifle是哪个,一般是default:
    sql>SELECT username,PROFILE FROM dba_users;
    2、查看指定概要文件(如default)的密码有效期设置:
    sql>SELECT FROM dba_profiles s WHERE s.profile=’DEFAULT’ AND
    resource_name=’PASSWORD_LIFE_TIME’;
    3、将密码有效期由默认的180天修改成“无限制”:
    sql>ALTER PROFILE DEFAULT LIMIT PASSWORD_LIFE_TIME
    UNLIMITED;
    修改之后不需要重启动数据库,会立即生效。
    4、修改后,还没有被提示ORA-28002警告的帐户不会再碰到同样的提示;
    已经被提示的帐户必须再改一次密码,举例如下:
    $sqlplus / as sysdba
    sql> alter user smsc identified by <原来的密码>
    ——不用换新密码
    oracle11g启动参数resource_limit无论设置为false还是true,密码有效期都是生效的,所以必须通过以上方式进行修改。以上的帐户名请根据实际使用的帐户名更改。
    四、Oracle数据库无法用IP连接
    Oracle数据库(Oracle
    11g)安装后,在本机使用sqldeveloper进行连接,如果主机名输入localhost,可以成功连接;但如果主机名输入IP地址,无法连接,提示信息为:Oracle
    the network adapter could not establish the connection。
    如果在命令行中输入 sqlplus username/password@IP地址,系统提示“无监听程序”。
    经百度,解决方案如下:
    1、开始—>程序—>Oracle -OraDb11g_home1—>配置和移植工具—>Net Manager
    2、点击 监听程序 LISTENER,在 监听位置 页面中,增加地址:协议:TCP/IP
    主机:本地IP地址
    端口:1521
    3、点击菜单 文件-保存网络配置
    4、重启监听服务:可使用命令进行重启 lsnrctl reload;也可在服务中重启 TNSListener 服务

    五、安装64位版Oracle11gR2后无法启动SQLDeveloper
    安装64位版Oracle11gR2后发现启动SQL
    Developer时弹出配置java.exe的路径,找到Oracle自带java.exe后产生的路径“\app\用户名\product\11.2.0\dbhome_1\jdk”却弹出错误信息:
    --------------------------
    Unable to find a java Virtual Machine
    to point to a location of a java virtual machine,please refer to
    the oracle9i Jdeveloper Install guide(jdev\install.html)
    --------------------------
    在安装目录下(app\用户名\product\11.2.0\dbhome_1\sqldeveloper0\sqldeveloper\bin)手动修改配置文件sqldeveloper.conf中的“SetJavaHome”为电脑上独立安装的JDK,结果还是一样。

    经百度,原来Oracle在制造64位版的时候没注意Oracle11gR2所带的SQL
    Developer是1.5.5.59.69版,不支持64位版的JDK,恰好64位Oracle带的JDK和“C:\Program
    Files”中的JDK都是64位的。如果你单独安装的JDK中“C:\Program Files
    (x86)”中则说明是32位版的,是可以用的。为什么MyEclipse所带的JDK可用呢,因为MyEcipse8.5没有64位版(包括最新的8.6也一样),所以其中带的JDK当然是32位版的了。
    解决方案如下:
    1)单独安装一个32位版的JDK就可以直接配置了;
    2)升级SQL
    Developer到最新版本:把原来“app\用户名\product\11.2.0\dbhome_1”下的的删除,从官网下载最新版本,直接解压得到一个sqldeveloper文件夹放到同一位置即可。

    SQLPLUS连接显示连接到空闲例程
    未命名图片.png
    说明数据库实例没有启动,需启动数据库实例。
    未命名图片.png
    实例启动完成后,查看当前实例与数据库的状态。(mounted)
    未命名图片.png
    未命名图1片.png
    tnsping操作超时
    *未命名图44片.png

    一、我先查了一下客户端安装路径下的network\admin下tnsname配置文件。
    二、排查一下网络问题,客户端PC—CMD下ping 服务器IP 无法ping通,ping自己和网关都没问题。经过尝试得到是服务器端防火墙设置的问题。
    操作如下:服务器管理器—高级安全windows防火墙—入站规则—找到文件和打印机共享(回显请求icmpv4)—将此规则启用,确定即可。此时就可以ping通 服务器IP了。再次尝试tnsping还是超时。
    三、win2008r2防火墙添加端口入站和出站规则:1521Oracle服务器与本机都在局域网内,不存在网络不通问题,怎么会无法连接。
    操作如下:服务器管理器—高级安全windows防火墙—入站规则—新建规则(根据提示操作将特定的1521端口添加入站、出站规则)
    RMAN备份时报“ORA-19504: failed to create file”和“ORA-27038: created file already exists”
    原因是控制文件和参数文件需要单独生成一个备份集,不能和数据库共用一个备份集,而在给数据文件指定备份集时又只指定一个单一的文件名,所以报了个文件已经存在的错误。 解决方法是在format里加一个%U,这样就会自动生成不同又唯一的文件名了。
    Ora-12514:TNS:监听程序当前无法识别链接描述符中请求的服务
    该问题是由于缺少监听器的SID_LIST描述项引起的,采用netca进行配置的时候经常会遇到该问题,listener.ora示例如下

    SID_LIST_LISTENER =
    (SID_LIST =
    (SID_DESC =
    (SID_NAME = PLSExtProc)
    (ORACLE_HOME = /opt/oracle/product/9.2.0.4)
    (PROGRAM = extproc)
    )
    (SID_DESC =
    (GLOBAL_DBNAME = SAMPLE.COM)
    (ORACLE_HOME = /opt/oracle/product/9.2.0.4)
    (SID_NAME = SAMPLE)
    ))

    LISTENER =
    (DESCRIPTION_LIST =
    (DESCRIPTION =
    (ADDRESS_LIST =
    (ADDRESS = (PROTOCOL = TCP)(HOST = tcy.com)(PORT = 1521))
    )
    (ADDRESS_LIST =
    (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC))
    )))