qq_43075916 2018-11-28 02:34 采纳率: 100%
浏览 4554
已采纳

在Android Studio中,用jdbc连接MySQL连不上

网上的很多方法都试过,还是不行,各位大神帮我看下什么原因。
目前排除的原因:
1.在单元测试中可以连接成功,并获得数据。所以数据库、连接格式应该没问题。
2.connect-java包试了好几个版本都不行。
3.在Activity中连接不上,但我已经放在新的线程中了,而且用好几种开启新线程的方式试过。

以下是代码

        public class MainActivity extends AppCompatActivity {
    private Connection conn;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        new Thread(){
            @Override
            public void run() {
                try {
                    Class.forName("com.mysql.jdbc.Driver");
                    conn = DriverManager.getConnection("jdbc:mysql://rm-bp1p408m8ey1z7ndv4o.mysql.rds.aliyuncs.com/mysql_data", "myroot", "Kwkx12345678");
                    System.err.println(conn);
                } catch (ClassNotFoundException e) {
                    e.printStackTrace();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
        }.start();
    }
}

Locat输出:
图片说明
错误提示,百度上搜了一下也没有
Caused by: java.lang.ClassNotFoundException: Didn't find class "java.sql.SQLType" on path: DexPathList[[zip file "/data/app/com.example.administrator.

  • 写回答

5条回答 默认 最新

  • 阳光纯粹 2018-11-30 09:43
    关注

    Android里已经内置了SQLlite数据库了,不需要再连接mysql了,而且Android的流行数据库框litepal也是基于SQLite数据库封装的,当然也可以连接mysql,你单元测试成功连接是因为Java的情况下,activity里开线程是获取不到的

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

悬赏问题

  • ¥15 飞机曲面部件如机翼,壁板等具体的孔位模型
  • ¥15 vs2019中数据导出问题
  • ¥20 云服务Linux系统TCP-MSS值修改?
  • ¥20 关于#单片机#的问题:项目:使用模拟iic与ov2640通讯环境:F407问题:读取的ID号总是0xff,自己调了调发现在读从机数据时,SDA线上并未有信号变化(语言-c语言)
  • ¥20 怎么在stm32门禁成品上增加查询记录功能
  • ¥15 Source insight编写代码后使用CCS5.2版本import之后,代码跳到注释行里面
  • ¥50 NT4.0系统 STOP:0X0000007B
  • ¥15 想问一下stata17中这段代码哪里有问题呀
  • ¥15 flink cdc无法实时同步mysql数据
  • ¥100 有人会搭建GPT-J-6B框架吗?有偿