こんにちは。よこやんです。
今回は、Androidで直接OracleDBに接続したいと思います。
言語はJavaです。
目次
・開発環境
・AndroidStudio Koala Feature Drop | 2024.1.2
・Oracle Database 11g Release 11.2.0.4.0
・jdbc:ojdbc6:11.2.0.4
・AndroidStudioの設定
・CompileSdk 34
・minSdk 29
・targetSdk 34
・Java 1.8
・build.gradle(:app)にJDBCを追加
Maven Repositoryにアクセスします。
今回はJDBC6を使います。
Gradle(Short)タブに書かれている、implementationをコピーします。
AndroidStudioを起動し、build.gradle(:app)を開きます。
dependenciesの部分にコピーした、implementationをペーストします。
・プログラム作成
Oracleに接続するConnectionClassを作成します。
Oracleに接続するために、サーバーのIPアドレス、Oracleのポート番号、SID、ユーザ名、パスワードが必要になります。
ConnectClass
package com.example.myapplication;
import java.sql.*;
public class ConnectClass {
public Connection Conn() throws SQLException, ClassNotFoundException {
Connection conn = null;
try{
Class.forName("oracle.jdbc.driver.OracleDriver");
String url = "jdbc:oracle:thin:@【IPアドレス】:【ポート番号】:【SID】";
String user = "【ユーザ名】";
String pass = "【パスワード】";
//データベースに接続
conn = DriverManager.getConnection(url,user,pass);
} catch (Exception e){
System.out.println("接続エラー");
System.out.println(e);
}
return conn;
}
}
MainActivityのプログラムは以下になります。
MainActivity
package com.example.myapplication;
import android.os.Bundle;
import android.widget.TextView;
import android.widget.Toast;
import androidx.activity.EdgeToEdge;
import androidx.appcompat.app.AppCompatActivity;
import java.sql.Connection;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class MainActivity extends AppCompatActivity {
ConnectClass connectionClass;
Connection con;
String str;
TextView textView1;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
textView1 = findViewById(R.id.textView1);
connectionClass = new ConnectClass();
connect();
}
public void connect(){
ExecutorService executorService = Executors.newSingleThreadExecutor();
executorService.execute(() -> {
try {
con = connectionClass.Conn();
if (con == null){
str = "ERROR";
} else {
str = "Connect";
}
} catch (Exception e){
throw new RuntimeException(e);
}
runOnUiThread(() -> {
try{
Thread.sleep(1000);
textView1.setText(str);
} catch (InterruptedException e){
Toast.makeText(this, str, Toast.LENGTH_SHORT).show();
}
});
});
}
}
※AndroidManifest.xmlに、1行追加する必要があります。これは相当ハマった…
赤文字の部分を追記します。
AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools">
<uses-permission android:name="android.permission.INTERNET" />
<application
android:allowBackup="true"
android:dataExtractionRules="@xml/data_extraction_rules"
android:fullBackupContent="@xml/backup_rules"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true"
android:theme="@style/Theme.MyApplication"
tools:targetApi="31">
<activity
android:name=".MainActivity"
android:exported="true">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>
このプログラムを実行すると、
OracleDBに接続成功した場合は、「Connect」
OracleDBに接続失敗した場合は、「ERROR」と表示されます。
次回はJDBCを使って、SELECT、UPDATE等やりたいと思います。
プロシージャの呼び出しもできるようです。
参考:
コメントを残す