设为首页 收藏本站
查看: 1230|回复: 0

[经验分享] android开发 如何通过web服务器访问MYSQL数据库并且使其数据同步到android SQLite数据库?

[复制链接]

尚未签到

发表于 2015-6-24 15:35:47 | 显示全部楼层 |阅读模式
  通过web服务器访问MYSQL数据库有以下几个过程:
  1、在MySql下创建自己的数据库和自己的表单
  2、连接数据库。
  3、访问数据库
  
  1、创建web工程 (服务器端)
  在Myeclipse下新建一个web项目,为了好统一管理在WEB-INF下建一个web.xml用来加载服务器启动时的配置信息。这个文件是由大量的与组成,这里只做讲解,
  web.xml实例如下:



1
2
6     
7     
8         LoginServlet
9         com.amaker.servlet.LoginServlet
10     
11     
12     
13         UpdateMenuServlet
14         /servlet/UpdateMenuServlet
15     
  
  2、为了方便对数据库验证信息的统一管理,在src目录下建一个DBConfig.properties文件。包含内容有:连接mysql数据库的驱动、url、用户名和密码。



1 driver=com.mysql.jdbc.Driver
2 url=jdbc:mysql://localhost:3306/wirelessorder_db?useUnicode=true&characterEncoding=utf-8
3 username=rootpassword=123
  
  3、连接数据库
  a、可以先在src目录下建一个工具类DBUtil.java用于连接和关闭数据库。具体代码如下。



1 package com.amaker.util;
2
3 import java.sql.Connection;
4 import java.sql.DriverManager;
5 import java.sql.SQLException;
6 import java.util.Properties;
7
8 /**
9  *
10  * @author BlackhorseMary
11 */
12 public class DBUtil {
13     
14     /*
15      * 关闭数据库连接
16      */
17     public void closeConn(Connection conn){
18         try {
19             conn.close();
20         } catch (SQLException e) {
21             e.printStackTrace();
22         }
23     }
24     
25     /*
26      * 打开数据库连接
27      */
28     public Connection openConnection() {
29         Properties prop = new Properties();
30         String driver = null;
31         String url = null;
32         String username = null;
33         String password = null;
34
35         try {
36             prop.load(this.getClass().getClassLoader().getResourceAsStream(
37                     "DBConfig.properties"));
38
39             driver = prop.getProperty("driver");
40             url = prop.getProperty("url");
41             username = prop.getProperty("username");
42             password = prop.getProperty("password");
43            
44             Class.forName(driver);
45             return DriverManager.getConnection(url, username, password);
46         } catch (Exception e) {
47             e.printStackTrace();
48         }
49
50         return null;
51     }
52
53 }
  
b、再在src目录下新建一个Menu.java,用于设置获取其属性。



1 package com.amaker.entity;
2
3 public class Menu {
4     private int id;
5     private int price;
6     private int typeId;
7     private String name;
8     private String pic;
9     private String remark;
10     
11     public int getId() {
12         return id;
13     }
14     public void setId(int id) {
15         this.id = id;
16     }
17     public String getName() {
18         return name;
19     }
20     public void setName(String name) {
21         this.name = name;
22     }
23     public String getPic() {
24         return pic;
25     }
26     public void setPic(String pic) {
27         this.pic = pic;
28     }
29     public int getPrice() {
30         return price;
31     }
32     public void setPrice(int price) {
33         this.price = price;
34     }
35     public String getRemark() {
36         return remark;
37     }
38     public void setRemark(String remark) {
39         this.remark = remark;
40     }
41     public int getTypeId() {
42         return typeId;
43     }
44     public void setTypeId(int typeId) {
45         this.typeId = typeId;
46     }
47     
48 }


1 /**
2  * @author BlackhorseMary
3  *    完成更新SQLite数据功能
4  */
5 public class Update {
6     // 获得菜单列表
7     public List getMenuList() {
8         // 查询SQL语句
9         String sql =" select id,typeId,price,name,pic,remark from MenuTbl ";
10         // 数据库连接工具类
11         DBUtil util = new DBUtil();
12         // 获得连接
13         Connection conn = util.openConnection();
14         try {
15             // 获得预定义语句
16             Statement pstmt = conn.createStatement();
17             // 执行查询
18             ResultSet rs = pstmt.executeQuery(sql);
19             // 判断订单详细
20             List list = new ArrayList();
21             while (rs.next()) {
22                 // 获得菜单信息
23                 
24                 int id = rs.getInt(1);
25                 int typeId = rs.getInt(2);
26                 int price = rs.getInt(3);
27                 String name = rs.getString(4);
28                 String pic = rs.getString(5);
29                 String remark = rs.getString(6);
30                 
31                 Menu m = new Menu();
32                 m.setId(id);
33                 m.setName(name);
34                 m.setPic(pic);
35                 m.setPrice(price);
36                 m.setRemark(remark);
37                 m.setTypeId(typeId);
38                 
39                 list.add(m);
40             }
41             return list;
42         } catch (SQLException e) {
43             e.printStackTrace();
44         } finally {
45             util.closeConn(conn);
46         }
47         return null;
48     }
49     
50 }
  
  4、在src下建一个update.java类用于执行同步,即更新android SQLites数据库中的数据(前提是SQLite数据库里面有对应的Menu表)。




  5、启动服务器,在浏览器中输入相应URL地址,可以把相应的SQLITE数据库导出来,用SQLITE数据库工具,查看数据库中Menu表的结果。
  至此,大功告成。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-80229-1-1.html 上篇帖子: 将Mysql转为Sqlite(原理加工具实现) 下篇帖子: Entity Framework:第三方开发MySQL,Oracle,SQLite ADO.NET Provider支持Entity Framework
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表