• Oracle11g R2学习系列 之三教程选择


    工欲善其事必先利其器,选择一本入门教程也是很重要的,本人使用的也是这位同事推荐的电子工业出版社的<<Oracle 实用教程(第3版)>>郑阿奇主编,可以至这里购买到,我个人还是蛮推荐这本书的,注册之后,可以下载这本书的ppt和实验电子档。

     匆匆看完了所有的PPT和其它的rtf文档,打开了实验文档的<<实习4:ASP.NET3.5-Oracle>>,于是各种问题出现了:

    实验IDE:VS2012 ultimate 英文版

    F5启动时就出现BadImageFormatException

    BadImageFormatException

    奇怪了去,我下的Oracle本身就是win64_11gR2_database_1of2.zip 和win64_11gR2_database_2of2.zip 这两个解压版的。按照这个黄页的提示,只有可能是我的vS2012是32位的,难不成其所使用的webdev.exe是32的oracleClient? 如果我换成64位的client并改用iis host是不是就可以了呢?抱着试验的心态重新去官网下载了个instantclient-basic-windows.x64-11.2.0.3.0.zip,解压并path向解压文件夹。并且还使改用了IIS承载方式,不曾想却又出现

    ORA-12154: TNS: could not resolve the connect identifier specified

    tns

    这个更无语了,我的SQLPLUS和SQLDeveleper以及OEM都是可以连接的。难道用以下这样的连接字符串不行:

    <connectionStrings>
    <add name="ConnectionString" connectionString="Server=localhost; User ID=system;Password=abcdef;Data Source=orcl" providerName="System.Data.OracleClient"/>
      </connectionStrings>
    View Code

    打开C:oracle11gr2product11.2.0dbhome_1NETWORKADMIN nsnames.ora文件,发现内容是这样子的:

    # tnsnames.ora Network Configuration File: C:oracle11gr2product11.2.0dbhome_1
    etworkadmin	nsnames.ora
    # Generated by Oracle configuration tools.
    
    LISTENER_ORCL =
      (ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))
    
    
    ORACLR_CONNECTION_DATA =
      (DESCRIPTION =
        (ADDRESS_LIST =
          (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
        )
        (CONNECT_DATA =
          (SID = CLRExtProc)
          (PRESENTATION = RO)
        )
      )
    
    ORCL =
      (DESCRIPTION =
        (ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))
        (CONNECT_DATA =
          (SERVER = DEDICATED)
          (SERVICE_NAME = orcl)
        )
      )
    View Code

    于是我将连接字符串改成如下所示

    <connectionStrings>
        <add name="ConnectionString" connectionString="Server=localhost; User ID=system;Password=abcdef;Data Source=(DESCRIPTION =(ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))(CONNECT_DATA = (SERVER = DEDICATED)(SERVICE_NAME = orcl)))" providerName="System.Data.OracleClient"/>
      </connectionStrings>
    View Code

    然后就好了,出现期待的画面。感觉这个有点坑,为什么会这样子呢?求解于Google的时候,发现海峡对岸有位仁兄说加个TNS_ADMIN字串值在regedit(HKEY_LOCAL_MACHINESOFTWAREORACLEKEY_OraDb11g_home1)中就可以解决,貌似我加了没有什么反应。还有CSDN上面有位哥们说加TNS_ADMIN进环境变量,同样在我机器上没起作用。

     总结:Oracle在Windows 64位机器上真的是各种坑啊?特别是.NET开发的人员。感觉Oracle就是一个麻烦物样的。:)

  • 相关阅读:
    ES 内存深度解析
    Spring Cache介绍和使用
    mysql 索引及索引创建原则
    mysql中四种存储引擎的区别和选择
    Java中数组、List、Set互相转换
    COGS 1151 活动安排
    洛谷P1650赛马与codevs 2181 田忌赛马
    5月3日济南清北学堂随堂测试题目
    codevs 1206 保留两位小数
    codevs 1203 判断浮点数是否相等
  • 原文地址:https://www.cnblogs.com/SLKnate/p/oracle11g_book_example.html
Copyright © 2020-2023  润新知