Android连接mysql数据库,实现下拉刷新(简易新闻 三)
关于之前的功能实现可以从制作简易新闻App导航篇中查看
首先看一下效果:

采用swipeRefreshLayout,mysql数据库来实现下拉刷新并通过Handler发送消息加载本地数据到界面上,本篇实现的功能有:
1. 建立新闻数据库表,下拉刷新
2. 在聚合数据访问了100次每天免费次数后,加载本地数据内容到主界面
3. 在点击子item新闻时,将新闻json数据插入到new_info表中
关于新闻json的解析与展示和界面搭建请看上一篇:
项目结构:

使用版本
数据库 MySQL 5.7
编辑器 Android Studio 3.2
MySQL 驱动 5.1.47
实现过程第一步,导入jar包
下载MySQL Connector/J » 5.1.47版本,如图所示:

将下载好的jia包复制到项目的libs目录下,然后点击jar包,在选项中选择Add as Library,当build完成后,表示驱动已经安装完成。

第二步,建立MySql数据库表
1. 下载MySql数据库
2.下载安装HeidiSQL
**3.**建表
打开HeidiSQL,如图所示你可以设置自己的用户名与密码:

打开后选择新建库,这里我新建一个user数据库,然后新建一个news_info的表,字段属性设置如下:

,到这里关于外部数据库的部署已经解决。
注意,如果数据库不是部署在云服务器上而是装在本地电脑上时,在第三步中连接数据库帮助类中的url IP地址需要是你主机网络v4地址,且电脑和手机处于同一个网络中,每次变化网络都需要调整一下
查看个人ip地址,在电脑中输入cmd进入命令行中,输入ipconfig,查看ip地址:

第三步新建数据库连接帮助类DBOpenHelper类
在java/com.example,frametest/下新建一个tools文件夹,在文件夹内新建一个DBOpenHelper类
package com.example.frametest.tools;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
public class DBOpenHelper {
private static String driver = "com.mysql.jdbc.Driver"; //MySql驱动
private static String url = "jdbc:mysql://192.168.1.121:3306/user?characterEncoding=utf-8"; //MySql数据库连接url
private static String user = "liu"; //用户名
private static String paswword = "031122"; //密码
/*连接数据库*/
public static Connection getConn(){
Connection conn = null;
try {
Class.forName(driver);
conn = (Connection) DriverManager.getConnection(url,user,paswword); //获取连接
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}
return conn;
}
}
第四步修改NewsFragment.class类
在下拉刷新的监听事件中新建一个线程,在Thread中,连接数据库查询new_info表,每次下拉刷新时进行page自增,然后查询进行翻页每页10条新闻数据,这里还解决了访问次数上限的数据问题。
package com.example.frametest;
import android.annotation.SuppressLint;
import android.content.Intent;
import android.os.AsyncTask;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.support.annotation.NonNull;
import android.support.annotation.Nullable;
import android.support.design.widget.FloatingActionButton;
import android.support.v4.app.Fragment;
import android.support.v4.widget.SwipeRefreshLayout;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.ListView;
import com.example.frametest.json.NewsBean;
import com.example.frametest.TabAdapter.MyTabAdapter;
import com.example.frametest.tools.DBOpenHelper;
import com.google.gson.Gson;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.ProtocolException;
import java.net.URL;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
public class NewsFragment extends Fragment {
private FloatingActionButton fab;
private ListView listView;
private SwipeRefreshLayout swipeRefreshLayout;
private List<NewsBean.ResultBean.DataBean> list;
private static final int UPNEWS_INSERT = 0;
private int page =0,row =10;
private static final int SELECT_REFLSH = 1;
@

最低0.47元/天 解锁文章
1700





