經過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表的結果。
至此,大功告成。