我已经尝试使用 JDBC 连接到 MYSQL 一段时间了,但没有成功。 我已经设置了数据库,其中包含一些信息,并且在 libs 文件夹中添加了 mysql-connector-java-5.1.35-bin 库。访问互联网和网络的权限也被添加到清单中。我在 Windows 7 中运行 Android Studio。到目前为止运行后没有语法错误,但在我的模拟器中,我收到以下消息:
测试错误:java.sql.SQLException:用户“root”@“192.168.56.101”访问被拒绝(使用密码:NO)
我的工作哪一部分是错误的?!我在下面附上了我的代码。
public class MainActivity extends Activity {
//private static final String url = "jdbc:mysql://<server>:<port>/<database>";
public static final String LISTEN_ACTIVITY = "listenActivity";
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
testDB();
}
public void testDB() {
TextView tv = (TextView)this.findViewById(R.id.txtv);
try {
Class.forName("com.mysql.jdbc.Driver").newInstance();
Log.i("Android", " MySQL Connection ok");
Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/k_sql1", "root", "");
// System.out.println("Database connection success");
Log.d("Android2","Line 2");
String result = ("");
Log.d("Android3", " Line 3");
Statement st = con.createStatement();
ResultSet rs = st.executeQuery("select * from kpeople");
ResultSetMetaData rsmd = rs.getMetaData();
while (rs.next()) {
result += rsmd.getColumnName(1) + ": " + rs.getInt(1) + "\n";
result += rsmd.getColumnName(2) + ": " + rs.getString(2) + "\n";
result += rsmd.getColumnName(3) + ": " + rs.getString(3) + "\n";
}
tv.setText(result);
} catch (Exception e) {
e.printStackTrace();
tv.setText("Test Error:"+e.toString());
Log.w("Android-system","system get connection");
}
}
}
这里有很多专家,请帮忙解决问题。谢谢你们。
这不是客户的错。 您的 Android 设备 IP 是 192.168.56.101。 MySQL服务器root账户默认可以通过localhost访问。 您应该更改 root 访问权限或在 MySQL 中创建另一个帐户。
实际上有两个问题,一个来自MYSQL权限,不允许我访问数据库,另一个问题是编码。 String result = (""); 的存在性在我的编码中是没有意义的,通过将其从代码连接中删除,就没有问题了。这里出现的问题是如何使我的编码具有自动更新,意味着通过将任何新数据输入我的数据库,它也会自动出现在我的应用程序中,任何自动更新的想法......
在 MySQL 中,为应用程序创建一个用户,范围为“%”,例如
创建由“密码”标识的用户“androidapp”@“%”;
这意味着,它可以从任何地方“%”登录,如果您仅使用“localhost”,则可以