Android直连MySQL数据库

本文详细介绍了如何在Android应用中直接连接MySQL数据库的过程,包括解决连接失败的问题、配置网络权限、处理多线程访问及授权等关键步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Android直连MySQL数据库

记录直连MySQL数据库中所出现的情况

  1. 首先导入mysql-connector-java-xx.jar包,一开始我使用的是和本机MySQL数据库相同的8.0.11的版本

  2. 数据库的连接

    public final class DBConnection {
        public DBConnection() {
    	//要连接的数据库url,注意:此处连接的应该是服务器上的MySQl的地址,我这使用本机上的WLAN地址,如果使用模拟器使用10.0.2.2
            String url = "jdbc:mysql://192.168.1.5:3306/song?serverTimezone=UTC&useSSL=false&allowPublicKeyRetrieval=true";        //连接数据库使用的用户名
            String userName = "root";
            //连接的数据库时使用的密码
            String password = "root";
    
            //1、加载驱动
            try {
                Class.forName("com.mysql.cj.jdbc.Driver");
            } catch (ClassNotFoundException e) {
                e.printStackTrace();
                Log.e("SQL","找不到jdbc");
            }
            //2、获取与数据库的连接
            Connection connection = null;
            ResultSet set = null;
            Statement statement = null;
            try {
                connection = DriverManager.getConnection(url, userName, password);
                //3、获取用于向数据库发送sql语句的statement
                statement = connection.createStatement();
                //sql语句
                String sql = "select * from songs";
                //4、向数据库发送sql,并获取代表结果集的resultSet
                set = statement.executeQuery(sql);
    
                //5、取出结果集的数据
                while (set.next()) {
                    System.out.println("id = " + set.getObject("id"));
                    System.out.println("name = " + set.getObject("name"));
                    System.out.println("singer = " + set.getObject("singer"));
                    System.out.println("picPath = " + set.getObject("picPath"));
                    System.out.println("songPath = " + set.getObject("songPath"));
                }
                //6、关闭连接,释放资源
                set.close();
                statement.close();
                connection.close();
            } catch (SQLException e) {
                e.printStackTrace();
                Log.e("SQL","数据库连接失败");
            }
    	}
    }
    
  3. 在MainActivity中代码

    public class MainActivity extends AppCompatActivity {
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
            DBConnection dbConnection = new DBConnection();
        }
    }
    
  4. 到这里按逻辑来说运行就可以连接数据库并在窗口打印song数据库中的信息,但是出现第一个问题是数据库无法连接

  5. 检查问题,发现没有添加网络权限,加上

    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.INTERNET" />
    
  6. 还是不能连接,网上查了一下,网络访问不能在主线程,所以修改MainActivity中代码,为数据库连接新开一个线程

    new Thread(() -> {
                DBConnection dbConnection = new DBConnection();
            }).start();
    
  7. 这时还是无法连接,出现问题如下

    java.lang.NoClassDefFoundError: Failed resolution of: Ljava/sql/SQLType
    

    原因是SDK不支持该类,或者是jar包中不存在该类,如上我使用的是8.0.11,然后换成5.1.49版本,同时修改代码

    Class.forName("com.mysql.jdbc.Driver");
    
  8. 这时在Android模拟器上已经可以连接上数据库了,但在真机上运行时出现问题,首先确认的是手机和电脑处在一个局域网内,也就是连接着同一个网络

    java.sql.SQLException: null, message from server: "Host '192.168.1.3' is not allowed to connect
    

    192.168.1.3应该是我手机的ip,也就是说我的手机不能连接电脑上的数据库,查了一下,一种方法是授权:参考博客https://blog.youkuaiyun.com/matengzz/article/details/40207459,另一种方法如下(我采用的是这个方法):

    https://www.cnblogs.com/mlh2019616/p/12335700.html)

    • 登录mysql
    • 输入use mysql;
    • 再输入select host,user from user;
    • 再输入update user set host =’%’ where user =‘root’;
    • 最后重新启动MySQL服务
  9. 至此真机已经可以连接到数据库了

https://blog.youkuaiyun.com/wlwh90/article/details/45152287

评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值