Android Studio连接mysql数据库方法
采用配置:
Android Studio北极狐 Lollipop版模拟器 Navicat15 mysql5.7.27 mysql-connector-java-5.1.38.jar
mysql下载地址
MySQL :: Download MySQL Community Server (Archived Versions)
选择:
Windows (x86, 64-bit), ZIP Archive |
1、下载后解压,放在自己喜欢的文件,将bin包加入环境配置的PATH路径即可。
2、管理员方式打开cmd,导入bin包所在目录,使用指令mysqld -install。(下载数据库)
3、使用指令mysqld -initialize。(初始化数据库)
4、回到bin上一级文件夹,发现多了几个文件夹,其中有一个data文件夹,点开进入,找到err结尾的文件,一个个用记事本打开,找到A temporary password is generated for root@localhost:,后面是你的mysql初始密码
5、管理员打开cmd,输入net start mysql,启动数据库,输入mysql -uroot -p密码 password 新密码
6、输入mysql -uroot -p新密码,做验证,验证成功则mysql配置完成(还有一步远程配置,留在Navicat中配置)
Navicat下载地址
https://pan.百度.com/s/1Xn_ddT8v3RgAihROPFcq_A?pwd=phu5
下载后按照提示配置即可,记得断网。
配置完后
1、点开连接-新建连接-mysql,连接名随便取,密码为数据库密码,输入完成后,双击左侧连接,绿了说明连接成功。
2、点击上方的“用户”,双击root@localhost,将主机从localhost改为%。(这一步如果单机应该可以省略)。
3、打开cmd,输入ipconfig,找到自己的iPv4地址,在Navicat中点开连接-新建连接-mysql,连接名随便取,密码为数据库密码,主机改为自己的iPv4地址。
下载mysql-connector-java-5.1.38.jar
https://mvnrepository.com/artifact/mysql/mysql-connector-java/5.1.38
找到Files栏下载jar即可
配置Android Studio
1、打开项目,导入jar包,将下载的jar包放入项目/app/libs内,右键,点击Add As Library。
2、配置环境,在AndroidManifest.xml中加入
<uses-permission android:name="android.permission.INTERNET" />
3、 编写类,一共要编写三个类:JDBCUtils、User、UserDao。JDBCUtils用于连接数据库,User是信息存储类,UserDao是数据库与前端交互类。
编写类
JDBCUtils类:
-
package utils;
-
-
import android.util.Log;
-
-
import java.sql.Connection;
-
import java.sql.DriverManager;
-
import java.sql.SQLException;
-
-
public class JDBCUtils {
-
private static final String TAG = "mysql11111";
-
static {
-
-
try {
-
Class.forName("com.mysql.jdbc.Driver");
-
Log.v(TAG, "加载JDBC驱动成功");
-
} catch (ClassNotFoundException e) {
-
Log.e(TAG, "加载JDBC驱动失败");
-
e.printStackTrace();
-
}
-
-
}
-
-
public static Connection getConn() {
-
Connection conn = null;
-
try {
-
conn= DriverManager.getConnection("jdbc:mysql://10.0.2.2:3306/lls?useUnicode=true&characterEncoding=utf-8&useSSL=false","root","123456");
-
Log.d(TAG, "数据库连接成功");
-
}catch (Exception exception){
-
Log.d(TAG, "数据库连接失败");
-
exception.printStackTrace();
-
}
-
return conn;
-
}
-
-
public static void close(Connection conn){
-
try {
-
conn.close();
-
} catch (SQLException throwables) {
-
throwables.printStackTrace();
-
}
-
}
-
-
}
后续如果出现问题可以单击下方Logcat,点击搜索框,输入设定的TAG(此处设定为mysql111111),查看驱动是否成功,连接是否成功。
上面的static是进行驱动。getConn函数是获取一个连接,如果连接失败了,返回的conn就是个空。
getConnection函数内10.0.2.2:3306/后的是数据库名,此处需要在Navicat中,打开自己的连接后,右键连接,创建数据库。后续的两个变量是用户名和密码。
close函数是关闭数据库。
User类:
-
package entity;
-
-
public class User {
-
-
private int id;
-
private String name;
-
private int age;
-
private String password;
-
private String phone_number;
-
private String address;
-
-
public User(){
-
}
-
-
public User(int id,String name,int age,String password,String phone_number,String address){
-
this.id=id;
-
this.name=name;
-
this.age=age;
-
this.password=password;
-
this.phone_number=phone_number;
-
this.address=address;
-
}
-
-
public int getId(){
-
return id;
-
}
-
public void setId(int id){
-
this.id=id;
-
}
-
-
public String getName(){
-
return name;
-
}
-
public void setName(String name){
-
this.name=name;
-
}
-
-
public int getAge(){
-
return age;
-
}
-
public void setAge(int age){
-
this.age=age;
-
}
-
-
public String getPassword(){
-
return password;
-
}
-
public void setPassword(String password){
-
this.password=password;
-
}
-
-
public String getPhone_number(){
-
return phone_number;
-
}
-
public void setPhone_number(String phone_number){
-
this.phone_number=phone_number;
-
}
-
-
public String getAddress(){
-
return address;
-
}
-
public void setAddress(String address){
-
this.address=address;
-
}
-
}
非常明显,就是一个存储用户信息类,没什么好说的。
UserDao:
-
package dao;
-
-
import entity.User;
-
import utils.JDBCUtils;
-
-
import java.sql.Connection;
-
import java.sql.PreparedStatement;
-
import java.sql.ResultSet;
-
import java.sql.SQLException;
-
-
public class UserDao {
-
public boolean login(String phone_number,String password){
-
-
String sql = "select * from users where phone_number = ? and password = ?";
-
-
Connection con = JDBCUtils.getConn();
-
-
try {
-
PreparedStatement pst=con.prepareStatement(sql);
-
-
pst.setString(1,phone_number);
-
pst.setString(2,password);
-
-
if(pst.executeQuery().next()){
-
-
return true;
-
-
}
-
-
} catch (SQLException throwables) {
-
throwables.printStackTrace();
-
}finally {
-
JDBCUtils.close(con);
-
}
-
-
return false;
-
}
-
-
public User findUser(String name){
-
-
String sql = "select * from users where name = ?";
-
-
Connection con = JDBCUtils.getConn();
-
User user = null;
-
try {
-
PreparedStatement pst=con.prepareStatement(sql);
-
-
pst.setString(1,name);
-
-
ResultSet rs = pst.executeQuery();
-
-
while (rs.next()){
-
-
int id = rs.getInt(0);
-
String namedb = rs.getString(1);
-
int age = rs.getInt(2);
-
String passworddb = rs.getString(3);
-
String phone_number = rs.getString(4);
-
String address = rs.getString(5);
-
user = new User(id,namedb,age,passworddb,phone_number,address);
-
}
-
-
} catch (SQLException throwables) {
-
throwables.printStackTrace();
-
}finally {
-
JDBCUtils.close(con);
-
}
-
-
return user;
-
}
-
public User findPhone_number(String phone_number){
-
-
String sql = "select * from users where phone_number = ?";
-
-
Connection con = JDBCUtils.getConn();
-
User user = null;
-
try {
-
PreparedStatement pst=con.prepareStatement(sql);
-
-
pst.setString(1,phone_number);
-
-
ResultSet rs = pst.executeQuery();
-
-
while (rs.next()){
-
-
int id = rs.getInt(0);
-
String namedb = rs.getString(1);
-
int age = rs.getInt(2);
-
String passworddb = rs.getString(3);
-
String phone_numberdb = rs.getString(4);
-
String address = rs.getString(5);
-
user = new User(id,namedb,age,passworddb,phone_numberdb,address);
-
}
-
-
} catch (SQLException throwables) {
-
throwables.printStackTrace();
-
}finally {
-
JDBCUtils.close(con);
-
}
-
-
return user;
-
}
-
}
可以稍微学一下语法,这里主要用到sql语句,设计的函数就算最基本的用于我们的页面搭建中的login、findUser等函数了。页面搭建的过程中也只需要调用这个类中的这几个函数即可。
这篇好文章是转载于:学新通技术网
- 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
- 本站站名: 学新通技术网
- 本文地址: /boutique/detail/tanhgcijag
-
photoshop保存的图片太大微信发不了怎么办
PHP中文网 06-15 -
Android 11 保存文件到外部存储,并分享文件
Luke 10-12 -
《学习通》视频自动暂停处理方法
HelloWorld317 07-05 -
word里面弄一个表格后上面的标题会跑到下面怎么办
PHP中文网 06-20 -
photoshop扩展功能面板显示灰色怎么办
PHP中文网 06-14 -
微信公众号没有声音提示怎么办
PHP中文网 03-31 -
excel下划线不显示怎么办
PHP中文网 06-23 -
怎样阻止微信小程序自动打开
PHP中文网 06-13 -
excel打印预览压线压字怎么办
PHP中文网 06-22 -
TikTok加速器哪个好免费的TK加速器推荐
TK小达人 10-01