1
首先在云服务器上安装mysql,这一步就不讲了。安装完成后,需要修改防火墙开放mysql端口。然后就是授权root远程登陆,进入mysql后输入以下命令:GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION;
,其中的123456将用于安卓访问的密码,输入以上命令后,需要输入flush privileges;
,立即执行生效。然后就是检查是否设置成功:
2
com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: Communication link failure, message from server: “Can’t get hostname for your address”
如果出现以上错误,我的解决办法是去/etc/my.cnf的文件里在
[mysqld]下添加
skip-name-resolve
然后保存,重启service mysqld restart
。此方法不一定对所有的问题都好用。
3
然后就是安卓端,需要在libs目录下添加一个mysql-connector-java的包,自行下载然后复制到那个目录,然后右击那个包点击add as library
。然后添加网络权限<uses-permission android:name="android.permission.INTERNET" />
。
然后就是简单的代码部分:
package com.example.myapplication;
import androidx.appcompat.app.AppCompatActivity;
import android.nfc.Tag;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class MainActivity extends AppCompatActivity {
private Button btn;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
btn = findViewById(R.id.button);
editText = findViewById(R.id.editTextTextPersonName);
te=findViewById(R.id.textView);
btn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
new Thread(new Runnable() {
@Override
public void run() {
try {
Class.forName("com.mysql.jdbc.Driver");
String url = "jdbc:mysql://服务器ip:3306/数据库名字?useUnicode=true&characterEncoding=utf-8";
String name = "root";
String passwd = "密码";
Connection connection = DriverManager.getConnection(url, name, passwd);
if (!connection.isClosed()) {
System.out.println("yes");
}
Statement statement = connection.createStatement();
String sql = "select * from test;";//我的表格叫test
ResultSet resultSet = statement.executeQuery(sql);
String nae;
while (resultSet.next()) {
nae = resultSet.getString("name");
System.out.println(nae);
}
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}
}
}).start();
}
});
}
}
这个就是对我在数据库上建的test这个表的name这一列查询并输出。