Android直连MySQL数据库
记录直连MySQL数据库中所出现的情况
-
首先导入mysql-connector-java-xx.jar包,一开始我使用的是和本机MySQL数据库相同的8.0.11的版本
-
数据库的连接
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","数据库连接失败"); } } }
-
在MainActivity中代码
public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); DBConnection dbConnection = new DBConnection(); } }
-
到这里按逻辑来说运行就可以连接数据库并在窗口打印song数据库中的信息,但是出现第一个问题是数据库无法连接
-
检查问题,发现没有添加网络权限,加上
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> <uses-permission android:name="android.permission.INTERNET" />
-
还是不能连接,网上查了一下,网络访问不能在主线程,所以修改MainActivity中代码,为数据库连接新开一个线程
new Thread(() -> { DBConnection dbConnection = new DBConnection(); }).start();
-
这时还是无法连接,出现问题如下
java.lang.NoClassDefFoundError: Failed resolution of: Ljava/sql/SQLType
原因是SDK不支持该类,或者是jar包中不存在该类,如上我使用的是8.0.11,然后换成5.1.49版本,同时修改代码
Class.forName("com.mysql.jdbc.Driver");
-
这时在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服务
-
至此真机已经可以连接到数据库了
https://blog.youkuaiyun.com/wlwh90/article/details/45152287