Android Studio中实现mysql连接

在Android Studio编译器中实现Mysql连接

  1. Mysql要开启远程连接
    可以在cmd中输入开启mysql远程连接的命令
    具体方法如图具体方法链接

2.在Android studio中的libs中添加mysql.jar和mysql-connector-java-xxxx.jar两个架包,mysql-connector-java-xxxx-jar包中xxxx为版本号,具体自己mysql是什么版本的就添加什么版本的。我的mysql是8.0.19版本,所以我用的是mysql-connector-java-8.0.19.jar.添加后需要记得一定要Add As Library…,这是常识。
在这里插入图片描述

在这里插入图片描述
3.弄完这些我们开始写mysql连接代码了
我是从其他csdn中直接copy过来的`public class TestDAO {

protected static final String DBDRIVER = "com.mysql.cj.jdbc.Driver";
protected static final String DBURL = "jdbc:mysql://ip地址:端口号/数据库?useSSL=false&serverTimezone=UTC&characterEncoding=utf8";
protected static final String DBUSER = "用户名";
protected static final String DBPASSWORD = "密码";

private static final String TAG=TestDAO.class.getSimpleName();

public static boolean linkMysql(){
    Connection c=null;
    try{
        Class.forName(DBDRIVER);
        Log.e(TAG, "驱动加载成功" );
    }catch (Exception e){
        Log.e(TAG,"驱动加载失败\n"+e.toString() );
        return false;
    }

    try{
        c= DriverManager.getConnection(DBURL,DBUSER,DBPASSWORD);
        String sql = "select * from student where stu_id=?";
        PreparedStatement pst=c.prepareStatement(sql);
        pst.setString(1,"1810301116");
        ResultSet rs=pst.executeQuery();
        if(rs.next()){
            Log.e(TAG, rs.getString("stu_name") );
        }
        rs.close();
        pst.close();
        c.close();
        return true;
    } catch (SQLException e) {
        Log.e(TAG, "Mysql连接失败"+e.toString());
       e.printStackTrace();

        return false;
    }
    finally {
        if(c!=null){

            try {
                c.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }

}

}`

Android 访问mysql与web访问mysql有点区别,Android 访问mysql时不能在主线程中直接访问,需要新创建一个线程访问
在MainActivity中代码如下

public class MainActivity extends AppCompatActivity implements View.OnClickListener {

    private TextView mTextView;
    private Button mButton;
    private String TAG=MainActivity.class.getSimpleName();

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        initView();
    }

    private void initView() {
        mTextView = (TextView) findViewById(R.id.textView);
        mButton = (Button) findViewById(R.id.button);

        mButton.setOnClickListener(this);
    }

    @Override
    public void onClick(View v) {
        switch (v.getId()) {
            case R.id.button:
                new Thread(new Runnable() {
                    @Override
                    public void run() {
                        TestDAO.linkMysql();
                    }
                }).start();
                break;
        }
    }
}

在AndroidManifest中不要忘了添加网络访问权限
在这里插入图片描述
这些步骤是基本步骤,做完这些后你还可能遇到一些问题如:
在这里插入图片描述
你需要在对应module中的build.gradle中添加

 compileOptions {
        sourceCompatibility JavaVersion.VERSION_1_8
        targetCompatibility JavaVersion.VERSION_1_8
    }

在这里插入图片描述
4.做完这些应该就可以连接上mysql了,然后可以获取mysql的数据库中的数据;
但是这些弄完后,你还有可能遇到其他问题,一定要耐心,小白我Android连接mysql花了一天多的时间。我在mysql开启远程连接这块一直卡死。最后还是请求大佬帮忙解决的。

注:小白第一次发csdn。

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值