android開發 如何經過web服務器訪問MYSQL數據庫而且使其數據同步到android SQLite數據庫?

經過web服務器訪問MYSQL數據庫有如下幾個過程:java

一、在MySql下建立本身的數據庫和本身的表單mysql

二、鏈接數據庫。android

三、訪問數據庫web

 

一、建立web工程 (服務器端)sql

  在Myeclipse下新建一個web項目,爲了好統一管理在WEB-INF下建一個web.xml用來加載服務器啓動時的配置信息。這個文件是由大量的<servlet></servlet>與<servlet-mapping></servlet-mapping>組成,這裏只作講解,數據庫

web.xml實例以下:瀏覽器

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

 

二、爲了方便對數據庫驗證信息的統一管理,在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

 

三、鏈接數據庫app

a、能夠先在src目錄下建一個工具類DBUtil.java用於鏈接和關閉數據庫。具體代碼以下。less

 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<Menu> 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<Menu> list = new ArrayList<Menu>();
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 }

 

四、在src下建一個update.java類用於執行同步,即更新android SQLites數據庫中的數據(前提是SQLite數據庫裏面有對應的Menu表)。

 

五、啓動服務器,在瀏覽器中輸入相應URL地址,能夠把相應的SQLITE數據庫導出來,用SQLITE數據庫工具,查看數據庫中Menu表的結果。 

至此,大功告成。

相關文章
相關標籤/搜索