Java子线程结束后返回信息给主线程(安卓中使用云数据库返回数据)

项目需求:安卓要求连接云数据库必须重开一个子线程,于是涉及到子线程中查询数据的返回。
代码:

private void findCourse() {
    Thread thread = new Thread(new Runnable() {
        @Override
        public void run() {
            MySQLUtil mySQLUtil = new MySQLUtil();
            mySQLUtil.getConnection("cce-18");
            course = mySQLUtil.getCourseName("course_info_2018_2019");
        }
    });
    thread.start();
    try {
        thread.join();
    } catch (InterruptedException e) {
        e.printStackTrace();
    }
}

  在findCourse中,我们新开了一个子线程,其中course是我们需要返回的数据。如果我们正常运行会发现:在我们需要使用course时它还是一个null,因为主线程同时也在进行,子线程还没运行到对course初始化这句话时,我们就在使用course了,因此我们必须等子线程运行结束course有值之后才继续运行主线程。有两个解决办法:

  1. sleep函数。这种方法不推荐,因为我们并不知道子线程什么时候结束,延时太久的话是对资源的一种浪费。
  2. join()函数。join()是等待调用此方法的线程结束。
Android开发可以通过jtds直接连接SQL Server进行读写操作。以下是连接SQL Server数据库的步骤: 1.在项目的build.gradle文件添加以下依赖项: ```gradle implementation 'net.sourceforge.jtds:jtds:1.3.1' ``` 2.在代码使用以下语句加载jtds驱动程序: ```java Class.forName("net.sourceforge.jtds.jdbc.Driver"); ``` 3.使用以下代码连接到SQL Server数据库: ```java String url = "jdbc:jtds:sqlserver://服务器IP:端口号/数据库名称;instance=实例名"; Connection conn = DriverManager.getConnection(url, "用户名", "密码"); ``` 4.连接成功后,可以使用以下代码执行SQL查询并获取结果: ```java Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery("SELECT * FROM 表名"); while (rs.next()) { // 处理查询结果 } ``` 需要注意的是,网络访问以及特别耗时的操作不能放在线程进行,需要创建一个线程或者一个异步任务来执行。可以使用AsyncTask来实现异步任务,以下是一个使用AsyncTask连接SQL Server数据库并执行查询的例: ```java public class MySQLConnectAsyncTask extends AsyncTask<Void, Void, String> { @Override protected String doInBackground(Void... voids) { try { Class.forName("net.sourceforge.jtds.jdbc.Driver"); String url = "jdbc:jtds:sqlserver://服务器IP:端口号/数据库名称;instance=实例名"; Connection conn = DriverManager.getConnection(url, "用户名", "密码"); Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery("SELECT * FROM 表名"); StringBuilder sb = new StringBuilder(); while (rs.next()) { sb.append(rs.getString("列名")).append("\n"); } rs.close(); stmt.close(); conn.close(); return sb.toString(); } catch (Exception e) { e.printStackTrace(); return "连接数据库失败:" + e.getMessage(); } } @Override protected void onPostExecute(String s) { tvContent.setText(s); } } ``` 可以在Activity调用该异步任务来连接SQL Server数据库并执行查询: ```java new MySQLConnectAsyncTask().execute(); ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Cyril_KI

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值