java - Oracle 数据库与 Android Studio 的连接
问题描述
我是 android 新手所以有人可以告诉我如何在 java 中将 Oracle 10g Express Edition Database 连接到 Android .. 因为我试图使用 ojdbc14.jar 连接它,但它对我不起作用,它给出了错误。下面提到的是与 oracle 数据库建立连接的代码。所以请帮助我如何解决这个问题
主要活动
public class MainActivity extends AppCompatActivity {
private static final String DEFAULT_DRIVER = "oracle.jdbc.driver.OracleDriver";
private static final String DEFAULT_URL = "jdbc:oracle:thin:@127.0.0.1:8080:apex";
private static final String DEFAULT_USERNAME = "system";
private static final String DEFAULT_PASSWORD = "12345";
private Connection connection;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
if (android.os.Build.VERSION.SDK_INT > 9) {
StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();
StrictMode.setThreadPolicy(policy);
}
TextView tv = (TextView) findViewById(R.id.hello);
try {
this.connection = createConnection();
Toast.makeText(MainActivity.this, "Connected",
Toast.LENGTH_SHORT).show();
Statement stmt=connection.createStatement();
StringBuffer stringBuffer = new StringBuffer();
ResultSet rs=stmt.executeQuery("select * from cat");
while(rs.next()) {
stringBuffer.append( rs.getString(1)+"\n");
}
tv.setText(stringBuffer.toString());
connection.close();
}
catch (Exception e) {
Toast.makeText(MainActivity.this, ""+e,
Toast.LENGTH_SHORT).show();
e.printStackTrace();
}
}
public static Connection createConnection(String driver, String url, String username, String password) throws ClassNotFoundException, SQLException {
Class.forName(DEFAULT_DRIVER);
return DriverManager.getConnection(url, username, password);
}
public static Connection createConnection() throws ClassNotFoundException, SQLException {
return createConnection(DEFAULT_DRIVER, DEFAULT_URL, DEFAULT_USERNAME, DEFAULT_PASSWORD);
}
}
日志错误:
2021-01-09 12:12:14.391 7420-7420/? E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.example.smsapp, PID: 7420
java.lang.NoClassDefFoundError: Failed resolution of: Ljava/sql/DriverAction;
at java.lang.Class.classForName(Native Method)
at java.lang.Class.forName(Class.java:454)
at java.lang.Class.forName(Class.java:379)
at com.example.smsapp.MainActivity.createConnection(MainActivity.java:61)
at com.example.smsapp.MainActivity.createConnection(MainActivity.java:66)
at com.example.smsapp.MainActivity.onCreate(MainActivity.java:39)
at android.app.Activity.performCreate(Activity.java:8000)
at android.app.Activity.performCreate(Activity.java:7984)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1309)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3422)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3601)
at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:85)
at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135)
at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2066)
at android.os.Handler.dispatchMessage(Handler.java:106)
at android.os.Looper.loop(Looper.java:223)
at android.app.ActivityThread.main(ActivityThread.java:7656)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:592)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:947)
Caused by: java.lang.ClassNotFoundException: Didn't find class "java.sql.DriverAction" on path: DexPathList[[zip file "/data/app/~~EJwytfOxILxUukbju8Aaxg==/com.example.smsapp-g50eDPxoOlS69i38LN8oDA==/base.apk"],nativeLibraryDirectories=[/data/app/~~EJwytfOxILxUukbju8Aaxg==/com.example.smsapp-g50eDPxoOlS69i38LN8oDA==/lib/x86, /system/lib, /system_ext/lib, /product/lib]]
at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:207)
at java.lang.ClassLoader.loadClass(ClassLoader.java:379)
at java.lang.ClassLoader.loadClass(ClassLoader.java:312)
at java.lang.Class.classForName(Native Method)
at java.lang.Class.forName(Class.java:454)
at java.lang.Class.forName(Class.java:379)
at com.example.smsapp.MainActivity.createConnection(MainActivity.java:61)
at com.example.smsapp.MainActivity.createConnection(MainActivity.java:66)
at com.example.smsapp.MainActivity.onCreate(MainActivity.java:39)
at android.app.Activity.performCreate(Activity.java:8000)
at android.app.Activity.performCreate(Activity.java:7984)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1309)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3422)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3601)
at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:85)
at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135)
at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2066)
at android.os.Handler.dispatchMessage(Handler.java:106)
at android.os.Looper.loop(Looper.java:223)
at android.app.ActivityThread.main(ActivityThread.java:7656)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:592)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:947)
2021-01-09 12:12:15.226 7420-7420/? I/Process: Sending signal. PID: 7420 SIG: 9
解决方案
推荐阅读
- python - 从 .csv 文件中找到值时如何停止 For 循环
- java - 使用 spring boot parent 2.1.4.RELEASE 移动到 Greenwich.RELEASE 后启动配置服务器时出错
- excel - 查找一行中第一次出现的值并返回它旁边的单元格
- json - 如何将 JSON 文件导入 Angular 库?
- groovy - Groovy MarkupTemplateEngine 中的元素
- azure - 从映像创建 VM 时,Set-AZVMOperatingSystem 无法设置 TimeZone
- c# - 使用静态函数的sqlite中的线程并发
- ios - 迅速。CoreGraphics、addRects 和 fillPath 只填充 1 个矩形
- javascript - Normalizr:使用 Entity.processStrategy 方法过滤掉客户端未使用的数据是最佳实践吗?
- python-3.x - 如何修复这行代码的 TypeError。print('一年后你将是' + str(int(my_age) + 1) + '。')