java访问oracle的jdbc连接方式:oci和thin
http://hi.baidu.com/anboqing/blog/item/5a7b49f4e36fb57ddcc4744a.html 最近在学习使用java语言连接oracle数据库,特意查询了jdbc的两种连接方式 oci 和 thin 是 Oracle 提供的两套 Java 访问 Oracle 数据库方式。 thin 是一种瘦客户端的连接方式,即采用
http://hi.baidu.com/anboqing/blog/item/5a7b49f4e36fb57ddcc4744a.html
最近在学习使用java语言连接oracle数据库,特意查询了jdbc的两种连接方式
oci和thin是Oracle提供的两套Java访问Oracle数据库方式。
thin是一种瘦客户端的连接方式,即采用这种连接方式不需要安装oracle客户端,只要求classpath中包含jdbc驱动的jar包就行。thin就是纯粹用Java写的ORACLE数据库访问接口。
oci是一种胖客户端的连接方式,即采用这种连接方式需要安装oracle客户端。oci是Oracle
Call Interface的首字母缩写,是ORACLE公司提供了访问接口,就是使用Java来调用本机的Oracle客户端,然后再访问数据库,优点是速度快,但是需要安装和配置数据库。
从相关资料可以总结出以下几点:
1. 从使用上来说,oci必须在客户机上安装oracle客户端或才能连接,而thin就不需要,因此从使用上来讲thin还是更加方便,这也是thin比较常见的原因。
2. 原理上来看,thin是纯java实现tcp/ip的c/s通讯;而oci方式,客户端通过native
java method调用c library访问服务端,而这个c library就是oci(oracle
called interface),因此这个oci总是需要随着oracle客户端安装(从oracle10.1.0开始,单独提供OCI
Instant Client,不用再完整的安装client)
3. 它们分别是不同的驱动类别,oci是二类驱动, thin是四类驱动,但它们在功能上并无差异。
从使用thin驱动切换到oci驱动在配置来说很简单,只需把连接字符串java:oracle:thin:@hostip:1521:实例名换为java:oracle:oci@本地服务名即可。如:从
jdbc:oracle:thin:@10.1.1.2:1521:shdb
改成
jdbc:oracle:oci8:@shdb
但这里这台机需安装oracle数据库的客户端并配置本地服务名,同时还需指定NLS_LANG环境变量,NLS_LANG环境变量是用来控制客户端在显示
oracle数据库的数据时所用的字符集和本地化习惯。通常把NLS_LANG的字符集部分指定为数据库所用的字符集则就不会存在java显示的乱码问题了。
对于oracle数据库客户端的安装,有二种选择,一是老实的用oracle数据库的安装光盘安装对应版本的oracle客户端。二是下载oracle提从的即时客户端,即时客户端是不用安装的,把下载包解压即可。
要使java web正常的通过oci驱动访问oracle,还需要客户端正确的配置一下相关变量。主要如下:
对于windows系统并使用oracle客户端时:
1. 把%ORACLE_HOME%lib加到PATH环境变量.
2. 把%ORACLE_HOME%jdbclibclasses12.jar加到CLASSPATH环境变量里.也可以把classes12.jar拷贝到tomcat的commanlib目录下。
对于windows系统并使用oracle的即时客户端时(假定即时客户端解压在d盘):
1. 把d:instantclient_10_2加到PATH环境变量
2. 把d:instantclient_10_2classes12.jar加到CLASSPATH环境变量里.也可以把classes12.jar拷贝到tomcat的commanlib目录下。
对于Linux系统并使用oracle客户端时:
1. 在使用tomcat的用户主目录下的.bash_profile文件中加入
exprot ORACLE_HOME=/u01/app/oracle/prodUCt/9.2.0.4
export LD_LIBRARY_PATH=$ORACLE_HOME/lib
2. 把classes12.jar拷贝到tomcat的commanlib目录下。
对于linux系统并使用oracle即时客户端时:
1. 在使用tomcat的用户主目录下的.bash_profile文件中加入
exprot ORACLE_HOME=/instantclient_10_2
export LD_LIBRARY_PATH=$ORACLE_HOME/lib
2. 把instantclient_10_2目录下的classes12.jar拷贝到tomcat的commanlib目录下。
假如一个tomcat下带了几个应用,且几个应用都要连接oracle数据库时,则要注重的时,不要在每个应用的WEB-
INF/lib目录下放入oracle的classes12.jar/zip文件。而应该把classes12.jar/zip文件放到tomcat的
common/lib目录下。否则会出来ojdbclib9/10库重复加载的错误。
使用oracle即时客户端是,本地服务名的建立可以在目录instantclient_10_2下建立tnsnames.ora下添加连接串,如:
SHDB =(DESCRIPTION =(ADDRESS_LIST =(ADDRESS = (PROTOCOL = TCP)(HOST = 10.1.1.236)(PORT = 1521))) (CONNECT_DATA =(SERVICE_NAME = shdb)))即可。

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Java 8 führt die Stream -API ein und bietet eine leistungsstarke und ausdrucksstarke Möglichkeit, Datensammlungen zu verarbeiten. Eine häufige Frage bei der Verwendung von Stream lautet jedoch: Wie kann man von einem Foreach -Betrieb brechen oder zurückkehren? Herkömmliche Schleifen ermöglichen eine frühzeitige Unterbrechung oder Rückkehr, aber die Stream's foreach -Methode unterstützt diese Methode nicht direkt. In diesem Artikel werden die Gründe erläutert und alternative Methoden zur Implementierung vorzeitiger Beendigung in Strahlverarbeitungssystemen erforscht. Weitere Lektüre: Java Stream API -Verbesserungen Stream foreach verstehen Die Foreach -Methode ist ein Terminalbetrieb, der einen Vorgang für jedes Element im Stream ausführt. Seine Designabsicht ist

Spring Boot vereinfacht die Schaffung robuster, skalierbarer und produktionsbereiteter Java-Anwendungen, wodurch die Java-Entwicklung revolutioniert wird. Der Ansatz "Übereinkommen über Konfiguration", der dem Feder -Ökosystem inhärent ist, minimiert das manuelle Setup, Allo

Diesmal wird der Redstone Token $ Red auf Binance Launchpool auf Binance TGE auf den Markt gebracht! Dies ist auch das erste Mal, dass Binance einen Mechanismus vor dem Markt für Handelsgrenze auf den Markt gebracht hat! Das erste Tageslimit beträgt 200%und das Verbot wird nach 3 Tagen aufgehoben, um zu vermeiden, dass "der Höhepunkt erreicht wird, wenn sich der Markt öffnet"! Der Launchpool-Mechanismus führt den an Redstone teilnehmenden Binancelaunchpool vor, der die Aktivitätszeit von Token (BNB, USDC, FDUSD) verpflichten muss, 48 Stunden: 08:00 UTC am 26. Februar 2025 bis 08:00 UTC am 28. Februar 2025 Ende des Vorschriftens Daily Daily DAILY DAILY: 18:00 Uhr am 28. Februar, 2025, 2025 Vorab-Daily Daily Regel: 18:00 Uhr am 18.18.18.18.18.201.

Um die Sicherheit der Oracle -Datenbank für das Debian -System zu stärken, müssen viele Aspekte beginnen. Die folgenden Schritte bieten ein Framework für die sichere Konfiguration: 1. Oracle Database Installation und Erstkonfigurationssystemvorbereitung: Stellen Sie sicher, dass das Debian -System auf die neueste Version aktualisiert wurde, die Netzwerkkonfiguration korrekt ist und alle erforderlichen Softwarepakete installiert sind. Es wird empfohlen, auf offizielle Dokumente oder zuverlässige Ressourcen von Drittanbietern für die Installation zu verweisen. Benutzer und Gruppen: Erstellen Sie eine dedizierte Oracle -Benutzergruppe (z. B. Oinstall, DBA, Backupdba) und setzen Sie geeignete Berechtigungen dafür. 2. Sicherheitsbeschränkungen setzen

Ein Stapel ist eine Datenstruktur, die dem LIFO -Prinzip (zuletzt, zuerst heraus) folgt. Mit anderen Worten, das letzte Element, das wir einem Stapel hinzufügen, ist das erste, das entfernt wird. Wenn wir einem Stapel Elemente hinzufügen (oder drücken), werden sie oben platziert. vor allem der

In diesem Leitfaden werden mehrere Java -Methoden zum Vergleich von zwei Arraylisten untersucht. Erfolgreicher Vergleich erfordert, dass beide Listen die gleiche Größe haben und identische Elemente enthalten. Methoden zum Vergleich von Arraylisten in Java Für den Vergleich von AR existieren mehrere Ansätze

Schritte zum Senden von SMS -Erinnerungen in Java In diesem Artikel wird untersucht, wie Sie Java verwenden, um SMS -Erinnerungen an gespeicherte Kontakte zu senden. Wir führen Sie bei der Verwendung von Java zum Senden von SMS -Erinnerungen an gespeicherte oder nicht gerettete Kontakte. Die spezifischen Schritte sind wie folgt: Richten Sie ein Konto im SMS -Anbieter ein. Fügen Sie die Java -Bibliothek des Anbieters zu Ihrem Projekt hinzu. Schreiben Sie Java -Code, um Textnachrichten zu senden. Lassen Sie uns die obigen Schritte ausführlich ausführen. Richten Sie ein Konto ein Zunächst müssen wir ein Konto in jeder Messaging -API (z. B. Twilio) einrichten. Erstellen Sie ein Twilio -Konto Registrieren Sie ein Konto. Holen Sie sich die Anmeldeinformationen und sobald Sie ein Konto haben, haben Sie ein Konto Sid und Auth Token. Sie benötigen diese Informationen, um dies zu überprüfen

Muss ich einen Oracle -Client installieren, wenn ich mit GO eine Verbindung zu einer Oracle -Datenbank herstellen kann? Bei der Entwicklung in Go ist die Verbindung zu Oracle -Datenbanken eine übliche Anforderung ...
