Archive for the ‘JDBC’ Category
-
Hello, JDBC Type4(Groovy) World!
Posted on 10月 3rd, 2012 by cx20
JDBC Type4
JDBC(Java Database Connectivity)は、Java 用のデータベース接続 API である。実装方法によりType1~4の4つのタイプが存在する。
Type4 は DBMS のクライアントライブラリを使用しない Pure Java の DBMS ドライバである。
以下は Groovy による JDBC ライブラリの使用例となっている。ソースコード(Groovy + JDBC Type4 + SQL Server)
import groovy.sql.Sql class Hello { static void main(args) { Sql sql = Sql.newInstance("jdbc:sqlserver://;serverName=localhost", "sa", "P@ssW0rd", "com.microsoft.sqlserver.jdbc.SQLServerDriver") sql.eachRow("SELECT 'Hello, JDBC Type4 World!' AS Message"){ println it.Message } } }
実行方法(Groovy + JDBC Type4 + SQL Server)
C:¥> groovy -cp "sqljdbc4.jar;." Hello.groovy
ソースコード(Groovy + JDBC Type4 + Oracle)
import groovy.sql.Sql class Hello { static void main(args) { Sql sql = Sql.newInstance("jdbc:oracle:thin:@localhost:1521:orcl", "scott", "tiger", "oracle.jdbc.driver.OracleDriver") sql.eachRow("SELECT 'Hello, JDBC Type4 World!' AS Message FROM DUAL"){ println it.Message } } }
実行方法(Groovy + JDBC Type4 + Oracle)
C:¥> groovy -cp "ojdbc6.jar;." Hello.groovy
ソースコード(Groovy + JDBC Type4 + MySQL)
import groovy.sql.Sql class Hello { static void main(args) { Sql sql = Sql.newInstance("jdbc:mysql://localhost:3306", "root", "P@ssW0rd", "com.mysql.jdbc.Driver") sql.eachRow("SELECT 'Hello, JDBC Type4 World!' AS Message"){ println it.Message } } }
実行方法(Groovy + JDBC Type4 + MySQL)
C:¥> groovy -cp "mysql-connector-java-5.1.22-bin.jar;." Hello.groovy
実行結果
Hello, JDBC Type4 World!
-
Hello, JDBC Type2(Groovy) World!
Posted on 10月 2nd, 2012 by cx20
JDBC Type2
JDBC(Java Database Connectivity)は、Java 用のデータベース接続 API である。実装方法によりType1~4の4つのタイプが存在する。
Type2 は JDBC と DBMS クライアントの API をマップさせたブリッジドライバである。
例えば、Oracle であればクライアントライブラリとして OCI が使用される。
以下は Groovy による JDBC ライブラリの使用例となっている。ソースコード(Groovy + JDBC Type2 + Oracle)
import groovy.sql.Sql class Hello { static void main(args) { Sql sql = Sql.newInstance("jdbc:oracle:oci:@orcl", "scott", "tiger", "oracle.jdbc.driver.OracleDriver") sql.eachRow("SELECT 'Hello, JDBC Type2 World!' AS Message FROM DUAL"){ println it.Message } } }
実行方法
C:¥> groovy Hello.groovy C:¥> groovy -cp "ojdbc6.jar;." Hello.groovy
実行結果
Hello, JDBC Type2 World!
-
Hello, JDBC Type1(Groovy) World!
Posted on 10月 1st, 2012 by cx20
JDBC Type1
JDBC(Java Database Connectivity)は、Java 用のデータベース接続 API である。実装方法によりType1~4の4つのタイプが存在する。
Type1 は JDBC と ODBC の API をマップさせたブリッジドライバである。
以下は Groovy による JDBC ライブラリの使用例となっている。ソースコード(Groovy + JDBC Type1 + ODBC + Jet データベース)
import groovy.sql.Sql class Hello { static void main(args) { Sql sql = Sql.newInstance("jdbc:odbc:Driver={Microsoft Access Driver (*.mdb)};DBQ=.\hello.mdb", "", "", "sun.jdbc.odbc.JdbcOdbcDriver") sql.eachRow("SELECT 'Hello, JDBC Type1 World!' AS Message"){ println it.Message } } }
ソースコード(Groovy + JDBC Type1 + ODBC + ACE データベース)
import groovy.sql.Sql class Hello { static void main(args) { Sql sql = Sql.newInstance("jdbc:odbc:Driver={Microsoft Access Driver (*.mdb, *.accdb)};DBQ=.\hello.accdb", "", "", "sun.jdbc.odbc.JdbcOdbcDriver") sql.eachRow("SELECT 'Hello, JDBC Type1 World!' AS Message"){ println it.Message } } }
ソースコード(Groovy + JDBC Type1 + ODBC + SQL Server)
import groovy.sql.Sql class Hello { static void main(args) { Sql sql = Sql.newInstance("jdbc:odbc:Driver={SQL Server};SERVER=(local);DATABASE=master", "sa", "P@ssword", "sun.jdbc.odbc.JdbcOdbcDriver") sql.eachRow("SELECT 'Hello, JDBC Type1 World!' AS Message"){ println it.Message } } }
ソースコード(Groovy + JDBC Type1 + ODBC + Oracle)
import groovy.sql.Sql class Hello { static void main(args) { Sql sql = Sql.newInstance("jdbc:odbc:Driver={Oracle in OraDb11g_home1};DBQ=ORCL", "scott", "tiger", "sun.jdbc.odbc.JdbcOdbcDriver") sql.eachRow("SELECT 'Hello, JDBC Type1 World!' AS Message FROM DUAL"){ println it.Message } } }
実行方法
C:¥> groovy Hello.groovy
実行結果
Hello, JDBC Type1 World!
-
Hello, SQLJ World!
Posted on 4月 7th, 2012 by cx20
SQLJ
SQLJ は Oracle Database に対応した Java 用の埋め込み SQL(Embedded SQL)である。類似の製品としては、Pro*C/C++、Pro*COBOL、Pro*FORTRAN、Pro*Pascal 等がある。
なお、埋め込み SQL 自体は、標準SQL として ANSI/ISO にて仕様が策定されている。ソースコード(SQLJ)
import java.sql.*; import oracle.sqlj.runtime.Oracle; #sql iterator MessageIter ( String MESSAGE ); class Hello { public static void main( String[] args ) throws Exception { Oracle.connect("jdbc:oracle:oci:@", "scott", "tiger"); MessageIter iter; #sql iter = { SELECT 'Hello, SQLJ World!' AS Message FROM DUAL }; while ( iter.next() ) { System.out.println( iter.MESSAGE() ); } } }
上記コードは、SQLJ トランスレータ により、以下の Java のコードが生成される。
ソースコード(Java)
/*@lineinfo:filename=Hello*//*@lineinfo:user-code*//*@lineinfo:1^1*/import java.sql.*; import oracle.sqlj.runtime.Oracle; /*@lineinfo:generated-code*//*@lineinfo:4^1*/ // ************************************************************ // SQLJ iterator declaration: // ************************************************************ class MessageIter extends sqlj.runtime.ref.ResultSetIterImpl implements sqlj.runtime.NamedIterator { public MessageIter(sqlj.runtime.profile.RTResultSet resultSet) throws java.sql.SQLException { super(resultSet); MESSAGENdx = findColumn("MESSAGE"); m_rs = (oracle.jdbc.OracleResultSet) resultSet.getJDBCResultSet(); } private oracle.jdbc.OracleResultSet m_rs; public String MESSAGE() throws java.sql.SQLException { return (String)m_rs.getString(MESSAGENdx); } private int MESSAGENdx; } // ************************************************************ /*@lineinfo:user-code*//*@lineinfo:4^44*/ class Hello { public static void main( String[] args ) throws Exception { Oracle.connect("jdbc:oracle:oci:@", "scott", "tiger"); MessageIter iter; /*@lineinfo:generated-code*//*@lineinfo:10^9*/ // ************************************************************ // #sql iter = { SELECT 'Hello, SQLJ World!' AS Message FROM DUAL }; // ************************************************************ { // declare temps oracle.jdbc.OraclePreparedStatement __sJT_st = null; sqlj.runtime.ref.DefaultContext __sJT_cc = sqlj.runtime.ref.DefaultContext.getDefaultContext(); if (__sJT_cc==null) sqlj.runtime.error.RuntimeRefErrors.raise_NULL_CONN_CTX(); sqlj.runtime.ExecutionContext.OracleContext __sJT_ec = ((__sJT_cc.getExecutionContext()==null) ? sqlj.runtime.ExecutionContext.raiseNullExecCtx() : __sJT_cc.getExecutionContext().getOracleContext()); try { String theSqlTS = "SELECT 'Hello, SQLJ World!' AS Message FROM DUAL"; __sJT_st = __sJT_ec.prepareOracleStatement(__sJT_cc,"0MessageIter",theSqlTS); // execute query iter = new MessageIter(new sqlj.runtime.ref.OraRTResultSet(__sJT_ec.oracleExecuteQuery(),__sJT_st,"0MessageIter",null)); } finally { __sJT_ec.oracleCloseQuery(); } } // ************************************************************ /*@lineinfo:user-code*//*@lineinfo:10^72*/ while ( iter.next() ) { System.out.println( iter.MESSAGE() ); } } }/*@lineinfo:generated-code*/
コンパイル&実行方法
C:¥> SET PATH=ORACLE_BASEORACLE_HOMEbin;%PATH% C:¥> SET CLASSPATH=ORACLE_BASEORACLE_HOMEsqljlibruntime12.jar; ORACLE_BASEORACLE_HOMEsqljlibtranslator.jar; ORACLE_BASEORACLE_HOMEjdbclibojdbc6.jar;%CLASSPATH% C:¥> sqlj Hello.sqlj C:¥> java Hello実行結果
Hello, SQLJ World!
-
Hello, JDBC Type4 World!
Posted on 4月 6th, 2012 by cx20
JDBC Type4
JDBC(Java Database Connectivity)は、Java 用のデータベース接続 API である。実装方法によりType1~4の4つのタイプが存在する。
Type4 は DBMS のクライアントライブラリを使用しない Pure Java の DBMS ドライバである。ソースコード(Java + JDBC Type4 + SQL Server)
import java.sql.*; class Hello { public static void main( String[] args ) throws Exception { Class.forName ("com.microsoft.sqlserver.jdbc.SQLServerDriver"); Connection conn = DriverManager.getConnection("jdbc:sqlserver://;serverName=localhost", "sa", "P@ssW0rd"); Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery("SELECT 'Hello, JDBC Type4 World!' AS Message"); while ( rs.next() ) { System.out.println( rs.getString(1) ); } rs.close(); stmt.close(); conn.close(); } }
コンパイル&実行方法(Java + JDBC Type4 + SQL Server)
C:¥> javac Hello.java C:¥> java -cp "sqljdbc4.jar;." Hello
ソースコード(Java + JDBC Type4 + Oracle)
import java.sql.*; class Hello { public static void main( String[] args ) throws Exception { Class.forName ("oracle.jdbc.driver.OracleDriver"); Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:orcl", "scott", "tiger"); Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery("SELECT 'Hello, JDBC Type4 World!' AS Message FROM DUAL"); while ( rs.next() ) { System.out.println( rs.getString(1) ); } rs.close(); stmt.close(); conn.close(); } }
コンパイル&実行方法(Java + JDBC Type4 + Oracle)
C:¥> javac Hello.java C:¥> java -cp "ojdbc6.jar;." Hello
ソースコード(Java + JDBC Type4 + MySQL)
import java.sql.*; class Hello { public static void main( String[] args ) throws Exception { Class.forName ("com.mysql.jdbc.Driver"); Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306", "root", "P@ssW0rd"); Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery("SELECT 'Hello, JDBC Type4 World!' AS Message"); while ( rs.next() ) { System.out.println( rs.getString(1) ); } rs.close(); stmt.close(); conn.close(); } }
コンパイル&実行方法(Java + JDBC Type4 + MySQL)
C:¥> javac Hello.java C:¥> java -cp "mysql-connector-java-5.1.22-bin.jar;." Hello
実行結果
Hello, JDBC Type4 World!
-
Hello, JDBC Type2 World!
Posted on 4月 5th, 2012 by cx20
JDBC Type2
JDBC(Java Database Connectivity)は、Java 用のデータベース接続 API である。実装方法によりType1~4の4つのタイプが存在する。
Type2 は JDBC と DBMS クライアントの API をマップさせたブリッジドライバである。
例えば、Oracle であればクライアントライブラリとして OCI が使用される。
ソースコード(Java + JDBC Type2 + Oracle)
import java.sql.*; class Hello { public static void main( String[] args ) throws Exception { Class.forName("oracle.jdbc.driver.OracleDriver"); Connection conn = DriverManager.getConnection("jdbc:oracle:oci:@orcl", "scott", "tiger"); Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery("SELECT 'Hello, JDBC Type2 World!' AS Message FROM DUAL"); while ( rs.next() ) { System.out.println( rs.getString(1) ); } rs.close(); stmt.close(); conn.close(); } }
コンパイル&実行方法
C:¥> javac Hello.java C:¥> java -cp "ojdbc6.jar;." Hello
実行結果
Hello, JDBC Type2 World!
-
Hello, JDBC Type1 World!
Posted on 4月 4th, 2012 by cx20
JDBC Type1
JDBC(Java Database Connectivity)は、Java 用のデータベース接続 API である。実装方法によりType1~4の4つのタイプが存在する。
Type1 は JDBC と ODBC の API をマップさせたブリッジドライバである。ソースコード(Java + JDBC Type1 + ODBC + Jet データベース)
import java.sql.*; import sun.jdbc.odbc.*; class Hello { public static void main( String[] args ) throws Exception { Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); // ODBC DSN を使用したケース Connection conn = DriverManager.getConnection("jdbc:odbc:HELLODSN", "", ""); // ODBC 接続文字列を使用したケース //Connection conn = DriverManager.getConnection("jdbc:odbc:Driver={Microsoft Access Driver (*.mdb)};DBQ=.\hello.mdb", "", ""); Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery("SELECT 'Hello, JDBC Type1 World!' AS Message"); while ( rs.next() ) { System.out.println( rs.getString(1) ); } rs.close(); stmt.close(); conn.close(); } }
ソースコード(Java + JDBC Type1 + ODBC + ACE データベース)
import java.sql.*; import sun.jdbc.odbc.*; class Hello { public static void main( String[] args ) throws Exception { Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); // ODBC DSN を使用したケース Connection conn = DriverManager.getConnection("jdbc:odbc:HELLODSN", "", ""); // ODBC 接続文字列を使用したケース //Connection conn = DriverManager.getConnection("jdbc:odbc:Driver={Microsoft Access Driver (*.mdb, *.accdb)};DBQ=.\hello.accdb", "", ""); Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery("SELECT 'Hello, JDBC Type1 World!' AS Message"); while ( rs.next() ) { System.out.println( rs.getString(1) ); } rs.close(); stmt.close(); conn.close(); } }
ソースコード(Java + JDBC Type1 + ODBC + SQL Server)
import java.sql.*; import sun.jdbc.odbc.*; class Hello { public static void main( String[] args ) throws Exception { Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); // ODBC DSN を使用したケース Connection conn = DriverManager.getConnection("jdbc:odbc:HELLODSN", "sa", "P@ssW0rd"); // ODBC 接続文字列を使用したケース //Connection conn = DriverManager.getConnection("jdbc:odbc:Driver={SQL Server};SERVER=(local)", "sa", "P@ssW0rd"); Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery("SELECT 'Hello, JDBC Type1 World!' AS Message"); while ( rs.next() ) { System.out.println( rs.getString(1) ); } rs.close(); stmt.close(); conn.close(); } }
ソースコード(Java + JDBC Type1 + ODBC + Oracle)
import java.sql.*; import sun.jdbc.odbc.*; class Hello { public static void main( String[] args ) throws Exception { Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); // ODBC DSN を使用したケース Connection conn = DriverManager.getConnection("jdbc:odbc:HELLODSN", "scott", "tiger"); // ODBC 接続文字列を使用したケース1(MS 製 ODBC ドライバ) //Connection conn = DriverManager.getConnection("jdbc:odbc:Driver={Microsoft ODBC for Oracle};Data Source=ORCL", "scott", "tiger"); // ODBC 接続文字列を使用したケース2(Oracle 製 ODBC ドライバ) //Connection conn = DriverManager.getConnection("jdbc:odbc:Driver={Oracle in OraDb11g_home1};DBQ=ORCL", "scott", "tiger"); Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery("SELECT 'Hello, JDBC Type1 World!' AS Message FROM DUAL"); while ( rs.next() ) { System.out.println( rs.getString(1) ); } rs.close(); stmt.close(); conn.close(); } }
ソースコード(Java + JDBC Type1 + ODBC + MySQL)
import java.sql.*; import sun.jdbc.odbc.*; class Hello { public static void main( String[] args ) throws Exception { Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); // ODBC DSN を使用したケース Connection conn = DriverManager.getConnection("jdbc:odbc:HELLODSN", "root", "P@ssW0rd"); // ODBC 接続文字列を使用したケース //Connection conn = DriverManager.getConnection("jdbc:odbc:Driver={MySQL ODBC 5.1 Driver};Server=localhost", "root", "P@ssW0rd"); Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery("SELECT 'Hello, JDBC Type1 World!' AS Message"); while ( rs.next() ) { System.out.println( rs.getString(1) ); } rs.close(); stmt.close(); conn.close(); } }
コンパイル&実行方法
C:¥> javac Hello.java C:¥> java Hello
実行結果
Hello, JDBC Type1 World!