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

數據庫中間件 MyCAT 源碼分析 —— SQL ON MongoDB

數據庫 其他數據庫 MongoDB
Java數據庫連接,(Java Database Connectivity,簡稱JDBC)是Java語言中用來規范客戶端程序如何來訪問數據庫的應用程序接口,提供了諸如查詢和更新數據庫中數據的方法。JDBC也是Sun Microsystems的商標。JDBC是面向關系型數據庫的。
  • 1. 概述
  • 2. 主流程
  • 3. 查詢操作
  • 4. 插入操作

1. 概述

可能你在看到這個標題會小小的吃驚,MyCAT 能使用 MongoDB 做數據節點。是的,沒錯,確實可以。

吼吼吼,讓我們開啟這段神奇的“旅途”。

本文主要分成四部分:

  1. 總體流程,讓你有個整體的認識
  2. 查詢操作
  3. 插入操作

2. 主流程

MyCAT Server 接收 MySQL Client 基于 MySQL協議 的請求,翻譯 SQL 成 MongoDB操作 發送給 MongoDB Server。

MyCAT Server 接收 MongoDB Server 返回的 MongoDB數據,翻譯成 MySQL數據結果 返回給 MySQL Client。

這樣一看,MyCAT 連接 MongoDB 是不是少神奇一點列。

Java數據庫連接,(Java Database Connectivity,簡稱JDBC)是Java語言中用來規范客戶端程序如何來訪問數據庫的應用程序接口,提供了諸如查詢和更新數據庫中數據的方法。JDBC也是Sun Microsystems的商標。JDBC是面向關系型數據庫的。

MyCAT 使用 JDBC 規范,抽象了對 MongoDB 的訪問。通過這樣的方式,MyCAT 也抽象了 SequoiaDB 的訪問??赡苓@樣說法有些抽象,看個類圖壓壓驚。

是不是熟悉的味道。不得不說 JDBC 規范的精妙。

3. 查詢操作

  1. SELECT id, name FROM user WHERE name > '' ORDER BY _id DESC

看順序圖已經很方便的理解整體邏輯,我就不多廢話啦。我們來看幾個核心的代碼邏輯。

1、查詢 MongoDB

  1. // MongoSQLParser.java 
  2. public MongoData query() throws MongoSQLException { 
  3.    if (!(statement instanceof SQLSelectStatement)) { 
  4.        //return null
  5.        throw new IllegalArgumentException("not a query sql statement"); 
  6.    } 
  7.    MongoData mongo = new MongoData(); 
  8.    DBCursor c = null
  9.    SQLSelectStatement selectStmt = (SQLSelectStatement) statement; 
  10.    SQLSelectQuery sqlSelectQuery = selectStmt.getSelect().getQuery(); 
  11.    int icount = 0; 
  12.    if (sqlSelectQuery instanceof MySqlSelectQueryBlock) { 
  13.        MySqlSelectQueryBlock mysqlSelectQuery = (MySqlSelectQueryBlock) selectStmt.getSelect().getQuery(); 
  14.  
  15.        BasicDBObject fields = new BasicDBObject(); 
  16.  
  17.        // 顯示(返回)的字段 
  18.        for (SQLSelectItem item : mysqlSelectQuery.getSelectList()) { 
  19.            //System.out.println(item.toString()); 
  20.            if (!(item.getExpr() instanceof SQLAllColumnExpr)) { 
  21.                if (item.getExpr() instanceof SQLAggregateExpr) { 
  22.                    SQLAggregateExpr expr = (SQLAggregateExpr) item.getExpr(); 
  23.                    if (expr.getMethodName().equals("COUNT")) { // TODO 待讀:count(*) 
  24.                        icount = 1; 
  25.                        mongo.setField(getExprFieldName(expr), Types.BIGINT); 
  26.                    } 
  27.                    fields.put(getExprFieldName(expr), 1); 
  28.                } else { 
  29.                    fields.put(getFieldName(item), 1); 
  30.                } 
  31.            } 
  32.  
  33.        } 
  34.  
  35.        // 表名 
  36.        SQLTableSource table = mysqlSelectQuery.getFrom(); 
  37.        DBCollection coll = this._db.getCollection(table.toString()); 
  38.        mongo.setTable(table.toString()); 
  39.  
  40.        // WHERE 
  41.        SQLExpr expr = mysqlSelectQuery.getWhere(); 
  42.        DBObject query = parserWhere(expr); 
  43.  
  44.        // GROUP BY 
  45.        SQLSelectGroupByClause groupby = mysqlSelectQuery.getGroupBy(); 
  46.        BasicDBObject gbkey = new BasicDBObject(); 
  47.        if (groupby != null) { 
  48.            for (SQLExpr gbexpr : groupby.getItems()) { 
  49.                if (gbexpr instanceof SQLIdentifierExpr) { 
  50.                    String name = ((SQLIdentifierExpr) gbexpr).getName(); 
  51.                    gbkey.put(nameInteger.valueOf(1)); 
  52.                } 
  53.            } 
  54.            icount = 2; 
  55.        } 
  56.  
  57.        // SKIP / LIMIT 
  58.        int limitoff = 0; 
  59.        int limitnum = 0; 
  60.        if (mysqlSelectQuery.getLimit() != null) { 
  61.            limitoff = getSQLExprToInt(mysqlSelectQuery.getLimit().getOffset()); 
  62.            limitnum = getSQLExprToInt(mysqlSelectQuery.getLimit().getRowCount()); 
  63.        } 
  64.        if (icount == 1) { // COUNT(*) 
  65.            mongo.setCount(coll.count(query)); 
  66.        } else if (icount == 2) { // MapReduce 
  67.            BasicDBObject initial = new BasicDBObject(); 
  68.            initial.put("num", 0); 
  69.            String reduce = "function (obj, prev) { " + "  prev.num++}"
  70.            mongo.setGrouyBy(coll.group(gbkey, query, initial, reduce)); 
  71.        } else { 
  72.            if ((limitoff > 0) || (limitnum > 0)) { 
  73.                c = coll.find(query, fields).skip(limitoff).limit(limitnum); 
  74.            } else { 
  75.                c = coll.find(query, fields); 
  76.            } 
  77.  
  78.            // order by 
  79.            SQLOrderBy orderby = mysqlSelectQuery.getOrderBy(); 
  80.            if (orderby != null) { 
  81.                BasicDBObject order = new BasicDBObject(); 
  82.                for (int i = 0; i < orderby.getItems().size(); i++) { 
  83.                    SQLSelectOrderByItem orderitem = orderby.getItems().get(i); 
  84.                    order.put(orderitem.getExpr().toString(), getSQLExprToAsc(orderitem.getType())); 
  85.                } 
  86.                c.sort(order); 
  87.                // System.out.println(order); 
  88.            } 
  89.        } 
  90.        mongo.setCursor(c); 
  91.    } 
  92.    return mongo; 

2、查詢條件

  1. // MongoSQLParser.java 
  2. private void parserWhere(SQLExpr aexpr, BasicDBObject o) { 
  3.    if (aexpr instanceof SQLBinaryOpExpr) { 
  4.        SQLBinaryOpExpr expr = (SQLBinaryOpExpr) aexpr; 
  5.        SQLExpr exprL = expr.getLeft(); 
  6.        if (!(exprL instanceof SQLBinaryOpExpr)) { 
  7.            if (expr.getOperator().getName().equals("=")) { 
  8.                o.put(exprL.toString(), getExpValue(expr.getRight())); 
  9.            } else { 
  10.                String op = ""
  11.                if (expr.getOperator().getName().equals("<")) { 
  12.                    op = "$lt"
  13.                } else if (expr.getOperator().getName().equals("<=")) { 
  14.                    op = "$lte"
  15.                } else if (expr.getOperator().getName().equals(">")) { 
  16.                    op = "$gt"
  17.                } else if (expr.getOperator().getName().equals(">=")) { 
  18.                    op = "$gte"
  19.                } else if (expr.getOperator().getName().equals("!=")) { 
  20.                    op = "$ne"
  21.                } else if (expr.getOperator().getName().equals("<>")) { 
  22.                    op = "$ne"
  23.                } 
  24.                parserDBObject(o, exprL.toString(), op, getExpValue(expr.getRight())); 
  25.            } 
  26.        } else { 
  27.            if (expr.getOperator().getName().equals("AND")) { 
  28.                parserWhere(exprL, o); 
  29.                parserWhere(expr.getRight(), o); 
  30.            } else if (expr.getOperator().getName().equals("OR")) { 
  31.                orWhere(exprL, expr.getRight(), o); 
  32.            } else { 
  33.                throw new RuntimeException("Can't identify the operation of  of where"); 
  34.            } 
  35.        } 
  36.    } 
  37.  
  38. private void orWhere(SQLExpr exprL, SQLExpr exprR, BasicDBObject ob) { 
  39.    BasicDBObject xo = new BasicDBObject(); 
  40.    BasicDBObject yo = new BasicDBObject(); 
  41.    parserWhere(exprL, xo); 
  42.    parserWhere(exprR, yo); 
  43.    ob.put("$or", new Object[]{xo, yo}); 

3、解析 MongoDB 數據

  1. // MongoResultSet.java 
  2. public MongoResultSet(MongoData mongo, String schema) throws SQLException { 
  3.    this._cursor = mongo.getCursor(); 
  4.    this._schema = schema
  5.    this._table = mongo.getTable(); 
  6.    this.isSum = mongo.getCount() > 0; 
  7.    this._sum = mongo.getCount(); 
  8.    this.isGroupBy = mongo.getType(); 
  9.  
  10.    if (this.isGroupBy) { 
  11.        dblist = mongo.getGrouyBys(); 
  12.        this.isSum = true
  13.    } 
  14.    if (this._cursor != null) { 
  15.        select = _cursor.getKeysWanted().keySet().toArray(new String[0]); 
  16.        // 解析 fields 
  17.        if (this._cursor.hasNext()) { 
  18.            _cur = _cursor.next(); 
  19.            if (_cur != null) { 
  20.                if (select.length == 0) { 
  21.                    SetFields(_cur.keySet()); 
  22.                } 
  23.                _row = 1; 
  24.            } 
  25.        } 
  26.        // 設置 fields 類型 
  27.        if (select.length == 0) { 
  28.            select = new String[]{"_id"}; 
  29.            SetFieldType(true); 
  30.        } else { 
  31.            SetFieldType(false); 
  32.        } 
  33.    } else { 
  34.        SetFields(mongo.getFields().keySet());//new String[]{"COUNT(*)"}; 
  35.        SetFieldType(mongo.getFields()); 
  36.    } 
  • 當使用 SELECT * 查詢字段時,fields 使用***條數據返回的 fields。即使,后面的數據有其他 fields,也不返回。

4、返回數據給 MySQL Client

  1. // JDBCConnection.java 
  2. private void ouputResultSet(ServerConnection sc, String sql) 
  3.        throws SQLException { 
  4.    ResultSet rs = null
  5.    Statement stmt = null
  6.  
  7.    try { 
  8.        stmt = con.createStatement(); 
  9.        rs = stmt.executeQuery(sql); 
  10.  
  11.        // header 
  12.        List<FieldPacket> fieldPks = new LinkedList<>(); 
  13.        ResultSetUtil.resultSetToFieldPacket(sc.getCharset(), fieldPks, rs, this.isSpark); 
  14.        int colunmCount = fieldPks.size(); 
  15.        ByteBuffer byteBuf = sc.allocate(); 
  16.        ResultSetHeaderPacket headerPkg = new ResultSetHeaderPacket(); 
  17.        headerPkg.fieldCount = fieldPks.size(); 
  18.        headerPkg.packetId = ++packetId; 
  19.        byteBuf = headerPkg.write(byteBuf, sc, true); 
  20.        byteBuf.flip(); 
  21.        byte[] header = new byte[byteBuf.limit()]; 
  22.        byteBuf.get(header); 
  23.        byteBuf.clear(); 
  24.        List<byte[]> fields = new ArrayList<byte[]>(fieldPks.size()); 
  25.        for (FieldPacket curField : fieldPks) { 
  26.            curField.packetId = ++packetId; 
  27.            byteBuf = curField.write(byteBuf, sc, false); 
  28.            byteBuf.flip(); 
  29.            byte[] field = new byte[byteBuf.limit()]; 
  30.            byteBuf.get(field); 
  31.            byteBuf.clear(); 
  32.            fields.add(field); 
  33.        } 
  34.        // header eof 
  35.        EOFPacket eofPckg = new EOFPacket(); 
  36.        eofPckg.packetId = ++packetId; 
  37.        byteBuf = eofPckg.write(byteBuf, sc, false); 
  38.        byteBuf.flip(); 
  39.        byte[] eof = new byte[byteBuf.limit()]; 
  40.        byteBuf.get(eof); 
  41.        byteBuf.clear(); 
  42.        this.respHandler.fieldEofResponse(header, fields, eof, this); 
  43.  
  44.        // row 
  45.        while (rs.next()) { 
  46.            RowDataPacket curRow = new RowDataPacket(colunmCount); 
  47.            for (int i = 0; i < colunmCount; i++) { 
  48.                int j = i + 1; 
  49.                if (MysqlDefs.isBianry((byte) fieldPks.get(i).type)) { 
  50.                    curRow.add(rs.getBytes(j)); 
  51.                } else if (fieldPks.get(i).type == MysqlDefs.FIELD_TYPE_DECIMAL || 
  52.                        fieldPks.get(i).type == (MysqlDefs.FIELD_TYPE_NEW_DECIMAL - 256)) { // field type is unsigned byte 
  53.                    // ensure that do not use scientific notation format 
  54.                    BigDecimal val = rs.getBigDecimal(j); 
  55.                    curRow.add(StringUtil.encode(val != null ? val.toPlainString() : null, sc.getCharset())); 
  56.                } else { 
  57.                    curRow.add(StringUtil.encode(rs.getString(j), sc.getCharset())); 
  58.                } 
  59.            } 
  60.            curRow.packetId = ++packetId; 
  61.            byteBuf = curRow.write(byteBuf, sc, false); 
  62.            byteBuf.flip(); 
  63.            byte[] row = new byte[byteBuf.limit()]; 
  64.            byteBuf.get(row); 
  65.            byteBuf.clear(); 
  66.            this.respHandler.rowResponse(row, this); 
  67.        } 
  68.        fieldPks.clear(); 
  69.        // row eof 
  70.        eofPckg = new EOFPacket(); 
  71.        eofPckg.packetId = ++packetId; 
  72.        byteBuf = eofPckg.write(byteBuf, sc, false); 
  73.        byteBuf.flip(); 
  74.        eof = new byte[byteBuf.limit()]; 
  75.        byteBuf.get(eof); 
  76.        sc.recycle(byteBuf); 
  77.        this.respHandler.rowEofResponse(eof, this); 
  78.    } finally { 
  79.        if (rs != null) { 
  80.            try { 
  81.                rs.close(); 
  82.            } catch (SQLException e) { 
  83.            } 
  84.        } 
  85.        if (stmt != null) { 
  86.            try { 
  87.                stmt.close(); 
  88.            } catch (SQLException e) { 
  89.            } 
  90.        } 
  91.    } 
  92.  
  93. // MongoResultSet.java 
  94. @Override 
  95. public String getString(String columnLabel) throws SQLException { 
  96.    Object x = getObject(columnLabel); 
  97.    if (x == null) { 
  98.        return null
  99.    } 
  100.    return x.toString(); 

當返回字段值是 Object 時,返回該對象.toString()。例如:

  1. mysql> select * from user order by _id asc
  2. +--------------------------+------+-------------------------------+ 
  3. | _id                      | name | profile                       | 
  4. +--------------------------+------+-------------------------------+ 
  5. | 1                        | 123  | { "age" : 1 , "height" : 100} | 

4. 插入操作

 

  1. // MongoSQLParser.java 
  2. public int executeUpdate() throws MongoSQLException { 
  3.    if (statement instanceof SQLInsertStatement) { 
  4.        return InsertData((SQLInsertStatement) statement); 
  5.    } 
  6.    if (statement instanceof SQLUpdateStatement) { 
  7.        return UpData((SQLUpdateStatement) statement); 
  8.    } 
  9.    if (statement instanceof SQLDropTableStatement) { 
  10.        return dropTable((SQLDropTableStatement) statement); 
  11.    } 
  12.    if (statement instanceof SQLDeleteStatement) { 
  13.        return DeleteDate((SQLDeleteStatement) statement); 
  14.    } 
  15.    if (statement instanceof SQLCreateTableStatement) { 
  16.        return 1; 
  17.    } 
  18.    return 1; 
  19.  
  20. private int InsertData(SQLInsertStatement state) { 
  21.    if (state.getValues().getValues().size() == 0) { 
  22.        throw new RuntimeException("number of  columns error"); 
  23.    } 
  24.    if (state.getValues().getValues().size() != state.getColumns().size()) { 
  25.        throw new RuntimeException("number of values and columns have to match"); 
  26.    } 
  27.    SQLTableSource table = state.getTableSource(); 
  28.    BasicDBObject o = new BasicDBObject(); 
  29.    int i = 0; 
  30.    for (SQLExpr col : state.getColumns()) { 
  31.        o.put(getFieldName2(col), getExpValue(state.getValues().getValues().get(i))); 
  32.        i++; 
  33.    } 
  34.    DBCollection coll = this._db.getCollection(table.toString()); 
  35.    coll.insert(o); 
  36.    return 1; 
責任編輯:武曉燕 來源: oschina博客
相關推薦

2017-07-18 17:35:16

數據庫MyCATPreparedSta

2017-07-18 17:07:40

數據庫 MyCATJoin

2017-12-01 05:04:32

數據庫中間件Atlas

2017-11-27 05:36:16

數據庫中間件TDDL

2017-11-27 05:06:42

數據庫中間件cobar

2018-02-24 19:37:33

Java8數據庫中間件

2009-01-20 10:45:55

Oracle數據庫中間件

2011-08-10 13:03:58

CJDBC數據庫集群

2017-05-23 18:55:05

mysql-proxy數據庫架構

2017-11-27 06:01:37

數據庫中間件中間層

2017-12-01 05:40:56

數據庫中間件join

2017-12-11 13:30:49

Go語言數據庫中間件

2020-04-10 17:00:33

Mycat分庫分表SpringBoot

2017-11-03 11:02:08

數據庫中間件

2017-11-30 08:56:14

數據庫中間件架構師

2024-12-06 08:29:29

2019-05-13 15:00:14

MySQLMyCat數據庫

2021-07-27 05:49:59

MySQL數據庫中間件

2020-10-15 08:34:32

數據庫中間件漫談

2018-11-07 15:30:19

數據庫NewSQLNoSQL
點贊
收藏

51CTO技術棧公眾號

秋霞影院午夜丰满少妇在线视频| 法国伦理少妇愉情| 尤物网在线观看| 国产一区二区三区国产| 久久久久久久香蕉网| 中国毛片在线观看| 亚洲国产伊人| 天天av天天翘天天综合网色鬼国产| 久久综合九色综合网站| 亚洲综合精品国产一区二区三区| 欧美日韩第一区| 亚洲欧美日韩一区二区三区在线| 在线观看免费不卡av| 欧美日韩色网| 国产视频一区在线观看| 亚洲最大的网站| 91玉足脚交嫩脚丫在线播放| 亚洲91中文字幕无线码三区| 日韩电影免费观看在线观看| 亚洲怡红院在线| 欧产日产国产精品视频| 国产精品成人网| 麻豆av一区二区三区| 国产精品国产一区二区三区四区| 一本久道久久综合狠狠爱| 日日噜噜噜夜夜爽亚洲精品| 亚洲天堂成人av| 国产精品美女久久久久| 日韩欧美在线视频观看| 欧美中文字幕在线观看视频 | 水蜜桃亚洲一二三四在线| 成人午夜福利视频| 精品在线你懂的| 97热在线精品视频在线观看| 国精品无码一区二区三区| 欧美人与牛zoz0性行为| 亚洲第一福利网| aaaaaaaa毛片| 国产毛片精品久久| 一本色道久久综合狠狠躁的推荐| 91免费国产精品| 麻豆传媒在线免费| 国产精品色哟哟| 日韩精品久久久毛片一区二区| 高h调教冰块play男男双性文| 精品一区二区三区蜜桃| 国产日产久久高清欧美一区| 天堂网中文字幕| 在线视频精品| 欧美精品久久久久久久久| 神马久久精品综合| 久久视频在线| 自拍亚洲一区欧美另类| 亚洲一区免费网站| 男人靠女人免费视频网站| 在线午夜影院| 亚洲欧美国产高清| 六月婷婷激情网| caoporn免费在线| 亚洲欧美国产三级| 日韩一二区视频| 在线中文字幕-区二区三区四区| 亚洲天堂福利av| 超碰免费在线公开| 黄色成年人视频在线观看| 国产精品久久久久久久久搜平片| 亚洲高清视频在线观看| 日本视频在线免费观看| 中文字幕在线视频一区| 国产成年人在线观看| h网站久久久| 亚洲综合激情网| 国产亚洲黄色片| 国内精彩免费自拍视频在线观看网址| 亚洲综合一区二区精品导航| 97视频在线免费| 超碰在线中文字幕| 狠狠躁天天躁日日躁欧美| 欧美日韩中文在线视频| 少妇精品视频一区二区免费看| 欧美在线观看视频一区二区| 黄色小视频免费网站| 国产成人免费视频网站视频社区 | 久久久高清一区二区三区| 日本一区视频在线| 69xxxx欧美| 一区二区在线观看免费视频播放| 日本黄大片在线观看| 欧美xxxhd| 欧美午夜电影网| 日本人dh亚洲人ⅹxx| 久久影院资源站| 亚洲午夜激情免费视频| 亚洲欧美卡通动漫| 国产尤物精品| 国产成人精品免高潮在线观看 | 青青草精品视频| 91久久综合亚洲鲁鲁五月天| 天天干免费视频| 欧美激情一区二区三区蜜桃视频| 国产精品一区在线免费观看| 国产精品一二三产区| 亚洲一区二区三区高清不卡| 欧美性猛交xxxx乱大交| 欧美成年人视频在线观看| 在线综合色站| 中文字幕精品网| 精品在线免费观看视频| 青青国产91久久久久久| 国产区二精品视| a天堂在线资源| 亚洲成人激情av| 色啦啦av综合| 午夜先锋成人动漫在线| 久久偷看各类女兵18女厕嘘嘘| 国产女同在线观看| 国产麻豆精品theporn| 欧美亚洲国产免费| 久色国产在线| 欧美久久久久久久久| 中文字字幕码一二三区| 欧美久久成人| 国产精品一区久久久| 天堂av电影在线观看| 亚洲天堂精品在线观看| 人人爽人人av| 天堂av一区二区三区在线播放| 久久这里有精品视频| 日批视频免费在线观看| proumb性欧美在线观看| 国内精品国产三级国产99| 成人不卡视频| 亚洲欧美日韩精品久久| 天天爽夜夜爽夜夜爽精品| 国产成人h网站| 好色先生视频污| 欧美美女福利视频| 中文欧美日本在线资源| 一级成人黄色片| 97se亚洲国产综合自在线| 97碰在线视频| 日韩精品中文字幕吗一区二区| 日韩在线观看网站| 真实新婚偷拍xxxxx| 久久色在线观看| 国内外成人免费激情视频| 国产精品99久久免费观看| 欧美日韩国产成人高清视频| 日韩aaaaaa| 蜜臀av一区二区| 亚洲精品中字| 男人天堂久久| 在线视频一区二区| 中文字幕+乱码+中文字幕明步| 国产日韩欧美在线一区| av免费网站观看| 欧美精选一区二区三区| 国产精品第8页| 波多野结衣在线网站| 欧美性淫爽ww久久久久无| 欧美18—19性高清hd4k| 日韩av中文字幕一区二区三区 | 精品国产一区一区二区三亚瑟| 日本亚洲欧洲色α| 高清在线观看av| 欧美日韩精品综合在线| 亚洲av无一区二区三区| 日韩精品国产精品| 亚洲一区三区视频在线观看| 欧美少妇激情| 欧美床上激情在线观看| 秋霞欧美在线观看| 精品美女永久免费视频| 亚洲精品视频久久久| 日韩成人av影视| 国产免费一区二区三区四在线播放| 麻豆精品国产| 2019亚洲日韩新视频| 高清毛片在线看| 6080国产精品一区二区| 国产亚洲欧美久久久久| 91麻豆国产香蕉久久精品| 日韩av片网站| 欧美特黄视频| 欧洲一区二区在线 | 在线综合视频播放| 国产精品1234区| 国产欧美精品一区二区三区四区 | 在线观看18视频网站| 国产精品videossex| 国产成人精品一区二区三区| 免费观看在线午夜影视| 日本亚洲视频在线| 国产亚洲综合久久| 国产精品无码久久av| 亚洲第一综合色| 免费黄在线观看| 国产精品中文字幕一区二区三区| 无码人妻精品一区二区蜜桃网站| 免费黄色成人| 成人福利网站在线观看11| 爱啪啪综合导航| 夜夜嗨av一区二区三区四区 | 精品人妻一区二区三区日产乱码| 亚洲欧美区自拍先锋| 中文字幕免费在线播放| 奇米色一区二区| 亚洲精品国产suv一区88| 久久精品国产亚洲5555| 成人午夜高潮视频| 国产欧洲在线| xvideos国产精品| www.五月婷婷| 欧美视频中文一区二区三区在线观看 | 欧美va视频| 久久国产精品电影| 欧美扣逼视频| 5858s免费视频成人| 天天操天天爽天天干| 一色桃子久久精品亚洲| japan高清日本乱xxxxx| 天堂一区二区在线| 青青草成人免费在线视频| 成人久久一区| 国产日韩精品久久| 日日狠狠久久| 国产精品高潮呻吟久久av野狼| 91在线中文| 国产亚洲一区二区精品| 欧美一区二不卡视频| 日韩视频在线一区二区| 久久久精品毛片| 午夜影院在线观看欧美| 网站永久看片免费| 久久久精品日韩欧美| 性xxxxxxxxx| 久久99精品一区二区三区| 国产福利一区视频| 国产欧美精品| 成人毛片100部免费看| 精品视频国产| 日本一区精品| 外国成人在线视频| 国产精品亚洲不卡a| 午夜久久av| 91亚洲国产成人久久精品网站| 亚洲成av在线| 日本高清视频一区| 成人性生活视频| 91精品成人久久| 久草成色在线| 性欧美视频videos6一9| 青草视频在线免费直播| 日韩在线www| 午夜国产福利在线| 久久精品久久精品亚洲人| gogogo高清在线观看免费完整版| 日韩精品视频在线播放| 五月婷婷六月丁香| 亚洲二区中文字幕| 欧美视频在线观看一区二区三区| 欧美一区二区三区色| 国产成人精品a视频| 这里只有精品电影| 国产毛片毛片毛片毛片| 在线视频一区二区三区| 在线免费看91| 欧美日韩激情一区二区三区| 中文字幕观看视频| 欧美一区二区二区| 亚洲高清视频在线播放| 精品国产免费久久| 亚洲国产一二三区| 亚洲国产免费av| 午夜福利一区二区三区| 亚洲精品视频中文字幕| 91xxx在线观看| 久久精品国产2020观看福利| 免费av不卡| 久久久久久国产精品久久| 丁香影院在线| 欧美孕妇性xx| 蜜桃成人精品| 91久久大香伊蕉在人线| 操欧美女人视频| 久久国产精品一区二区三区四区| 精品72久久久久中文字幕| 亚洲国产日韩综合一区| 天天综合久久| 日韩成人手机在线| 久久精品国产清高在天天线| 无人在线观看的免费高清视频| 久久精品99久久久| 无码任你躁久久久久久老妇| 91捆绑美女网站| avhd101老司机| 1024国产精品| 亚洲 欧美 成人| 欧美日韩成人一区| 国产人妻精品一区二区三| 亚洲精品国产成人| 97视频在线观看网站| 欧美激情视频给我| 国产亚洲人成a在线v网站| 亚洲xxxx18| 婷婷综合电影| 欧美视频你懂的| www.黄色com| 亚洲欧美偷拍卡通变态| 国产成人无码精品久在线观看| 91久久免费观看| 精品久久久久中文慕人妻| 亚洲二区中文字幕| 免费看a在线观看| 午夜精品久久久久久久久久久久| 国产调教在线| 2022国产精品| 国产一区二区三区四区二区| 免费在线精品视频| 日韩在线卡一卡二| 日本美女视频网站| 国产欧美一区二区三区鸳鸯浴 | 91免费国产精品| 美腿丝袜在线亚洲一区| 一区二区免费在线观看视频| 国产精品毛片久久久久久| 精品人妻无码一区二区性色| 欧美一区二区视频网站| 黄色美女网站在线观看| 2019国产精品自在线拍国产不卡| 亚洲一区av| 欧美日本国产精品| 亚洲欧美综合| 久久久久久蜜桃一区二区| 99久久精品国产毛片| 女人18毛片毛片毛片毛片区二 | 水蜜桃在线免费观看| 久久一二三四| 国产乱了高清露脸对白| 亚洲高清久久久| 99久久亚洲精品日本无码| 在线日韩日本国产亚洲| 欧美91看片特黄aaaa| 国产亚洲一区在线播放 | 国产伦精一区二区三区| 神马久久久久久久久久久| 精品久久久久久久久久久久久| 精品久久久久中文慕人妻| 另类色图亚洲色图| 日韩午夜视频在线| 亚洲精品一区二区三区av| 免费观看在线综合| 在线视频第一页| 亚洲国产日韩a在线播放| 亚洲精品一区二区三区新线路 | 亚洲黄色在线| 日韩大尺度视频| 亚洲成人免费视频| www.黄色一片| 欧美日韩国产91| 欧美日韩一区二区三区在线电影| 97干在线视频| 成人网男人的天堂| 中国一级特黄毛片| 日韩电影中文字幕av| 国产桃色电影在线播放| 国内精品久久久久久久果冻传媒| 亚洲午夜一级| 特种兵之深入敌后| 亚洲成人黄色影院| 亚洲av片在线观看| 国产成人精品一区二区在线| 国产欧美日韩一区二区三区四区| 日本免费一级视频| 中文字幕在线不卡国产视频| 91久久久久久久久久久久| 久久精品成人欧美大片| 久久动漫网址| 黑人糟蹋人妻hd中文字幕| 91在线观看地址| 亚洲天堂视频在线| 超碰日本道色综合久久综合| 国产亚洲人成a在线v网站| 日韩精品一区二区免费| 99视频精品在线| av黄色在线看| 中文字幕亚洲欧美日韩在线不卡| 久久精品国产福利| 国产欧美日韩小视频| 久久久国产一区二区三区四区小说| 国产又粗又猛又爽又| 欧美美最猛性xxxxxx| 欧美一区二区三区久久| 免费日韩视频在线观看| 亚洲色图第一区| 色综合免费视频| 国产欧美一区二区三区久久人妖 | 国产精品黄色网| 国产亚洲a∨片在线观看| 日韩一区二区三区四区五区 |