精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

如何用Java實(shí)現(xiàn).NET中DataTable功能

開發(fā) 后端
前兩天實(shí)現(xiàn)了net中DataTable功能,雖說功能不是很強(qiáng)大,但是完全滿足了java中的多表查詢,帶來的編程風(fēng)格改變還是存在的。現(xiàn)在拿出來說下,和各位大哥探討下。

因?yàn)槲冶緛砭褪歉鉵et的,突然來了兩個(gè)項(xiàng)目就是要用java以及oracle,便從各種方向上尋求net的影子,便有了今天這些工具類。不知道好不好,bug測(cè)試了一下了,性能上也只有經(jīng)過項(xiàng)目來驗(yàn)證吧。其中一部分涉及到雙數(shù)據(jù)庫(kù)操作,所以也提了一種解決方案,寫的不好,大家看看吧!

我們先看效果,再說說怎么弄!

我們來試試如何用,我也寫了一個(gè)測(cè)試數(shù)據(jù)。

然后我們?cè)贘unit中測(cè)試:

  1. @Test 
  2. public void joinTable() { 
  3. JingZongDB jzdb=new JingZongDB(); 
  4. DataTable dt1=jzdb.getDataTable("select * from newsType"); 
  5. DataTable dt2=jzdb.getDataTable("select * from news"); 
  6. DataTable dt=DataTable.joinTable(dt1, dt2, "id""typeid"); 
  7. wl("新聞?lì)愋捅恚?quot;+dt1.getRow().size()); 
  8. DataTable.outTable(dt1); 
  9. wl("新聞表:"+dt2.getRow().size()); 
  10. DataTable.outTable(dt2); 
  11. wl("合并后:"+dt.getRow().size()); 
  12. DataTable.outTable(dt); 
  13. private void wl(String s) { 
  14. System.out.println(s); 
  15. }  

最后結(jié)果為:

  1. 新聞?lì)愋捅恚?/span>4 
  2. id:1 typeName:學(xué)生工作 
  3. id:2 typeName:通知公告 
  4. id:3 typeName:招生簡(jiǎn)章 
  5. id:4 typeName:教務(wù)信息 
  6. 新聞表:16 
  7. id:1 typeid:1 newsName:學(xué)生工作1 
  8. id:2 typeid:1 newsName:學(xué)生工作2 
  9. id:3 typeid:1 newsName:學(xué)生工作3 
  10. id:4 typeid:1 newsName:學(xué)生工作4 
  11. id:5 typeid:2 newsName:通知公告1 
  12. id:6 typeid:2 newsName:通知公告2 
  13. id:7 typeid:2 newsName:通知公告3 
  14. id:8 typeid:2 newsName:通知公告4 
  15. id:9 typeid:3 newsName:招生簡(jiǎn)章1 
  16. id:10 typeid:3 newsName:招生簡(jiǎn)章2 
  17. id:11 typeid:3 newsName:招生簡(jiǎn)章3 
  18. id:12 typeid:3 newsName:招生簡(jiǎn)章4 
  19. id:13 typeid:4 newsName:教務(wù)信息1 
  20. id:14 typeid:4 newsName:教務(wù)信息2 
  21. id:15 typeid:4 newsName:教務(wù)信息3 
  22. id:16 typeid:4 newsName:教務(wù)信息4 
  23. 合并后:16 
  24. id:1 typeName:學(xué)生工作 id:1 typeid:1 newsName:學(xué)生工作1 
  25. id:1 typeName:學(xué)生工作 id:2 typeid:1 newsName:學(xué)生工作2 
  26. id:1 typeName:學(xué)生工作 id:3 typeid:1 newsName:學(xué)生工作3 
  27. id:1 typeName:學(xué)生工作 id:4 typeid:1 newsName:學(xué)生工作4 
  28. id:2 typeName:通知公告 id:5 typeid:2 newsName:通知公告1 
  29. id:2 typeName:通知公告 id:6 typeid:2 newsName:通知公告2 
  30. id:2 typeName:通知公告 id:7 typeid:2 newsName:通知公告3 
  31. id:2 typeName:通知公告 id:8 typeid:2 newsName:通知公告4 
  32. id:3 typeName:招生簡(jiǎn)章 id:9 typeid:3 newsName:招生簡(jiǎn)章1 
  33. id:3 typeName:招生簡(jiǎn)章 id:10 typeid:3 newsName:招生簡(jiǎn)章2 
  34. id:3 typeName:招生簡(jiǎn)章 id:11 typeid:3 newsName:招生簡(jiǎn)章3 
  35. id:3 typeName:招生簡(jiǎn)章 id:12 typeid:3 newsName:招生簡(jiǎn)章4 
  36. id:4 typeName:教務(wù)信息 id:13 typeid:4 newsName:教務(wù)信息1 
  37. id:4 typeName:教務(wù)信息 id:14 typeid:4 newsName:教務(wù)信息2 
  38. id:4 typeName:教務(wù)信息 id:15 typeid:4 newsName:教務(wù)信息3 
  39. id:4 typeName:教務(wù)信息 id:16 typeid:4 newsName:教務(wù)信息4  

#p#

現(xiàn)在說如何實(shí)現(xiàn)

1)實(shí)現(xiàn).net數(shù)據(jù)庫(kù)參數(shù)化。

  1. package cdu.yas.xykps.util; 
  2. import java.sql.Blob; 
  3. import java.sql.Date; 
  4. /** 
  5. * @功能描述 sql參數(shù),sql執(zhí)行時(shí)傳遞的參數(shù)用此類封裝 
  6. * @可能的錯(cuò)誤 
  7. * @作者 王磊 
  8. * @修改說明 
  9. * @修改人 
  10. */ 
  11. public class SqlParameter { 
  12. public SqlParameter(String type, String value) { 
  13. this.type = type; 
  14. this.value = value; 
  15. public SqlParameter(String type, int intValue) { 
  16. this.type = type; 
  17. this.intValue = intValue; 
  18. public SqlParameter(String type, boolean boolValue) { 
  19. this.type = type; 
  20. this.boolValue = boolValue; 
  21. public SqlParameter(String type, Date dateValue) { 
  22. this.type = type; 
  23. this.dateValue = dateValue; 
  24. public SqlParameter(String type, Blob blobValue) { 
  25. this.type = type; 
  26. this.blobValue = blobValue; 
  27. String type; 
  28. String value; 
  29. int intValue; 
  30. boolean boolValue; 
  31. Date dateValue; 
  32. Blob blobValue; 
  33. public String getType() { 
  34. return type; 
  35. public String getValue() { 
  36. return value; 
  37. public int getIntValue() { 
  38. return intValue; 
  39. public boolean getBoolValue() { 
  40. return boolValue; 
  41. public Date getDateValue() { 
  42. return dateValue; 
  43. public Blob getBlobValue() { 
  44. return blobValue; 
  45. public void setType(String type) { 
  46. this.type = type; 
  47. public void setValue(String value) { 
  48. this.value = value; 
  49. public void setIntValue(int intValue) { 
  50. this.intValue = intValue; 
  51. public void setBoolValue(boolean boolValue) { 
  52. this.boolValue = boolValue; 
  53. public void setDateValue(Date dateValue) { 
  54. this.dateValue = dateValue; 
  55. public void setBlobValue(Blob blobValue) { 
  56. this.blobValue = blobValue; 
  57. }  

2)后臺(tái)參數(shù)執(zhí)行:

  1. /** 
  2. * @功能描述 執(zhí)行一條select語句返回一張數(shù)據(jù)表,支持多表查詢 
  3. * @可能的錯(cuò)誤 
  4. * @作者 王磊 
  5. * @修改說明 
  6. * @修改人 
  7. */ 
  8. public DataTable getDataTable(String sql, SqlParameter[] p) { 
  9. Connection conn = DB.createConn(); 
  10. PreparedStatement ps = DB.prepare(conn, sql); 
  11. DataTable t = null
  12. try { 
  13. addSqlParameter(ps, p); 
  14. ResultSet rs = ps.executeQuery(); 
  15. ResultSetMetaData rsmd = rs.getMetaData(); 
  16. List<DataRow> row = new ArrayList<DataRow>();// 表所有行集合 
  17. List<DataColumn> col = null;// 行所有列集合 
  18. DataRow r = null// 單獨(dú)一行 
  19. DataColumn c = null;// 單獨(dú)一列 
  20. // 此處開始循環(huán)讀數(shù)據(jù),每次往表格中插入一行記錄 
  21. while (rs.next()) { 
  22. // 初始化行集合, 
  23. // 初始化列集合 
  24. col = new ArrayList<DataColumn>(); 
  25. // 此處開始列循環(huán),每次向一行對(duì)象插入一列 
  26. for (int i = 1; i <= rsmd.getColumnCount(); i++) { 
  27. String columnName = rsmd.getColumnName(i); 
  28. Object value = rs.getObject(columnName); 
  29. // 初始化單元列 
  30. c = new DataColumn(columnName, value); 
  31. // 將列信息加入列集合 
  32. col.add(c); 
  33. // 初始化單元行 
  34. r = new DataRow(col); 
  35. // 將行信息降入行結(jié)合 
  36. row.add(r); 
  37. // 得到數(shù)據(jù)表 
  38. t = new DataTable(row); 
  39. rs.close(); 
  40. rs = null
  41. catch (SQLException e) { 
  42. e.printStackTrace(); 
  43. finally { 
  44. DB.close(ps); 
  45. DB.close(conn); 
  46. return t; 
  47. }  

#p#

3)增加參數(shù)的方法:

 

  1. /** 
  2. * @功能描述 增加參數(shù)方法 
  3. * @可能的錯(cuò)誤 需要測(cè)試全局?jǐn)?shù)據(jù)共享問題,以及可能會(huì)擴(kuò)展參數(shù)類型 
  4. * @作者 王磊 
  5. * @修改說明 
  6. * @修改人 
  7. */ 
  8. private void addSqlParameter(PreparedStatement ps, SqlParameter[] p) 
  9. throws SQLException { 
  10. for (int j = 0; j < p.length; j++) { 
  11. // wl(p[j].getValue() + "--" + p[j].getType() + "--" + j); 
  12. if (p[j].getType().equals("int")) { 
  13. ps.setInt(j + 1, p[j].getIntValue()); 
  14. if (p[j].type.equals("String")) { 
  15. ps.setString(j + 1, p[j].getValue()); 
  16. if (p[j].type.equals("boolean")) { 
  17. ps.setBoolean(j + 1, p[j].getBoolValue()); 
  18. if (p[j].type.equals("Date")) { 
  19. ps.setDate(j + 1, p[j].getDateValue()); 
  20. if (p[j].type.equals("Blob")) { 
  21. ps.setBlob(j + 1, p[j].getBlobValue()); 
  22. }  
  23. ----------/////////////////////////////////////////////// 
  24. public DataTable getByParentId(int pId) { 
  25. String sql = "select * from kpxz where fbh=? order by kpxzsx asc"
  26. SqlParameter[] p = new SqlParameter[1]; 
  27. p[0] = new SqlParameter("int", pId); 
  28. return db.getDataTable(sql, p); 
  29. }  

4)看看我們?nèi)绾握{(diào)用方法:

  1. public DataTable getByParentId(int pId) { 
  2. String sql = "select * from kpxz where fbh=? order by kpxzsx asc"
  3. SqlParameter[] p = new SqlParameter[1]; 
  4. p[0] = new SqlParameter("int", pId); 
  5. return db.getDataTable(sql, p); 
  6. }  

#p#

上面就是調(diào)用函數(shù)的具體方法,現(xiàn)在我們來詳細(xì)說下DataTable,具體實(shí)現(xiàn)如下:

 

  1. package cdu.yas.xykps.util; 
  2. import java.util.ArrayList; 
  3. import java.util.List; 
  4. /** 
  5. * @功能描述 數(shù)據(jù)表,即是表格集合,為L(zhǎng)ist類型,其中List中每一個(gè)對(duì)象是一個(gè)DataRow類(List) 
  6. * @可能的錯(cuò)誤 
  7. * @作者 王磊 
  8. * @修改說明 
  9. * @修改人 
  10. */ 
  11. public class DataTable { 
  12. List<DataRow> row; 
  13. public DataTable() { 
  14. public DataTable(List<DataRow> r) { 
  15. row = r; 
  16. public List<DataRow> getRow() { 
  17. return row; 
  18. public void setRow(List<DataRow> row) { 
  19. this.row = row; 
  20. /** 
  21. * @功能描述 雙表根據(jù)兩表關(guān)聯(lián)字段連接,要求兩表必須包含公告字段,并且每一行數(shù)據(jù)公共字段相等 。dt1對(duì)應(yīng)colname1 ,dt2 
  22. * 對(duì)應(yīng)colName2 
  23. * @可能的錯(cuò)誤 未完成 
  24. * @作者 王磊 
  25. * @修改說明 
  26. * @修改人 
  27. */ 
  28. public static DataTable joinTable(DataTable dt1, DataTable dt2, String colName1, 
  29. String colName2) { 
  30. List<DataRow> newRows = new ArrayList<DataRow>(); 
  31. List<DataRow> rows1 = dt1.getRow(); 
  32. List<DataRow> rows2 = dt2.getRow(); 
  33. int i1 = rows1.size(); 
  34. int i2 = rows2.size(); 
  35. List<DataRow> temp = new ArrayList<DataRow>(); 
  36. String tempC = ""
  37. if (i1 > i2) { 
  38. temp = rows1; 
  39. rows1 = rows2; 
  40. rows2 = temp; 
  41. tempC = colName1; 
  42. colName1 = colName2; 
  43. colName2 = tempC; 
  44. for (DataRow r1 : rows1) { 
  45. String value1 = r1.eval(colName1); 
  46. for (DataRow r2 : rows2) { 
  47. String value2 = r2.eval(colName2); 
  48. if (value1.equals(value2)) { 
  49. List<DataColumn> cols = new ArrayList<DataColumn>(); 
  50. for (DataColumn c : r1.getCol()) { 
  51. cols.add(c); 
  52. for (DataColumn c : r2.getCol()) { 
  53. cols.add(c); 
  54. DataRow rr = new DataRow(cols); 
  55. newRows.add(rr); 
  56. DataTable dt = new DataTable(newRows); 
  57. return dt; 
  58. public static void outTable(DataTable dt) { 
  59. for (DataRow r : dt.getRow()) { 
  60. for (DataColumn c : r.getCol()) { 
  61. System.out.print(c.getKey() + ":" + c.getValue() + " "); 
  62. wl(""); 
  63. public static void wl(String s) { 
  64. System.out.println(s); 
  65. }  

對(duì)應(yīng)DataRow:

 

  1. package cdu.yas.xykps.util; 
  2. import java.sql.Blob; 
  3. import java.sql.Date; 
  4. import java.util.List; 
  5. /** 
  6. * @功能描述 數(shù)據(jù)行,即是表格中的每一行數(shù)據(jù)的集合,為L(zhǎng)ist類型,其中List中每一個(gè)對(duì)象是一個(gè)DataColumn類(鍵值對(duì)) 
  7. * @可能的錯(cuò)誤 當(dāng)需要取得行數(shù)據(jù)中某一列時(shí),若是類型轉(zhuǎn)換不匹配會(huì)出錯(cuò)(例:1 若是數(shù)據(jù)項(xiàng)為字符串,我們?nèi)r(shí)候想取整形;); 
  8. * @作者 王磊 
  9. * @修改說明 由于取為空字符串時(shí)候會(huì)報(bào)類型轉(zhuǎn)換的錯(cuò)誤,便使用了異常處理 
  10. * @修改人 王磊 
  11. */ 
  12. public class DataRow { 
  13. List<DataColumn> col; 
  14. /** 
  15. * @功能描述 返回指定DataColumn類型數(shù)據(jù)列對(duì)象 
  16. * @作者 王磊 
  17. */ 
  18. public DataColumn getColumnObject(String colName) { 
  19.  
  20. for (DataColumn c : col) { 
  21. if (c.getKey().toUpperCase().equals(colName.toUpperCase())) { 
  22. try { 
  23. return c; 
  24. catch (Exception e) { 
  25. System.out.println("錯(cuò)誤描述:" + e.toString()); 
  26. return null
  27. /** 
  28. * @功能描述 返回指定Object類型數(shù)據(jù)列對(duì)象 
  29. * @作者 王磊 
  30. */ 
  31. public Object getColumn(String colName) { 
  32. for (DataColumn c : col) { 
  33. if (c.getKey().toUpperCase().equals(colName.toUpperCase())) { 
  34. try { 
  35. return c.getValue(); 
  36. catch (Exception e) { 
  37. System.out.println("錯(cuò)誤描述:" + e.toString()); 
  38. return null
  39. /** 
  40. * @功能描述 返回指定int類型數(shù)據(jù)列對(duì)象 
  41. * @作者 王磊 
  42. */ 
  43. public int getIntColumn(String colName) { 
  44. for (DataColumn c : col) { 
  45. if (c.getKey().toUpperCase().equals(colName.toUpperCase())) { 
  46. try { 
  47. return Integer.parseInt(c.getValue().toString()); 
  48. catch (Exception e) { 
  49. System.out.println("錯(cuò)誤描述:" + e.toString()); 
  50. return 0
  51. /** 
  52. * @功能描述 返回指定String類型數(shù)據(jù)列對(duì)象 
  53. * @作者 王磊 
  54. */ 
  55. public String getStringColumn(String colName) { 
  56. for (DataColumn c : col) { 
  57. if (c.getKey().toUpperCase().equals(colName.toUpperCase())) { 
  58. try { 
  59. return c.getValue().toString(); 
  60. catch (Exception e) { 
  61. System.out.println("錯(cuò)誤描述:" + e.toString()); 
  62. return null
  63. /** 
  64. * @功能描述 返回指定String類型數(shù)據(jù)列對(duì)象 
  65. * @作者 王磊 
  66. */ 
  67. public String eval(String colName) { 
  68. for (DataColumn c : col) { 
  69. if (c.getKey().toUpperCase().equals(colName.toUpperCase())) { 
  70. try { 
  71. return c.getValue() + "";// 此方法將屏蔽錯(cuò)誤!!! 
  72. catch (Exception e) { 
  73. System.out.println("錯(cuò)誤描述:" + e.toString()); 
  74. return null
  75. /** 
  76. * @功能描述 返回指定Date類型數(shù)據(jù)列對(duì)象 
  77. * @作者 王磊 
  78. */ 
  79. public Date getDateColumn(String colName) { 
  80. for (DataColumn c : col) { 
  81. if (c.getKey().toUpperCase().equals(colName.toUpperCase())) { 
  82. try { 
  83. return Date.valueOf(c.getValue().toString()); 
  84. catch (Exception e) { 
  85. System.out.println("錯(cuò)誤描述:" + e.toString()); 
  86. return null
  87. /** 
  88. * @功能描述 返回指定Blob類型數(shù)據(jù)列對(duì)象 
  89. * @作者 王磊 
  90. */ 
  91. public Blob getBlobColumn(String colName) { 
  92. for (DataColumn c : col) { 
  93. if (c.getKey().toUpperCase().equals(colName.toUpperCase())) { 
  94. try { 
  95. return (Blob) c.getValue(); 
  96. catch (Exception e) { 
  97. System.out.println("錯(cuò)誤描述:" + e.toString()); 
  98. return null
  99. /** 
  100. * @功能描述 返回指定Blob類型數(shù)據(jù)列對(duì)象 
  101. * @作者 王磊 
  102. */ 
  103. public float getFloatColumn(String colName) { 
  104. for (DataColumn c : col) { 
  105. if (c.getKey().toUpperCase().equals(colName.toUpperCase())) { 
  106. try { 
  107. return Float.parseFloat(c.getValue().toString()); 
  108. catch (Exception e) { 
  109. System.out.println("錯(cuò)誤描述:" + e.toString()); 
  110. return 0
  111. public DataRow(List<DataColumn> c) { 
  112. col = c; 
  113. public List<DataColumn> getCol() { 
  114. return col; 
  115. public void setCol(List<DataColumn> col) { 
  116. this.col = col; 
  117. }  

然后數(shù)據(jù)列:

 

  1. package cdu.yas.xykps.util; 
  2. import java.util.Collection; 
  3. import java.util.HashMap; 
  4. import java.util.Map; 
  5. import java.util.Set; 
  6. /** 
  7. * @功能描述 數(shù)據(jù)列,也是最簡(jiǎn)單的數(shù)據(jù)項(xiàng),相當(dāng)于表格中的一個(gè)單元項(xiàng)目。 
  8. * 采用健值對(duì)思想,key為列名,value對(duì)應(yīng)key值的單元格元素,為Object類型 
  9. * @可能的錯(cuò)誤 
  10. * @作者 王磊 
  11. * @修改說明 
  12. * @修改人 
  13. */ 
  14. public class DataColumn { 
  15. String key; 
  16. Object value; 
  17. public DataColumn(String k, Object v) { 
  18. key = k; 
  19. value = v; 
  20. public String getKey() { 
  21. return key; 
  22. public Object getValue() { 
  23. return value; 
  24. public void setKey(String key) { 
  25. this.key = key; 
  26. public void setValue(Object value) { 
  27. this.value = value; 
  28. }  

如此一來便實(shí)現(xiàn)了java中的DataTable了。好了暫時(shí)這個(gè)樣子了,我還封裝了一個(gè)分頁(yè)控件,也有點(diǎn)類似于net里面的分頁(yè)控件,等下次大家一起看看吧。

【編輯推薦】

  1. 小型ORM框架 ActiveJDBC
  2. Java 7發(fā)布倒計(jì)時(shí),你準(zhǔn)備好了嗎?
  3. 越早學(xué)會(huì)這些,你的編程之路越好走
責(zé)任編輯:艾婧 來源: 葉小釵的博客
相關(guān)推薦

2021-06-04 09:28:20

Java合同模板Java編程

2010-08-30 09:01:29

DHCP功能寬帶路由器

2018-02-08 16:45:22

前端JS粘貼板

2023-07-05 16:07:02

JavaScriptWeb 應(yīng)用程序

2011-03-15 09:10:47

iptablesNAT

2011-03-15 14:26:23

iptablesNAT

2009-02-05 14:17:37

FTP服務(wù)器Java

2016-08-11 08:24:39

AndroidIntentShareTestDe

2011-08-30 17:33:10

OracleSAS宏

2009-11-04 11:02:23

ADO.NET Dat

2014-10-13 09:57:31

SwiftTouch ID驗(yàn)證iOS 8

2016-09-17 00:12:46

2020-05-09 10:38:31

Python透視表數(shù)據(jù)

2023-12-15 10:21:20

Java聲音識(shí)別

2024-06-07 11:48:32

2009-08-03 17:31:26

.NET驗(yàn)證控件

2010-01-12 10:48:54

VB.NET LIST

2009-08-20 16:07:39

C#和ADO.NET訪

2024-07-26 00:00:12

2015-09-24 09:56:19

.NET二維碼
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

99国产精品视频免费观看一公开 | 精品一区二区三区无码视频| 国产女人爽到高潮a毛片| 欧美成人高清| 国产丝袜一区视频在线观看| 牛夜精品久久久久久久| 91极品在线| 成人激情免费网站| 国产精品日韩欧美大师| 免费在线观看h片| 欧美三级自拍| 8x8x8国产精品| 欧美成人xxxxx| 超碰免费公开在线| 国产亚洲人成网站| 丁香五月网久久综合| 天天爱天天做天天爽| 国产精品成人一区二区网站软件| 亚洲欧美一区二区三区四区| 韩国三级在线播放| 成人在线黄色| 欧美性xxxxxxx| 91网站在线观看免费| av片在线免费观看| 99精品一区二区| 91福利视频导航| 亚洲一区二区激情| 日韩精品一二三四| 91福利视频网| 国产第一页第二页| 99国产**精品****| 亚洲丝袜在线视频| 黄色av网址在线观看| 电影一区中文字幕| 欧美日韩在线三级| 国产性生交xxxxx免费| √天堂8资源中文在线| 亚洲乱码中文字幕| 青春草在线视频免费观看| 噜噜噜在线观看播放视频| 成人精品一区二区三区中文字幕| 成人黄色大片在线免费观看| 久久久久久亚洲av无码专区| 一级成人国产| 97av在线播放| 日本中文字幕网| 在线欧美三区| 欧美精品久久久久久久久| www.99re7| 亚洲成av人片一区二区密柚| 日韩在线免费视频观看| 免费看黄色三级| 精品久久国产| 中文字幕日本欧美| 顶级黑人搡bbw搡bbbb搡| 日韩理论电影| 俺去亚洲欧洲欧美日韩| 三级黄色录像视频| 亚洲女同中文字幕| 欧美成人免费观看| 欧美色图亚洲天堂| 1000部精品久久久久久久久| 久久久久久久91| 国产在线精品观看| 国产精品视频| 国产精品久久久久久久久久久新郎| 特黄视频免费看| 日韩在线一二三区| 国产一区红桃视频| 精品国产九九九| 处破女av一区二区| 久久一区二区精品| chinese偷拍一区二区三区| 欧美国产精品专区| 亚洲在线视频一区二区| 大地资源网3页在线观看| 曰韩精品一区二区| 成年人视频观看| 日韩伦理三区| 欧美一级高清片| 亚洲 欧美 日韩在线| 国产成人一区| 久久久久北条麻妃免费看| 欧美日韩免费做爰视频| 国产亚洲在线观看| 国产精品你懂得| 国产成人精品av在线观| 91在线视频18| 中文字幕欧美人与畜| 欧美aaaaaaa| 疯狂做受xxxx欧美肥白少妇| 日韩肉感妇bbwbbwbbw| 欧美日韩中出| 亚洲欧美在线免费| 99热精品免费| 久热综合在线亚洲精品| 亚洲a中文字幕| 欧美精品少妇| 亚洲色图欧洲色图| 2022亚洲天堂| 国产一区二区| 亚洲视频精品在线| 欧美黄色一级网站| 日本网站在线观看一区二区三区| 亚洲一区二区三区四区在线播放| 日日躁夜夜躁白天躁晚上躁91| 日本一区二区成人在线| 久久国产精品视频在线观看| 欧美男女视频| 亚洲欧洲xxxx| 亚洲精品午夜久久久久久久| 精品在线一区二区三区| 鲁丝片一区二区三区| 50度灰在线| 欧美天堂一区二区三区| av鲁丝一区鲁丝二区鲁丝三区| 欧美gayvideo| 日本精品久久久久久久| 蜜桃在线一区二区| 亚洲欧美电影一区二区| 乌克兰美女av| 中文字幕中文字幕精品| 久久免费高清视频| 99热在线只有精品| 中文字幕日本乱码精品影院| 日av中文字幕| 日韩av不卡一区| 欧美激情综合亚洲一二区| 一卡二卡三卡在线| 国产欧美精品在线观看| 久久9精品区-无套内射无码| av综合网站| 欧美理论片在线观看| 亚洲无码精品在线观看| 国产午夜精品美女毛片视频| 国产毛片视频网站| 国产欧美三级电影| 欧美精品激情在线观看| www精品国产| 一区二区三区免费| 中文字幕在线视频一区二区| 久久久久久美女精品| 国产欧美一区二区三区在线| 草碰在线视频| 欧美性猛交一区二区三区精品| 人妻精品久久久久中文字幕| 亚洲永久免费| 狼狼综合久久久久综合网| 成人黄色动漫| 日韩精品免费一线在线观看| 日本中文字幕免费观看| av一本久道久久综合久久鬼色| 免费看黄在线看| 牛牛影视一区二区三区免费看| 国内精品国产三级国产在线专| 超碰在线观看av| 亚洲高清视频中文字幕| 白嫩情侣偷拍呻吟刺激 | 国产精品色哟哟| 亚欧在线免费观看| 日韩精品看片| 成人欧美一区二区三区黑人孕妇| 久操视频在线观看| 日韩欧美国产一区二区在线播放| 国产精品白嫩白嫩大学美女| 成人综合婷婷国产精品久久蜜臀 | 久久精品国产精品亚洲综合| 亚洲欧洲精品一区| 亚州精品国产| 欧美国产中文字幕| 午夜影院在线视频| 91久久香蕉国产日韩欧美9色| 欧美三级视频网站| 国产专区综合网| 性一交一乱一伧国产女士spa| youjizzjizz亚洲| 日本成人免费在线| 日本中文字幕伦在线观看| 4438x成人网最大色成网站| 男女羞羞免费视频| 久久久久久一级片| 天天干天天玩天天操| 国产真实久久| 欧美一区视久久| 警花av一区二区三区| 国内揄拍国内精品| 啊v视频在线| 欧美精品一区二区三区很污很色的 | 日本v片在线免费观看| 欧美色精品天天在线观看视频| 丰满少妇被猛烈进入一区二区| www.成人网.com| 一区二区三区免费播放| 国产精品a久久久久| 欧美日韩一区在线视频| 久久91视频| 精品中文字幕视频| 青青草观看免费视频在线| 欧美另类高清zo欧美| 西西44rtwww国产精品| 中文字幕一区二区三区在线观看| 先锋资源av在线| 精品一区二区在线视频| 人妻熟妇乱又伦精品视频| 91精品国产91久久久久久黑人| 精品日产一区2区三区黄免费| 九七影院97影院理论片久久| 欧美一区二区三区图| 黄色小网站在线观看| 亚洲午夜色婷婷在线| 欧美 日韩 国产 精品| 欧美精品亚洲二区| 免费的毛片视频| 亚洲成a人v欧美综合天堂| 永久免费看片视频教学| 久久久国产精品午夜一区ai换脸| 亚洲午夜精品在线观看| 欧美aaaaa成人免费观看视频| 欧美日韩精品在线一区二区| 911精品美国片911久久久| 日韩一区二区三区高清| 欧美一性一交| 国产精品久久久久久久久婷婷| 深夜福利亚洲| 国产91在线播放| 国产夫妻在线| 久久久在线视频| 在线黄色网页| 久久夜精品va视频免费观看| 99reav在线| 一区二区三区四区在线观看视频| 婷婷亚洲一区二区三区| 精品处破学生在线二十三| 国产成人精品免费看视频| 欧美精品在线视频| 一道本在线视频| 欧美色网站导航| 中文字幕精品一区二区精| 色屁屁一区二区| 在线观看 亚洲| 欧美性猛交xxxx富婆| 99久热在线精品996热是什么| 亚洲图片有声小说| 国产一级视频在线观看| 亚洲综合999| 久久午夜鲁丝片午夜精品| 玉米视频成人免费看| 免费在线一区二区三区| 一区二区三区中文字幕| 久久亚洲成人av| 亚洲国产cao| 韩国av中文字幕| 色诱视频网站一区| 天天干天天插天天射| 欧美视频在线一区| 国产又黄又大又粗的视频| 91精品国产综合久久国产大片| 国产探花精品一区二区| 欧美一级淫片007| 亚洲国产综合网| 日韩av在线看| 九色在线播放| 中文字幕亚洲欧美一区二区三区| 91精彩在线视频| 久久综合免费视频影院| 爱情岛论坛亚洲品质自拍视频网站 | 国产一区二区久久久| 羞羞色国产精品网站| 日本成人黄色免费看| 欧美一区二区性| www亚洲国产| 亚洲网站视频| 国产a级片免费观看| 免费在线观看视频一区| 一级黄色大片儿| av不卡在线播放| 国产午夜精品福利视频| 亚洲精品成人在线| 日本一级片免费看| 欧美亚洲国产一卡| www日本在线| 亚洲精选中文字幕| 国产精品剧情| 97久久精品国产| 99久久精品一区二区成人| 91中文字精品一区二区| 欧美网色网址| 亚洲一二区在线| 亚洲精品婷婷| 天天视频天天爽| 成人av资源在线| 人妻熟人中文字幕一区二区| 亚洲影视在线播放| 国产免费a视频| 欧美videossexotv100| 国产一二三在线观看| 欧美成人免费在线视频| 欧美片第一页| 国产精品区一区二区三含羞草| 精品国产一区二区三区噜噜噜 | 免费一级特黄3大片视频| 一区二区三区.www| 欧美国产一级片| 亚洲黄色在线观看| 免费高清完整在线观看| 欧美有码在线视频| 午夜电影一区| 日本黄色a视频| 久久伊人亚洲| 91丨porny丨对白| 亚洲婷婷国产精品电影人久久| 亚洲自拍一区在线观看| 精品国产成人在线影院| 免费av在线网站| 国产精品99久久99久久久二8| avtt综合网| 天堂а√在线中文在线| 免费成人av资源网| 精品无码国产污污污免费网站| 亚洲国产美女搞黄色| 国产视频手机在线| 色久欧美在线视频观看| av有声小说一区二区三区| 国产日韩欧美二区| 午夜精品久久99蜜桃的功能介绍| 少妇网站在线观看| 久久精品免费在线观看| 国产又爽又黄的视频| 精品99999| 丰满的护士2在线观看高清| 91热精品视频| 天天做天天爱天天爽综合网| 激情五月亚洲色图| 久久久久久久久免费| 麻豆成人免费视频| 日韩精品极品在线观看| 三级中文字幕在线观看| 国产一区二区在线网站| 亚洲经典三级| 亚洲 欧美 日韩在线| 午夜视频一区二区| 亚洲av综合色区无码一二三区| 欧美成人精品在线播放| 日本高清久久| 女人帮男人橹视频播放| 成人国产精品免费观看视频| 久久久久久免费观看| 亚洲精品一区二区三区精华液| 国产后进白嫩翘臀在线观看视频| 99久久一区三区四区免费| 中文字幕一区二区三区在线视频 | 韩国三级大全久久网站| 中文字幕日韩一区二区三区| 激情深爱一区二区| 全网免费在线播放视频入口| 日韩精品中文字幕一区二区三区| 日本小视频在线免费观看| 国产在线观看一区| 欧美亚洲网站| 午夜精产品一区二区在线观看的| 欧洲中文字幕精品| 在线看免费av| 91久久国产综合久久蜜月精品 | 亚洲视频在线一区| 国产999久久久| 97国产精品视频| 狠狠色丁香婷婷综合影院| 超碰成人在线播放| 亚洲自拍偷拍网站| 欧美日韩影视| 成人亚洲激情网| 国色天香一区二区| 美女久久久久久久久久| 欧美日韩不卡在线| 青青草原av在线| 欧美在线一区二区三区四区| 另类小说一区二区三区| 国产十六处破外女视频| 日韩av在线不卡| 四虎国产精品免费久久5151| 久久99久久久久久| 久久久91精品国产一区二区三区| 91精品在线视频观看| 欧美精品videosex性欧美| 精品视频亚洲| 手机av在线网站| 欧美日韩人人澡狠狠躁视频| 成人在线免费公开观看视频| 91久久精品www人人做人人爽| 国产一区白浆| 日韩三级在线观看视频| 亚洲国产精品成人精品| 男人天堂久久| 欧美成人一区二区在线观看| 国产精品麻豆视频| 丝袜视频国产在线播放| 91久久精品国产91久久性色| 亚洲欧美日韩精品一区二区 | 97人妻精品一区二区三区免 | 日韩免费在线看|