怎么通过web服务器访问MYSQL数据库,使其数据同步到android SQLite数据库?

      通过web服务器访问MYSQL数据库有以下几个过程:

1、创建MYSQL数据库,并建表(如:menu表)。

2、连接数据库。

3、访问数据库

 

     过程2、3 具体步骤:

1、在Myeclipse下新建一个web项目,为了好统一管理在WEB-INF下建一个web.xml用来加载服务器启动时的配置信息。这个文件是由大量的<servlet></servlet>与<servlet-mapping></servlet-mapping>组成,这里只做讲解,

web.xml实例如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<? xml version = "1.0" encoding = "UTF-8" ?>
< web-app version = "2.4" xmlns = "http://java.sun.com/xml/ns/j2ee"
     xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee 
      
     < servlet >
         < servlet-name >LoginServlet</ servlet-name >
         < servlet-class >com.amaker.servlet.LoginServlet</ servlet-class >
     </ servlet >
      
     < servlet-mapping >
         < servlet-name >UpdateMenuServlet</ servlet-name >
         < url-pattern >/servlet/UpdateMenuServlet</ url-pattern >
     </ servlet-mapping >


 

2、为了方便对数据库验证信息的统一管理,在src目录下建一个DBConfig.properties文件。包含内容有:连接mysql数据库的驱动、url、用户名和密码。

1
2
3
4
<SPAN style="FONT-SIZE: 18px">driver=com.mysql.jdbc.Driver
username=root
password=123</SPAN>

 

3、连接数据库:

      a、可以先在src目录下建一个工具类DBUtil.java用于连接和关闭数据库。具体代码如下。

1
2
3
4
5
6
7
8
9
10
package com.amaker.util;
  
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.Properties;
  
/**
 
  * @author BlackhorseMary
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
*/
public class DBUtil {
      
     /*
      * 关闭数据库连接
      */
     public void closeConn(Connection conn){
         try {
             conn.close();
         } catch (SQLException e) {
             e.printStackTrace();
         }
     }
      
     /*
      * 打开数据库连接
      */
     public Connection openConnection() {
         Properties prop = new Properties();
         String driver = null ;
         String url = null ;
         String username = null ;
         String password = null ;
  
         try {
             prop.load( this .getClass().getClassLoader().getResourceAsStream(
                     "DBConfig.properties" ));
  
             driver = prop.getProperty( "driver" );
             url = prop.getProperty( "url" );
             username = prop.getProperty( "username" );
             password = prop.getProperty( "password" );
              
             Class.forName(driver);
             return DriverManager.getConnection(url, username, password);
         } catch (Exception e) {
             e.printStackTrace();
         }
  
         return null ;
     }
  
}


   b、再在src目录下新建一个Menu.java,用于设置获取其属性。

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


4、在src下建一个update.java类用于执行同步,即更新android SQLites数据库中的数据(前提是SQLite数据库里面有对应的Menu表)。

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

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

至此,大功告成。

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值