android 访问服务器mysql

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这一列查询并输出。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值