Android Studio 通过 JDBC 访问 MYSQL

问题描述 投票:0回答:3

我已经尝试使用 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 mysql jdbc
3个回答
0
投票

这不是客户的错。 您的 Android 设备 IP 是 192.168.56.101。 MySQL服务器root账户默认可以通过localhost访问。 您应该更改 root 访问权限或在 MySQL 中创建另一个帐户。


0
投票

实际上有两个问题,一个来自MYSQL权限,不允许我访问数据库,另一个问题是编码。 String result = (""); 的存在性在我的编码中是没有意义的,通过将其从代码连接中删除,就没有问题了。这里出现的问题是如何使我的编码具有自动更新,意味着通过将任何新数据输入我的数据库,它也会自动出现在我的应用程序中,任何自动更新的想法......


0
投票

在 MySQL 中,为应用程序创建一个用户,范围为“%”,例如

创建由“密码”标识的用户“androidapp”@“%”;

这意味着,它可以从任何地方“%”登录,如果您仅使用“localhost”,则可以

© www.soinside.com 2019 - 2024. All rights reserved.