在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.

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

android怎么会无法连接远程数据库,JDBC不就是用来连接远程数据库的吗?
而且阿里云数据库已经提供了接口,只要Android客户端通过这个接口连接到服务器就行了,不需要服务器吧?

我也是出现了这个问题,刚开始使用的是mysql-connector-java版本为8.0.XX.后面更改了mysql-connector-java-5.1.30就可以了。

https://blog.csdn.net/lkp1603645756/article/details/80259912

android无法连接远程数据库,正常做法是,服务器单独写一个接口,服务器里面连接数据库丢到云上,提供接口给android,android调用服务器的接口拿远程数据库的数据

一个正常的流程是,android写界面和逻辑,数据获取通过服务器接口,服务器写连接数据库,操作数据库并向android提供接口,所以需要懂android和服务器后台的