gpt4 book ai didi

android - 在 android 中建立到 MySQL 的池连接

转载 作者:行者123 更新时间:2023-11-29 02:32:40 26 4
gpt4 key购买 nike

我需要从我的 Android 应用程序访问 MySQL 数据库。现在所有的工作都是通过

DriverManager.getConnection(url);

等等。但是我必须从多个线程访问数据库,所以我必须使用连接池。

问题1.是

com.mysql.jdbc.jdbc2.optional.MysqlDataSource ds = new com.mysql.jdbc.jdbc2.optional.MysqlDataSource();

创建数据源的正确方法?

问题 2。如果我编写上一行代码,我的应用程序可以在设备(不是模拟器)上正常编译和安装,但我会遇到一个奇怪的问题

java.lang.NoClassDefFoundError: com.mysql.jdbc.jdbc2.optional.MysqlDataSource`

,我无法用 try/catch 处理程序捕获:

try
{
com.mysql.jdbc.jdbc2.optional.MysqlDataSource a = new com.mysql.jdbc.jdbc2.optional.MysqlDataSource();
}
catch (Exception e)
{
I don't get here. The app just crashes, as if I had no try/catch block.
}

问题3,我把mysql-connector-java-5.1.20-bin.jar复制到设备上,写了如下代码:

try
{
final String str = Environment.getExternalStorageState();
final File sd = getActivity().getExternalFilesDir(null);
final File file = new File(sd, "mysql-connector-java-5.1.20-bin.jar");

boolean b = file.exists();

final URLClassLoader cl = URLClassLoader.newInstance(new URL[] {file.toURI().toURL()} );
cl.loadClass("com.mysql.jdbc.jdbc2.optional.MysqlDataSource"); //$NON-NLS-1$
}

catch (Exception e)
{
new AlertDialog.Builder(getActivity())
.setMessage(ObjectConverter.throwable2String(e))
.show();
}

文件找到了但是

cl.loadClass()

失败

java.lang.NullPointerException
at java.net.URLClassLoader.getPermissions(URLClassLoader.java:614)
at java.security.SecureClassLoader.getPD(SecureClassLoader.java:140)
at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:93)
at java.net.URLClassLoader.access$600(URLClassLoader.java:55)
at java.net.URLClassLoader$URLJarHandler.createClass(URLClassLoader.java:364)
at java.net.URLClassLoader$URLJarHandler.findClass(URLClassLoader.java:303)
at java.net.URLClassLoader.findClass(URLClassLoader.java:748)
at java.lang.ClassLoader.loadClass(ClassLoader.java:501)
at java.lang.ClassLoader.loadClass(ClassLoader.java:461)
at ru.mypkg.myapp.func(myapp.java:367)
at android.view.View.performClick(View.java:3511)
at android.view.View$PerformClick.run(View.java:14110)
at android.os.Handler.handleCallback(Handler.java:605)
at android.os.Handler.dispatchMessage(Handler.java:92)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4424)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
at dalvik.system.NativeStart.main(Native Method)

非常感谢任何帮助。

最佳答案

这个问题已经有 6 年历史了,Mark 是正确的,在几乎所有您能想到的场景中,Android 上的 JDBC 都像在洗澡时尝试使用 toastr 一样明智。然而,有时我们做事是因为我们可以而不是因为我们必须这样做,今天我有正当理由想要这样做(对于在不寻常环境中运行的特定非常小众的应用程序),这就是我发现这个问题的方式。

首先解决 NoClassDefFoundError,它没有被 catch block 捕获的原因是因为它是一个 Error 而不是 异常ErrorException 都继承自 Throwable,因此您可以捕获它:

catch (Throwable t)
{
// This will catch NoClassDefFoundError
}

我相信它找不到 MySqlDataSource,而是它所依赖的类或接口(interface)之一 - 在我的例子中是 javax.naming.Referenceable。 Android 不提供 javax.naming 包,因此尝试使用 MySQL 的 Connector/J JDBC 驱动程序的池功能不会让你走得太远(你可以尝试提供缺失的依赖关系,但这条路可能会导致疯狂)。

相反,您可能会更幸运地使用第三方连接池实现。有各种 Java 库可以执行此操作。其中一些将在 Android 上运行。我已经验证确实有效的一个是 HikariCP .有配置说明here并且,专门针对 MySQL,here .

关于android - 在 android 中建立到 MySQL 的池连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10565491/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com