国产无遮挡裸体免费直播视频,久久精品国产蜜臀av,动漫在线视频一区二区,欧亚日韩一区二区三区,久艹在线 免费视频,国产精品美女网站免费,正在播放 97超级视频在线观看,斗破苍穹年番在线观看免费,51最新乱码中文字幕

Python讀取Hive數(shù)據(jù)庫實(shí)現(xiàn)代碼詳解

 更新時(shí)間:2023年03月01日 08:33:49   作者:是豬哥不是諸葛  
這篇文章主要介紹了Python讀取Hive數(shù)據(jù)庫實(shí)現(xiàn)代碼,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

背景:

在這篇文章之前,我讀取數(shù)據(jù)庫的數(shù)據(jù)沒有形成規(guī)范,并且代碼擴(kuò)展性不好,使用率不高,而且比較混亂。數(shù)據(jù)庫信息的替換也比較混亂。壞習(xí)慣包括:連接數(shù)據(jù)庫之后就開始讀數(shù),讀完就結(jié)束,數(shù)據(jù)的存放也沒有規(guī)范,而且容易重復(fù)讀取。

現(xiàn)在將代碼分為幾層,一層是底層,就是單獨(dú)連接數(shù)據(jù)庫,在這基礎(chǔ)上封裝第二個(gè)類別,加上了線程鎖和時(shí)間表,用于確保讀數(shù)的穩(wěn)定和超時(shí)錯(cuò)誤提醒。第三層才是真正的業(yè)務(wù),第三層的類里面封裝了很多讀取不同數(shù)據(jù)表的方法,每一個(gè)方法就是讀一個(gè)表,然后將數(shù)據(jù)緩存起來,并且設(shè)置好更新數(shù)據(jù)緩存的時(shí)間(例如24小時(shí)),和維護(hù)多線程讀數(shù)。

第四層也就是簡單的調(diào)用第三層即可,然后所有的數(shù)據(jù)都可以讀取然后緩存到我們?cè)谂渲庙?xiàng)中指定的文件夾目錄了

實(shí)際業(yè)務(wù)讀取hive數(shù)據(jù)庫的代碼

import logging
import pandas as pd
from impala.dbapi import connect
import sqlalchemy
from sqlalchemy.orm import sessionmaker
import os
import time
import os
import datetime
from dateutil.relativedelta import relativedelta
from typing import Dict, List
import logging
import threading
import pandas as pd
import pickle
class HiveHelper(object):
    def __init__(
        self,
        host='10.2.32.22',
        port=21051,
        database='ur_ai_dw',
        auth_mechanism='LDAP',
        user='urbi',
        password='Ur#730xd',
        logger:logging.Logger=None
        ):
        self.host = host
        self.port = port
        self.database = database
        self.auth_mechanism = auth_mechanism
        self.user = user
        self.password = password
        self.logger = logger
        self.impala_conn = None
        self.conn = None
        self.cursor = None
        self.engine = None
        self.session = None
    def create_table_code(self, file_name):
        '''創(chuàng)建表類代碼'''
        os.system(f'sqlacodegen {self.connection_str} > {file_name}')
        return self.conn
    def get_conn(self):
        '''創(chuàng)建連接或獲取連接'''
        if self.conn is None:
            engine = self.get_engine()
            self.conn = engine.connect()
        return self.conn
    def get_impala_conn(self):
        '''創(chuàng)建連接或獲取連接'''
        if self.impala_conn is None:
            self.impala_conn = connect(
                host=self.host,
                port=self.port,
                database=self.database,
                auth_mechanism=self.auth_mechanism,
                user=self.user,
                password=self.password
                )
        return self.impala_conn
    def get_engine(self):
        '''創(chuàng)建連接或獲取連接'''
        if self.engine is None:
            self.engine = sqlalchemy.create_engine('impala://', creator=self.get_impala_conn)
        return self.engine
    def get_cursor(self):
        '''創(chuàng)建連接或獲取連接'''
        if self.cursor is None:
            self.cursor = self.conn.cursor()
        return self.cursor
    def get_session(self) -> sessionmaker:
        '''創(chuàng)建連接或獲取連接'''
        if self.session is None:
            engine = self.get_engine()
            Session = sessionmaker(bind=engine)
            self.session = Session()
        return self.session
    def close_conn(self):
        '''關(guān)閉連接'''
        if self.conn is not None:
            self.conn.close()
            self.conn = None
        self.dispose_engine()
        self.close_impala_conn()
    def close_impala_conn(self):
        '''關(guān)閉impala連接'''
        if self.impala_conn is not None:
            self.impala_conn.close()
            self.impala_conn = None
    def close_session(self):
        '''關(guān)閉連接'''
        if self.session is not None:
            self.session.close()
            self.session = None
        self.dispose_engine()
    def dispose_engine(self):
        '''釋放engine'''
        if self.engine is not None:
            # self.engine.dispose(close=False)
            self.engine.dispose()
            self.engine = None
    def close_cursor(self):
        '''關(guān)閉cursor'''
        if self.cursor is not None:
            self.cursor.close()
            self.cursor = None
    def get_data(self, sql, auto_close=True) -> pd.DataFrame:
        '''查詢數(shù)據(jù)'''
        conn = self.get_conn()
        data = None
        try:
            # 異常重試3次
            for i in range(3):
                try:
                    data = pd.read_sql(sql, conn)
                    break
                except Exception as ex:
                    if i == 2:
                        raise ex # 往外拋出異常
                    time.sleep(60) # 一分鐘后重試
        except Exception as ex:
            self.logger.exception(ex)
            raise ex # 往外拋出異常
        finally:
            if auto_close:
                self.close_conn()
        return data
pass
class VarsHelper():
    def __init__(self, save_dir, auto_save=True):
        self.save_dir = save_dir
        self.auto_save = auto_save
        self.values = {}
        if not os.path.exists(os.path.dirname(self.save_dir)):
            os.makedirs(os.path.dirname(self.save_dir))
        if os.path.exists(self.save_dir):
            with open(self.save_dir, 'rb') as f:
                self.values = pickle.load(f)
                f.close()
    def set_value(self, key, value):
        self.values[key] = value
        if self.auto_save:
            self.save_file()
    def get_value(self, key):
        return self.values[key]
    def has_key(self, key):
        return key in self.values.keys()
    def save_file(self):
        with open(self.save_dir, 'wb') as f:
            pickle.dump(self.values, f)
            f.close()
pass
class GlobalShareArgs():
    args = {
        "debug": False
    }
    def get_args():
        return GlobalShareArgs.args
    def set_args(args):
        GlobalShareArgs.args = args
    def set_args_value(key, value):
        GlobalShareArgs.args[key] = value
    def get_args_value(key, default_value=None):
        return GlobalShareArgs.args.get(key, default_value)
    def contain_key(key):
        return key in GlobalShareArgs.args.keys()
    def update(args):
        GlobalShareArgs.args.update(args)
pass
class ShareArgs():
    args = {
        "labels_dir":"./hjx/shop_group/month_w_amt/data/labels", # 標(biāo)簽?zāi)夸?
        "labels_output_dir":"./hjx/shop_group/month_w_amt/data/labels_output", # 聚類導(dǎo)出標(biāo)簽?zāi)夸?
        "common_datas_dir":"./hjx/data", # 共用數(shù)據(jù)目錄。ur_bi_dw的公共
        "only_predict": False, # 只識(shí)別,不訓(xùn)練
        "delete_model": True, # 先刪除模型,僅在訓(xùn)練時(shí)使用
        "export_excel": False, # 導(dǎo)出excel
        "classes": 12, # 聚類數(shù)
        "batch_size": 16,
        "hidden_size": 32,
        "max_nrof_epochs": 100,
        "learning_rate": 0.0005,
        "loss_type": "categorical_crossentropy",
        "avg_model_num": 10,
        "steps_per_epoch": 4.0, # 4.0
        "lr_callback_patience": 4, 
        "lr_callback_cooldown": 1,
        "early_stopping_callback_patience": 6,
        "get_data": True,
    }
    def get_args():
        return ShareArgs.args
    def set_args(args):
        ShareArgs.args = args
    def set_args_value(key, value):
        ShareArgs.args[key] = value
    def get_args_value(key, default_value=None):
        return ShareArgs.args.get(key, default_value)
    def contain_key(key):
        return key in ShareArgs.args.keys()
    def update(args):
        ShareArgs.args.update(args)
pass
class UrBiGetDatasBase():
    # 線程鎖列表,同保存路徑共用鎖
    lock_dict:Dict[str, threading.Lock] = {}
    # 時(shí)間列表,用于判斷是否超時(shí)
    time_dict:Dict[str, datetime.datetime] = {}
    # 用于記錄是否需要更新超時(shí)時(shí)間
    get_data_timeout_dict:Dict[str, bool] = {}
    def __init__(
        self,
        host='10.2.32.22',
        port=21051,
        database='ur_ai_dw',
        auth_mechanism='LDAP',
        user='urbi',
        password='Ur#730xd',
        save_dir=None,
        logger:logging.Logger=None,
        ):
        self.save_dir = save_dir
        self.logger = logger
        self.db_helper = HiveHelper(
            host=host,
            port=port,
            database=database,
            auth_mechanism=auth_mechanism,
            user=user,
            password=password,
            logger=logger
            )
        # 創(chuàng)建子目錄
        if self.save_dir is not None and not os.path.exists(self.save_dir):
            os.makedirs(self.save_dir)
        self.vars_helper = None
        if GlobalShareArgs.get_args_value('debug'):
            self.vars_helper = VarsHelper('./hjx/data/vars/UrBiGetDatas') 
    def close(self):
        '''關(guān)閉連接'''
        self.db_helper.close_conn()
    def get_last_time(self, key_name) -> bool:
        '''獲取是否超時(shí)'''
        # 轉(zhuǎn)靜態(tài)路徑,確保唯一性
        key_name = os.path.abspath(key_name)
        if self.vars_helper is not None and self.vars_helper.has_key('UrBiGetDatasBase.time_list'):
            UrBiGetDatasBase.time_dict = self.vars_helper.get_value('UrBiGetDatasBase.time_list')
        timeout = 12 # 12小時(shí)
        if GlobalShareArgs.get_args_value('debug'):
            timeout = 24 # 24小時(shí)
        get_data_timeout = False
        if key_name not in UrBiGetDatasBase.time_dict.keys() or (datetime.datetime.today() - UrBiGetDatasBase.time_dict[key_name]).total_seconds()>(timeout*60*60):
            self.logger.info('超時(shí)%d小時(shí),重新查數(shù)據(jù):%s', timeout, key_name)
            # UrBiGetDatasBase.time_list[key_name] = datetime.datetime.today()
            get_data_timeout = True
        else:
            self.logger.info('未超時(shí)%d小時(shí),跳過查數(shù)據(jù):%s', timeout, key_name)
        # if self.vars_helper is not None :
        #     self.vars_helper.set_value('UrBiGetDatasBase.time_list', UrBiGetDatasBase.time_list)
        UrBiGetDatasBase.get_data_timeout_dict[key_name] = get_data_timeout
        return get_data_timeout
    def save_last_time(self, key_name):
        '''更新狀態(tài)超時(shí)'''
        # 轉(zhuǎn)靜態(tài)路徑,確保唯一性
        key_name = os.path.abspath(key_name)
        if UrBiGetDatasBase.get_data_timeout_dict[key_name]:
            UrBiGetDatasBase.time_dict[key_name] = datetime.datetime.today()
        if self.vars_helper is not None :
            UrBiGetDatasBase.time_dict[key_name] = datetime.datetime.today()
            self.vars_helper.set_value('UrBiGetDatasBase.time_list', UrBiGetDatasBase.time_dict)
    def get_lock(self, key_name) -> threading.Lock:
        '''獲取鎖'''
        # 轉(zhuǎn)靜態(tài)路徑,確保唯一性
        key_name = os.path.abspath(key_name)
        if key_name not in UrBiGetDatasBase.lock_dict.keys():
            UrBiGetDatasBase.lock_dict[key_name] = threading.Lock()
        return UrBiGetDatasBase.lock_dict[key_name]
    def get_data_of_date(
        self,
        save_dir,
        sql,
        sort_columns:List[str],
        del_index_list=[-1], # 刪除最后下標(biāo)
        start_date = datetime.datetime(2017, 1, 1), # 開始時(shí)間
        offset = relativedelta(months=3), # 時(shí)間間隔
        date_format_fun = lambda d: '%04d%02d01' % (d.year, d.month), # 查詢語句中替代時(shí)間參數(shù)的格式化
        filename_format_fun = lambda d: '%04d%02d.csv' % (d.year, d.month), # 查詢語句中替代時(shí)間參數(shù)的格式化
        stop_date = '20700101', # 超過時(shí)間則停止
        data_format_fun = None, # 格式化數(shù)據(jù)
        ):
        '''分時(shí)間增量讀取數(shù)據(jù)'''
        # 創(chuàng)建文件夾
        if not os.path.exists(save_dir):
            os.makedirs(save_dir)
        else:
            #刪除最后一個(gè)文件
            file_list = os.listdir(save_dir)
            if len(file_list)>0:
                file_list.sort()
                for del_index in del_index_list:
                    os.remove(os.path.join(save_dir,file_list[del_index]))
                    print('刪除最后一個(gè)文件:', file_list[del_index])
        select_index = -1
        # start_date = datetime.datetime(2017, 1, 1)
        while True:
            end_date = start_date + offset
            start_date_str = date_format_fun(start_date)
            end_date_str = date_format_fun(end_date)
            self.logger.info('date: %s-%s', start_date_str, end_date_str)
            file_path = os.path.join(save_dir, filename_format_fun(start_date))
            # self.logger.info('file_path: %s', file_path)
            if not os.path.exists(file_path):
                data:pd.DataFrame = self.db_helper.get_data(sql % (start_date_str, end_date_str))
                if data is None:
                    break
                self.logger.info('data: %d', len(data))
                # self.logger.info('data: %d', data.columns)
                if len(data)>0:
                    select_index+=1
                    if data_format_fun is not None:
                        data = data_format_fun(data)
                    # 排序
                    data = data.sort_values(sort_columns)
                    data.to_csv(file_path)
                elif select_index!=-1:
                    break
                elif stop_date < start_date_str:
                    raise Exception("讀取數(shù)據(jù)異常,時(shí)間超出最大值!")
            start_date = end_date
pass
class UrBiGetDatas(UrBiGetDatasBase):
    def __init__(
        self,
        host='10.2.32.22',
        port=21051,
        database='ur_ai_dw',
        auth_mechanism='LDAP',
        user='urbi',
        password='Ur#730xd',
        save_dir='./hjx/data/ur_bi_dw_data',
        logger:logging.Logger=None
        ):
        self.save_dir = save_dir
        self.logger = logger
        super().__init__(
            host=host,
            port=port,
            database=database,
            auth_mechanism=auth_mechanism,
            user=user,
            password=password,
            save_dir=save_dir,
            logger=logger
            )
    def get_dim_date(self):
        '''日期數(shù)據(jù)'''
        file_path = os.path.join(self.save_dir,'ur_bi_dw.dim_date.csv')
        now_lock = self.get_lock(file_path)
        now_lock.acquire() # 加鎖
        try:
            # 設(shè)置超時(shí)4小時(shí)才重新查數(shù)據(jù)
            if not self.get_last_time(file_path):
                return
            sql = 'SELECT * FROM ur_bi_dw.dim_date'
            data:pd.DataFrame = self.db_helper.get_data(sql)
            columns = list(data.columns)
            columns = {c:'dim_date.'+c for c in columns}
            data = data.rename(columns=columns)
            data = data.sort_values(['dim_date.date_key'])
            data.to_csv(file_path)
            # 更新超時(shí)時(shí)間
            self.save_last_time(file_path)
        except Exception as ex:
            self.logger.exception(ex)
            raise ex # 往外拋出異常
        finally:
            now_lock.release() # 釋放鎖
    def get_dim_shop(self):
        '''店鋪數(shù)據(jù)'''
        file_path = os.path.join(self.save_dir,'ur_bi_dw.dim_shop.csv')
        now_lock = self.get_lock(file_path)
        now_lock.acquire() # 加鎖
        try:
            # 設(shè)置超時(shí)4小時(shí)才重新查數(shù)據(jù)
            if not self.get_last_time(file_path):
                return
            sql = 'SELECT * FROM ur_bi_dw.dim_shop'
            data:pd.DataFrame = self.db_helper.get_data(sql)
            columns = list(data.columns)
            columns = {c:'dim_shop.'+c for c in columns}
            data = data.rename(columns=columns)
            data = data.sort_values(['dim_shop.shop_no'])
            data.to_csv(file_path)
            # 更新超時(shí)時(shí)間
            self.save_last_time(file_path)
        except Exception as ex:
            self.logger.exception(ex)
            raise ex # 往外拋出異常
        finally:
            now_lock.release() # 釋放鎖
    def get_dim_vip(self):
        '''會(huì)員數(shù)據(jù)'''
        sub_dir = os.path.join(self.save_dir,'vip_no')
        now_lock = self.get_lock(sub_dir)
        now_lock.acquire() # 加鎖
        try:
            # 設(shè)置超時(shí)4小時(shí)才重新查數(shù)據(jù)
            if not self.get_last_time(sub_dir):
                return
            sql = '''SELECT dv.*, dd.date_key, dd.date_name2 
            FROM ur_bi_dw.dim_vip as dv
            INNER JOIN ur_bi_dw.dim_date as dd
            ON dv.card_create_date=dd.date_name2 
            where dd.date_key >= %s
            and dd.date_key < %s'''
            # data:pd.DataFrame = self.db_helper.get_data(sql)
            sort_columns = ['dv.vip_no']
            # TODO:
            self.get_data_of_date(
                save_dir=sub_dir,
                sql=sql,
                sort_columns=sort_columns,
                start_date=datetime.datetime(2017, 1, 1), # 開始時(shí)間
                offset=relativedelta(years=1)
            )
            # 更新超時(shí)時(shí)間
            self.save_last_time(sub_dir)
        except Exception as ex:
            self.logger.exception(ex)
            raise ex # 往外拋出異常
        finally:
            now_lock.release() # 釋放鎖
    def get_weather(self):
        '''天氣數(shù)據(jù)'''
        sub_dir = os.path.join(self.save_dir,'weather')
        now_lock = self.get_lock(sub_dir)
        now_lock.acquire() # 加鎖
        try:
            # 設(shè)置超時(shí)4小時(shí)才重新查數(shù)據(jù)
            if not self.get_last_time(sub_dir):
                return
            sql = """
            select weather.* from ur_bi_ods.ods_base_weather_data_1200 as weather
            where weather.date_key>=%s and weather.date_key<%s
            """
            sort_columns = ['weather.date_key','weather.areaid']
            def data_format_fun(data):
                columns = list(data.columns)
                columns = {c:'weather.'+c for c in columns}
                data = data.rename(columns=columns)
                return data
            self.get_data_of_date(
                save_dir=sub_dir,
                sql=sql,
                sort_columns=sort_columns,
                del_index_list=[-2, -1], # 刪除最后下標(biāo)
                data_format_fun=data_format_fun,
            )
            # 更新超時(shí)時(shí)間
            self.save_last_time(sub_dir)
        except Exception as ex:
            self.logger.exception(ex)
            raise ex # 往外拋出異常
        finally:
            now_lock.release() # 釋放鎖
    def get_weather_city(self):
        '''天氣城市數(shù)據(jù)'''
        file_path = os.path.join(self.save_dir,'ur_bi_dw.weather_city.csv')
        now_lock = self.get_lock(file_path)
        now_lock.acquire() # 加鎖
        try:
            # 設(shè)置超時(shí)4小時(shí)才重新查數(shù)據(jù)
            if not self.get_last_time(file_path):
                return
            sql = 'SELECT * FROM ur_bi_dw.dim_weather_city as weather_city'
            data:pd.DataFrame = self.db_helper.get_data(sql)
            columns = list(data.columns)
            columns = {c:'weather_city.'+c for c in columns}
            data = data.rename(columns=columns)
            data.to_csv(file_path)
            # 更新超時(shí)時(shí)間
            self.save_last_time(file_path)
        except Exception as ex:
            self.logger.exception(ex)
            raise ex # 往外拋出異常
        finally:
            now_lock.release() # 釋放鎖
    def get_dim_goods(self):
        '''貨品數(shù)據(jù)'''
        file_path = os.path.join(self.save_dir,'ur_bi_dw.dim_goods.csv')
        now_lock = self.get_lock(file_path)
        now_lock.acquire() # 加鎖
        try:
            # 設(shè)置超時(shí)4小時(shí)才重新查數(shù)據(jù)
            if not self.get_last_time(file_path):
                return
            sql = 'SELECT * FROM ur_bi_dw.dim_goods'
            data:pd.DataFrame = self.db_helper.get_data(sql)
            columns = list(data.columns)
            columns = {c:'dim_goods.'+c for c in columns}
            data = data.rename(columns=columns)
            data.to_csv(file_path)
            # 更新超時(shí)時(shí)間
            self.save_last_time(file_path)
        except Exception as ex:
            self.logger.exception(ex)
            raise ex # 往外拋出異常
        finally:
            now_lock.release() # 釋放鎖
    def get_dim_goods_market_shop_date(self):
        '''店鋪商品生命周期數(shù)據(jù)'''
        file_path = os.path.join(self.save_dir,'ur_bi_dw.dim_goods_market_shop_date.csv')
        now_lock = self.get_lock(file_path)
        now_lock.acquire() # 加鎖
        try:
            # 設(shè)置超時(shí)4小時(shí)才重新查數(shù)據(jù)
            if not self.get_last_time(file_path):
                return
            # sql = 'SELECT * FROM ur_bi_dw.dim_goods_market_shop_date as goods_shop_date'
            sql = '''
            select shop_no, sku_no, shop_market_date, lifecycle_end_date, lifecycle_days
            FROM ur_bi_dw.dim_goods_market_shop_date
            where lifecycle_end_date is not null
            '''
            data:pd.DataFrame = self.db_helper.get_data(sql)
            columns = list(data.columns)
            columns = {c:c.replace('lifecycle_end_date.','') for c in columns}
            data = data.rename(columns=columns)
            data = data.sort_values(['shop_market_date'])
            data.to_csv(file_path, index=False)
            # 更新超時(shí)時(shí)間
            self.save_last_time(file_path)
        except Exception as ex:
            self.logger.exception(ex)
            raise ex # 往外拋出異常
        finally:
            now_lock.release() # 釋放鎖
    def get_dim_goods_market_date(self):
        '''全國商品生命周期數(shù)據(jù)'''
        file_path = os.path.join(self.save_dir,'ur_bi_dw.dim_goods_market_date.csv')
        now_lock = self.get_lock(file_path)
        now_lock.acquire() # 加鎖
        try:
            # 設(shè)置超時(shí)4小時(shí)才重新查數(shù)據(jù)
            if not self.get_last_time(file_path):
                return
            sql = '''
            select * FROM ur_bi_dw.dim_goods_market_date
            '''
            data:pd.DataFrame = self.db_helper.get_data(sql)
            columns = list(data.columns)
            columns = {c:'dim_goods_market_date.'+c for c in columns}
            data = data.rename(columns=columns)
            data = data.sort_values(['dim_goods_market_date.sku_no'])
            data.to_csv(file_path, index=False)
            # 更新超時(shí)時(shí)間
            self.save_last_time(file_path)
        except Exception as ex:
            self.logger.exception(ex)
            raise ex # 往外拋出異常
        finally:
            now_lock.release() # 釋放鎖
    def get_dim_goods_color_dev_sizes(self):
        '''商品開發(fā)碼數(shù)數(shù)據(jù)'''
        file_path = os.path.join(self.save_dir,'dim_goods_color_dev_sizes.csv')
        now_lock = self.get_lock(file_path)
        now_lock.acquire() # 加鎖
        try:
            # 設(shè)置超時(shí)4小時(shí)才重新查數(shù)據(jù)
            if not self.get_last_time(file_path):
                return
            # sql = 'SELECT * FROM ur_bi_dw.dim_goods_market_shop_date as goods_shop_date'
            sql = 'SELECT * FROM ur_bi_dm.dim_goods_color_dev_sizes'
            data:pd.DataFrame = self.db_helper.get_data(sql)
            columns = list(data.columns)
            columns = {c:c.replace('dim_goods_color_dev_sizes.','') for c in columns}
            data = data.rename(columns=columns)
            data.to_csv(file_path, index=False)
            # 更新超時(shí)時(shí)間
            self.save_last_time(file_path)
        except Exception as ex:
            self.logger.exception(ex)
            raise ex # 往外拋出異常
        finally:
            now_lock.release() # 釋放鎖
    def get_dwd_daily_sales_size(self):
        '''實(shí)際銷售金額'''
        sub_dir = os.path.join(self.save_dir,'dwd_daily_sales_size_all')
        now_lock = self.get_lock(sub_dir)
        now_lock.acquire() # 加鎖
        try:
            # 設(shè)置超時(shí)4小時(shí)才重新查數(shù)據(jù)
            if not self.get_last_time(sub_dir):
                return
            sql = """
            select shop_no,sku_no,date_key,`size`,
                sum(tag_price) as `tag_price`,
                sum(sales_qty) as `sales_qty`,
                sum(sales_tag_amt) as `sales_tag_amt`,
                sum(sales_amt) as `sales_amt`,
                count(0) as `sales_count`
            from ur_bi_dw.dwd_daily_sales_size as sales
            where sales.date_key>=%s and sales.date_key<%s
                and sales.currency_code='CNY'
            group by shop_no,sku_no,date_key,`size`
            """
            sort_columns = ['date_key','shop_no','sku_no']
            self.get_data_of_date(
                save_dir=sub_dir,
                sql=sql,
                sort_columns=sort_columns,
                start_date=datetime.datetime(2017, 1, 1), # 開始時(shí)間
            )
            # 更新超時(shí)時(shí)間
            self.save_last_time(sub_dir)
        except Exception as ex:
            self.logger.exception(ex)
            raise ex # 往外拋出異常
        finally:
            now_lock.release() # 釋放鎖
    def get_dwd_daily_delivery_size(self):
        '''實(shí)際配貨金額'''
        sub_dir = os.path.join(self.save_dir,'dwd_daily_delivery_size_all')
        now_lock = self.get_lock(sub_dir)
        now_lock.acquire() # 加鎖
        try:
            # 設(shè)置超時(shí)4小時(shí)才重新查數(shù)據(jù)
            if not self.get_last_time(sub_dir):
                return
            sql = """
            select shop_no,sku_no,date_key,`size`,
                sum(delivery.shop_distr_received_qty) as `shop_distr_received_qty`,
                sum(delivery.shop_distr_received_amt) as `shop_distr_received_amt`,
                sum(delivery.online_distr_received_qty) as `online_distr_received_qty`,
                sum(delivery.online_distr_received_amt) as `online_distr_received_amt`,
                sum(delivery.pr_received_qty) as `pr_received_qty`,
                count(0) as `delivery_count`
            from ur_bi_dw.dwd_daily_delivery_size as delivery
            where delivery.date_key>=%s and delivery.date_key<%s
                and delivery.currency_code='CNY'
            group by shop_no,sku_no,date_key,`size`
            """
            sort_columns = ['date_key','shop_no','sku_no']
            self.get_data_of_date(
                save_dir=sub_dir,
                sql=sql,
                sort_columns=sort_columns,
                start_date=datetime.datetime(2017, 1, 1), # 開始時(shí)間
            )
            # 更新超時(shí)時(shí)間
            self.save_last_time(sub_dir)
        except Exception as ex:
            self.logger.exception(ex)
            raise ex # 往外拋出異常
        finally:
            now_lock.release() # 釋放鎖
    def get_v_last_nation_sales_status(self):
        '''商品暢滯銷數(shù)據(jù)'''
        file_path = os.path.join(self.save_dir,'v_last_nation_sales_status.csv')
        now_lock = self.get_lock(file_path)
        now_lock.acquire() # 加鎖
        try:
            # 設(shè)置超時(shí)4小時(shí)才重新查數(shù)據(jù)
            if not self.get_last_time(file_path):
                return
            sql = 'SELECT * FROM ur_bi_dw.v_last_nation_sales_status'
            data:pd.DataFrame = self.db_helper.get_data(sql)
            columns = list(data.columns)
            columns = {c:c.replace('v_last_nation_sales_status.','') for c in columns}
            data = data.rename(columns=columns)
            data.to_csv(file_path, index=False)
            # 更新超時(shí)時(shí)間
            self.save_last_time(file_path)
        except Exception as ex:
            self.logger.exception(ex)
            raise ex # 往外拋出異常
        finally:
            now_lock.release() # 釋放鎖
    def get_dwd_daily_finacial_goods(self):
        '''商品成本價(jià)數(shù)據(jù)'''
        file_path = os.path.join(self.save_dir,'dwd_daily_finacial_goods.csv')
        now_lock = self.get_lock(file_path)
        now_lock.acquire() # 加鎖
        try:
            # 設(shè)置超時(shí)4小時(shí)才重新查數(shù)據(jù)
            if not self.get_last_time(file_path):
                return
            sql = """
            select t1.sku_no,t1.`size`,t1.cost_tax_incl from ur_bi_dw.dwd_daily_finacial_goods as t1
            inner join (
                select sku_no,`size`,max(date_key) as date_key
                from ur_bi_dw.dwd_daily_finacial_goods
                where currency_code='CNY' and country_code='CN'
                group by sku_no,`size`
            ) as t2
            on t2.sku_no=t1.sku_no
                and t2.`size`=t1.`size`
                and t2.date_key=t1.date_key
            where t1.currency_code='CNY' and t1.country_code='CN'
            """
            data:pd.DataFrame = self.db_helper.get_data(sql)
            columns = list(data.columns)
            columns = {c:c.replace('t1.','') for c in columns}
            data = data.rename(columns=columns)
            data.to_csv(file_path, index=False)
            # 更新超時(shí)時(shí)間
            self.save_last_time(file_path)
        except Exception as ex:
            self.logger.exception(ex)
            raise ex # 往外拋出異常
        finally:
            now_lock.release() # 釋放鎖
    def get_dim_size_group(self):
        '''尺碼映射數(shù)據(jù)'''
        file_path = os.path.join(self.save_dir,'dim_size_group.csv')
        now_lock = self.get_lock(file_path)
        now_lock.acquire() # 加鎖
        try:
            # 設(shè)置超時(shí)4小時(shí)才重新查數(shù)據(jù)
            if not self.get_last_time(file_path):
                return
            sql = """select * from ur_bi_dw.dim_size_group"""
            data:pd.DataFrame = self.db_helper.get_data(sql)
            columns = list(data.columns)
            columns = {c:c.replace('dim_size_group.','') for c in columns}
            data = data.rename(columns=columns)
            data.to_csv(file_path, index=False)
            # 更新超時(shí)時(shí)間
            self.save_last_time(file_path)
        except Exception as ex:
            self.logger.exception(ex)
            raise ex # 往外拋出異常
        finally:
            now_lock.release() # 釋放鎖
pass
def get_common_datas(
    host='10.2.32.22',
    port=21051,
    database='ur_ai_dw',
    auth_mechanism='LDAP',
    user='urbi',
    password='Ur#730xd',
    logger:logging.Logger=None):
    # 共用文件
    common_datas_dir = ShareArgs.get_args_value('common_datas_dir')
    common_ur_bi_dir = os.path.join(common_datas_dir, 'ur_bi_data')
    ur_bi_get_datas = UrBiGetDatas(
        host=host,
        port=port,
        database=database,
        auth_mechanism=auth_mechanism,
        user=user,
        password=password,
        save_dir=common_ur_bi_dir,
        logger=logger
    )
    try:
        logger.info('正在查詢?nèi)掌跀?shù)據(jù)...')
        ur_bi_get_datas.get_dim_date()
        logger.info('查詢?nèi)掌跀?shù)據(jù)完成!')
        logger.info('正在查詢店鋪數(shù)據(jù)...')
        ur_bi_get_datas.get_dim_shop()
        logger.info('查詢店鋪數(shù)據(jù)完成!')
        logger.info('正在查詢天氣數(shù)據(jù)...')
        ur_bi_get_datas.get_weather()
        logger.info('查詢天氣數(shù)據(jù)完成!')
        logger.info('正在查詢天氣城市數(shù)據(jù)...')
        ur_bi_get_datas.get_weather_city()
        logger.info('查詢天氣城市數(shù)據(jù)完成!')
        logger.info('正在查詢貨品數(shù)據(jù)...')
        ur_bi_get_datas.get_dim_goods()
        logger.info('查詢貨品數(shù)據(jù)完成!')
        logger.info('正在查詢實(shí)際銷量數(shù)據(jù)...')
        ur_bi_get_datas.get_dwd_daily_sales_size()
        logger.info('查詢實(shí)際銷量數(shù)據(jù)完成!')
    except Exception as ex:
        logger.exception(ex)
        raise ex # 往外拋出異常
    finally:
        ur_bi_get_datas.close()
pass
class CustomUrBiGetDatas(UrBiGetDatasBase):
    def __init__(
        self,
        host='10.2.32.22',
        port=21051,
        database='ur_ai_dw',
        auth_mechanism='LDAP',
        user='urbi',
        password='Ur#730xd',
        save_dir='./hjx/data/ur_bi_data',
        logger:logging.Logger=None
        ):
        self.save_dir = save_dir
        self.logger = logger
        super().__init__(
            host=host,
            port=port,
            database=database,
            auth_mechanism=auth_mechanism,
            user=user,
            password=password,
            save_dir=save_dir,
            logger=logger
            )
    def get_sales_goal_amt(self):
        '''銷售目標(biāo)金額'''
        file_path = os.path.join(self.save_dir,'month_of_year_sales_goal_amt.csv')
        now_lock = self.get_lock(file_path)
        now_lock.acquire() # 加鎖
        try:
            # 設(shè)置超時(shí)4小時(shí)才重新查數(shù)據(jù)
            if not self.get_last_time(file_path):
                return
            sql = '''
            select sales_goal.shop_no,
                if(sales_goal.serial='Y','W',sales_goal.serial) as `sales_goal.serial`,
                dates.month_of_year,
                sum(sales_goal.sales_goal_amt) as sales_goal_amt
            from ur_bi_dw.dwd_sales_goal_west as sales_goal
            inner join ur_bi_dw.dim_date as dates
                on sales_goal.date_key = dates.date_key
            group by sales_goal.shop_no,
                if(sales_goal.serial='Y','W',sales_goal.serial),
                dates.month_of_year
            '''
            data:pd.DataFrame = self.db_helper.get_data(sql)
            data = data.rename(columns={
                'shop_no':'sales_goal.shop_no',
                'serial':'sales_goal.serial',
                'month_of_year':'dates.month_of_year',
            })
            # 排序
            data = data.sort_values(['sales_goal.shop_no','sales_goal.serial','dates.month_of_year'])
            data.to_csv(file_path)
            # 更新超時(shí)時(shí)間
            self.save_last_time(file_path)
        except Exception as ex:
            self.logger.exception(ex)
            raise ex # 往外拋出異常
        finally:
            now_lock.release() # 釋放鎖
    def get_shop_serial_area(self):
        '''店-系列面積'''
        file_path = os.path.join(self.save_dir,'shop_serial_area.csv')
        now_lock = self.get_lock(file_path)
        now_lock.acquire() # 加鎖
        try:
            # 設(shè)置超時(shí)4小時(shí)才重新查數(shù)據(jù)
            if not self.get_last_time(file_path):
                return
            sql = '''
            select shop_serial_area.shop_no,
                if(shop_serial_area.serial='Y','W',shop_serial_area.serial) as `shop_serial_area.serial`,
                shop_serial_area.month_of_year,
                sum(shop_serial_area.area) as `shop_serial_area.area`
            from ur_bi_dw.dwd_shop_serial_area as shop_serial_area
            where shop_serial_area.area is not null
            group by shop_serial_area.shop_no,if(shop_serial_area.serial='Y','W',shop_serial_area.serial),shop_serial_area.month_of_year
            '''
            data:pd.DataFrame = self.db_helper.get_data(sql)
            data = data.rename(columns={
                'shop_no':'shop_serial_area.shop_no',
                'serial':'shop_serial_area.serial',
                'month_of_year':'shop_serial_area.month_of_year',
                'area':'shop_serial_area.area',
            })
            # 排序
            data = data.sort_values(['shop_serial_area.shop_no','shop_serial_area.serial','shop_serial_area.month_of_year'])
            data.to_csv(file_path)
            # 更新超時(shí)時(shí)間
            self.save_last_time(file_path)
        except Exception as ex:
            self.logger.exception(ex)
            raise ex # 往外拋出異常
        finally:
            now_lock.release() # 釋放鎖
pass
def get_datas(
    host='10.2.32.22',
    port=21051,
    database='ur_ai_dw',
    auth_mechanism='LDAP',
    user='urbi',
    password='Ur#730xd',
    save_dir='./data/sales_forecast/ur_bi_dw_data',
    logger:logging.Logger=None):
    ur_bi_get_datas = CustomUrBiGetDatas(
        host=host,
        port=port,
        database=database,
        auth_mechanism=auth_mechanism,
        user=user,
        password=password,
        save_dir=save_dir,
        logger=logger
    )
    try:
        # 店,系列,品類,年月,銷售目標(biāo)金額
        logger.info('正在查詢年月銷售目標(biāo)金額數(shù)據(jù)...')
        ur_bi_get_datas.get_sales_goal_amt()
        logger.info('查詢年月銷售目標(biāo)金額數(shù)據(jù)完成!')
    except Exception as ex:
        logger.exception(ex)
        raise ex # 往外拋出異常
    finally:
        ur_bi_get_datas.close()
pass
def getdata_ur_bi_dw(
    host='10.2.32.22',
    port=21051,
    database='ur_ai_dw',
    auth_mechanism='LDAP',
    user='urbi',
    password='Ur#730xd',
    save_dir='./data/sales_forecast/ur_bi_dw_data',
    logger=None
):
    get_common_datas(
        host=host,
        port=port,
        database=database,
        auth_mechanism=auth_mechanism,
        user=user,
        password=password,
        logger=logger
    )
    get_datas(
        host=host,
        port=port,
        database=database,
        auth_mechanism=auth_mechanism,
        user=user,
        password=password,
        save_dir=save_dir,
        logger=logger
    )
pass
# 代碼入口
# getdata_ur_bi_dw(
#     host=ur_bi_dw_host,
#     port=ur_bi_dw_port,
#     database=ur_bi_dw_database,
#     auth_mechanism=ur_bi_dw_auth_mechanism,
#     user=ur_bi_dw_user,
#     password=ur_bi_dw_password,
#     save_dir=ur_bi_dw_save_dir,
#     logger=logger
#     )

代碼說明和領(lǐng)悟

每個(gè)類的具體作用說明,代碼需要根據(jù)下面的文字說明進(jìn)行“食用”:

(第一層)HiveHelper完成了連接數(shù)據(jù)庫、關(guān)閉數(shù)據(jù)庫連接、生成事務(wù)、執(zhí)行、引擎、連接等功能

VarsHelper提供了一個(gè)簡單的持久化功能,可以將對(duì)象以文件的形式存放在磁盤上。并提供設(shè)置值、獲取值、判斷值是否存在的方法

GlobalShareArgs提供了一個(gè)字典,并且提供了獲取字典、設(shè)置字典、設(shè)置字典鍵值對(duì)、設(shè)置字典鍵的值、判斷鍵是否在字典中、更新字典等方法

ShareArgs跟GlobalShareArgs類似,只是一開始字典的初始化的鍵值對(duì)比較多

(第二層)UrBiGetDataBase類,提供了線程鎖字典、時(shí)間字典、超時(shí)判斷字典,都是類變量;使用了HiveHelper類,但注意,不是繼承。在具體的sql讀數(shù)時(shí),提供了線程固定和時(shí)間判斷

(第三層)UrBiGetDatas類,獲取hive數(shù)據(jù)庫那邊的日期數(shù)據(jù)、店鋪數(shù)據(jù)、會(huì)員數(shù)據(jù)、天氣數(shù)據(jù)、天氣城市數(shù)據(jù)、商品數(shù)據(jù)、店鋪生命周期數(shù)據(jù)、全國商品生命周期數(shù)據(jù)、商品開發(fā)碼數(shù)數(shù)據(jù)、實(shí)際銷售金額、實(shí)際配貨金額、商品暢滯銷數(shù)據(jù)、商品成本價(jià)數(shù)據(jù)、尺碼映射數(shù)據(jù)等。

(第四層)get_common_data函數(shù),使用URBiGetData類讀取日期、店鋪、天氣、天氣城市、貨品、實(shí)際銷量數(shù)據(jù),并緩存到文件夾./yongjian/data/ur_bi_data下面

CustomUrBiGetData類,繼承了UrBiGetDatasBase類,讀取銷售目標(biāo)金額、點(diǎn)系列面積數(shù)據(jù)。

(這個(gè)也是第四層)get_datas函數(shù),通過CustomUrBiGetData類,讀取年月銷售目標(biāo)金額。

總的函數(shù):(這個(gè)是總的調(diào)用入口函數(shù))get_data_ur_bi_dw函數(shù),調(diào)用了get_common_data和get_datas函數(shù)進(jìn)行讀取數(shù)據(jù),然后將數(shù)據(jù)保存到某個(gè)文件夾目錄下面。

舉一反三,如果你不是hive數(shù)據(jù)庫,你可以將第一層這個(gè)底層更換成mysql。主頁有解釋如果進(jìn)行更換。第二層不需要改變,第三層就是你想要進(jìn)行讀取的數(shù)據(jù)表,不同的數(shù)據(jù)庫你想要讀取的數(shù)據(jù)表也不同,所以sql需要你在這里寫,套用里面的方法即可,基本上就是修改sql就好了。

這種方法的好處在于,數(shù)據(jù)不會(huì)重復(fù)讀取,并且讀取的數(shù)據(jù)都可以得到高效的使用。

后續(xù)附上修改成mysql的一個(gè)例子代碼

import logging
import pandas as pd
from impala.dbapi import connect
import sqlalchemy
from sqlalchemy.orm import sessionmaker
import os
import time
import os
import datetime
from dateutil.relativedelta import relativedelta
from typing import Dict, List
import logging
import threading
import pandas as pd
import pickle
class MySqlHelper(object):
    def __init__(
        self,
        host='192.168.15.144',
        port=3306,
        database='test_ims',
        user='spkjz_writer',
        password='7cmoP3QDtueVJQj2q4Az',
        logger:logging.Logger=None
        ):
        self.host = host
        self.port = port
        self.database = database
        self.user = user
        self.password = password
        self.logger = logger
        self.connection_str = 'mysql+pymysql://%s:%s@%s:%d/%s' %(
            self.user, self.password, self.host, self.port, self.database
        )
        self.conn = None
        self.cursor = None
        self.engine = None
        self.session = None
    def create_table_code(self, file_name):
        '''創(chuàng)建表類代碼'''
        os.system(f'sqlacodegen {self.connection_str} > {file_name}')
        return self.conn
    def get_conn(self):
        '''創(chuàng)建連接或獲取連接'''
        if self.conn is None:
            engine = self.get_engine()
            self.conn = engine.connect()
        return self.conn
    def get_engine(self):
        '''創(chuàng)建連接或獲取連接'''
        if self.engine is None:
            self.engine = sqlalchemy.create_engine(self.connection_str)
        return self.engine
    def get_cursor(self):
        '''創(chuàng)建連接或獲取連接'''
        if self.cursor is None:
            self.cursor = self.conn.cursor()
        return self.cursor
    def get_session(self) -> sessionmaker:
        '''創(chuàng)建連接或獲取連接'''
        if self.session is None:
            engine = self.get_engine()
            Session = sessionmaker(bind=engine)
            self.session = Session()
        return self.session
    def close_conn(self):
        '''關(guān)閉連接'''
        if self.conn is not None:
            self.conn.close()
            self.conn = None
        self.dispose_engine()
    def close_session(self):
        '''關(guān)閉連接'''
        if self.session is not None:
            self.session.close()
            self.session = None
        self.dispose_engine()
    def dispose_engine(self):
        '''釋放engine'''
        if self.engine is not None:
            # self.engine.dispose(close=False)
            self.engine.dispose()
            self.engine = None
    def close_cursor(self):
        '''關(guān)閉cursor'''
        if self.cursor is not None:
            self.cursor.close()
            self.cursor = None
    def get_data(self, sql, auto_close=True) -> pd.DataFrame:
        '''查詢數(shù)據(jù)'''
        conn = self.get_conn()
        data = None
        try:
            # 異常重試3次
            for i in range(3):
                try:
                    data = pd.read_sql(sql, conn)
                    break
                except Exception as ex:
                    if i == 2:
                        raise ex # 往外拋出異常
                    time.sleep(60) # 一分鐘后重試
        except Exception as ex:
            self.logger.exception(ex)
            raise ex # 往外拋出異常
        finally:
            if auto_close:
                self.close_conn()
        return data
pass
class VarsHelper():
    def __init__(self, save_dir, auto_save=True):
        self.save_dir = save_dir
        self.auto_save = auto_save
        self.values = {}
        if not os.path.exists(os.path.dirname(self.save_dir)):
            os.makedirs(os.path.dirname(self.save_dir))
        if os.path.exists(self.save_dir):
            with open(self.save_dir, 'rb') as f:
                self.values = pickle.load(f)
                f.close()
    def set_value(self, key, value):
        self.values[key] = value
        if self.auto_save:
            self.save_file()
    def get_value(self, key):
        return self.values[key]
    def has_key(self, key):
        return key in self.values.keys()
    def save_file(self):
        with open(self.save_dir, 'wb') as f:
            pickle.dump(self.values, f)
            f.close()
pass
class GlobalShareArgs():
    args = {
        "debug": False
    }
    def get_args():
        return GlobalShareArgs.args
    def set_args(args):
        GlobalShareArgs.args = args
    def set_args_value(key, value):
        GlobalShareArgs.args[key] = value
    def get_args_value(key, default_value=None):
        return GlobalShareArgs.args.get(key, default_value)
    def contain_key(key):
        return key in GlobalShareArgs.args.keys()
    def update(args):
        GlobalShareArgs.args.update(args)
pass
class ShareArgs():
    args = {
        "labels_dir":"./hjx/shop_group/month_w_amt/data/labels", # 標(biāo)簽?zāi)夸?
        "labels_output_dir":"./hjx/shop_group/month_w_amt/data/labels_output", # 聚類導(dǎo)出標(biāo)簽?zāi)夸?
        "common_datas_dir":"./hjx/data", # 共用數(shù)據(jù)目錄。ur_bi_dw的公共
        "only_predict": False, # 只識(shí)別,不訓(xùn)練
        "delete_model": True, # 先刪除模型,僅在訓(xùn)練時(shí)使用
        "export_excel": False, # 導(dǎo)出excel
        "classes": 12, # 聚類數(shù)
        "batch_size": 16,
        "hidden_size": 32,
        "max_nrof_epochs": 100,
        "learning_rate": 0.0005,
        "loss_type": "categorical_crossentropy",
        "avg_model_num": 10,
        "steps_per_epoch": 4.0, # 4.0
        "lr_callback_patience": 4, 
        "lr_callback_cooldown": 1,
        "early_stopping_callback_patience": 6,
        "get_data": True,
    }
    def get_args():
        return ShareArgs.args
    def set_args(args):
        ShareArgs.args = args
    def set_args_value(key, value):
        ShareArgs.args[key] = value
    def get_args_value(key, default_value=None):
        return ShareArgs.args.get(key, default_value)
    def contain_key(key):
        return key in ShareArgs.args.keys()
    def update(args):
        ShareArgs.args.update(args)
pass
class IMSGetDatasBase():
    # 線程鎖列表,同保存路徑共用鎖
    lock_dict:Dict[str, threading.Lock] = {}
    # 時(shí)間列表,用于判斷是否超時(shí)
    time_dict:Dict[str, datetime.datetime] = {}
    # 用于記錄是否需要更新超時(shí)時(shí)間
    get_data_timeout_dict:Dict[str, bool] = {}
    def __init__(
        self,
        host='192.168.15.144',
        port=3306,
        database='test_ims',
        user='spkjz_writer',
        password='Ur#7cmoP3QDtueVJQj2q4Az',
        save_dir=None,
        logger:logging.Logger=None,
        ):
        self.save_dir = save_dir
        self.logger = logger
        self.db_helper = MySqlHelper(
            host=host,
            port=port,
            database=database,
            user=user,
            password=password,
            logger=logger
            )
        # 創(chuàng)建子目錄
        if self.save_dir is not None and not os.path.exists(self.save_dir):
            os.makedirs(self.save_dir)
        self.vars_helper = None
        if GlobalShareArgs.get_args_value('debug'):
            self.vars_helper = VarsHelper('./hjx/data/vars/IMSGetDatas') # 把超時(shí)時(shí)間保存到文件,注釋該行即可停掉,只用于調(diào)試
    def close(self):
        '''關(guān)閉連接'''
        self.db_helper.close_conn()
    def get_last_time(self, key_name) -> bool:
        '''獲取是否超時(shí)'''
        # 轉(zhuǎn)靜態(tài)路徑,確保唯一性
        key_name = os.path.abspath(key_name)
        if self.vars_helper is not None and self.vars_helper.has_key('IMSGetDatasBase.time_list'):
            IMSGetDatasBase.time_dict = self.vars_helper.get_value('IMSGetDatasBase.time_list')
        timeout = 12 # 12小時(shí)
        if GlobalShareArgs.get_args_value('debug'):
            timeout = 24 # 24小時(shí)
        get_data_timeout = False
        if key_name not in IMSGetDatasBase.time_dict.keys() or (datetime.datetime.today() - IMSGetDatasBase.time_dict[key_name]).total_seconds()>(4*60*60):
            self.logger.info('超時(shí)%d小時(shí),重新查數(shù)據(jù):%s', timeout, key_name)
            # IMSGetDatasBase.time_list[key_name] = datetime.datetime.today()
            get_data_timeout = True
        else:
            self.logger.info('未超時(shí)%d小時(shí),跳過查數(shù)據(jù):%s', timeout, key_name)
        # if self.vars_helper is not None :
        #     self.vars_helper.set_value('IMSGetDatasBase.time_list', IMSGetDatasBase.time_list)
        IMSGetDatasBase.get_data_timeout_dict[key_name] = get_data_timeout
        return get_data_timeout
    def save_last_time(self, key_name):
        '''更新狀態(tài)超時(shí)'''
        # 轉(zhuǎn)靜態(tài)路徑,確保唯一性
        key_name = os.path.abspath(key_name)
        if IMSGetDatasBase.get_data_timeout_dict[key_name]:
            IMSGetDatasBase.time_dict[key_name] = datetime.datetime.today()
        if self.vars_helper is not None :
            IMSGetDatasBase.time_dict[key_name] = datetime.datetime.today()
            self.vars_helper.set_value('IMSGetDatasBase.time_list', IMSGetDatasBase.time_dict)
    def get_lock(self, key_name) -> threading.Lock:
        '''獲取鎖'''
        # 轉(zhuǎn)靜態(tài)路徑,確保唯一性
        key_name = os.path.abspath(key_name)
        if key_name not in IMSGetDatasBase.lock_dict.keys():
            IMSGetDatasBase.lock_dict[key_name] = threading.Lock()
        return IMSGetDatasBase.lock_dict[key_name]
    def get_data_of_date(
        self,
        save_dir,
        sql,
        sort_columns:List[str],
        del_index_list=[-1], # 刪除最后下標(biāo)
        start_date = datetime.datetime(2017, 1, 1), # 開始時(shí)間
        offset = relativedelta(months=3), # 時(shí)間間隔
        date_format_fun = lambda d: '%04d%02d01' % (d.year, d.month), # 查詢語句中替代時(shí)間參數(shù)的格式化
        filename_format_fun = lambda d: '%04d%02d.csv' % (d.year, d.month), # 查詢語句中替代時(shí)間參數(shù)的格式化
        stop_date = '20700101', # 超過時(shí)間則停止
        ):
        '''分時(shí)間增量讀取數(shù)據(jù)'''
        # 創(chuàng)建文件夾
        if not os.path.exists(save_dir):
            os.makedirs(save_dir)
        else:
            #刪除最后一個(gè)文件
            file_list = os.listdir(save_dir)
            if len(file_list)>0:
                file_list.sort()
                for del_index in del_index_list:
                    os.remove(os.path.join(save_dir,file_list[del_index]))
                    print('刪除最后一個(gè)文件:', file_list[del_index])
        select_index = -1
        # start_date = datetime.datetime(2017, 1, 1)
        while True:
            end_date = start_date + offset
            start_date_str = date_format_fun(start_date)
            end_date_str = date_format_fun(end_date)
            self.logger.info('date: %s-%s', start_date_str, end_date_str)
            file_path = os.path.join(save_dir, filename_format_fun(start_date))
            # self.logger.info('file_path: %s', file_path)
            if not os.path.exists(file_path):
                data:pd.DataFrame = self.db_helper.get_data(sql % (start_date_str, end_date_str))
                if data is None:
                    break
                self.logger.info('data: %d', len(data))
                # self.logger.info('data: %d', data.columns)
                if len(data)>0:
                    select_index+=1
                    # 排序
                    data = data.sort_values(sort_columns)
                    data.to_csv(file_path)
                elif select_index!=-1:
                    break
                elif stop_date < start_date_str:
                    raise Exception("讀取數(shù)據(jù)異常,時(shí)間超出最大值!")
            start_date = end_date
pass
class CustomIMSGetDatas(IMSGetDatasBase):
    def __init__(
        self,
        host='192.168.13.134',
        port=4000,
        database='test_ims',
        user='root',
        password='rootimmsadmin',
        save_dir='./hjx/data/export_ims_data',
        logger:logging.Logger=None
        ):
        self.save_dir = save_dir
        self.logger = logger
        super().__init__(
            host=host,
            port=port,
            database=database,
            user=user,
            password=password,
            save_dir=save_dir,
            logger=logger
            )
    def get_ims_w_amt_pro(self):
        '''年月系列占比數(shù)據(jù)'''
        file_path = os.path.join(self.save_dir,'ims_w_amt_pro.csv')
        now_lock = self.get_lock(file_path)
        now_lock.acquire() # 加鎖
        try:
            # 設(shè)置超時(shí)4小時(shí)才重新查數(shù)據(jù)
            # if not self.get_last_time(file_path):
            #     return
            sql = 'SELECT * FROM ims_w_amt_pro'
            data:pd.DataFrame = self.db_helper.get_data(sql)
            data = data.rename(columns={
                'serial_forecast_proportion': 'forecast_proportion',
            })
            data.to_csv(file_path)
            # # 更新超時(shí)時(shí)間
            # self.save_last_time(file_path)
        except Exception as ex:
            self.logger.exception(ex)
            raise ex # 往外拋出異常
        finally:
            now_lock.release() # 釋放鎖
pass
def get_datas(
    host='192.168.13.134',
    port=4000,
    database='test_ims',
    user='root',
    password='rootimmsadmin',
    save_dir='./hjx/data/export_ims_data',
    logger:logging.Logger=None
    ):
    ur_bi_get_datas = CustomIMSGetDatas(
        host=host,
        port=port,
        database=database,
        user=user,
        password=password,
        save_dir=save_dir,
        logger=logger
    )
    try:
        # 年月系列占比數(shù)據(jù)
        logger.info('正在查詢年月系列占比數(shù)據(jù)...')
        ur_bi_get_datas.get_ims_w_amt_pro()
        logger.info('查詢年月系列占比數(shù)據(jù)完成!')
    except Exception as ex:
        logger.exception(ex)
        raise ex # 往外拋出異常
    finally:
        ur_bi_get_datas.close()
pass
def getdata_export_ims(
    host='192.168.13.134',
    port=4000,
    database='test_ims',
    user='root',
    password='rootimmsadmin',
    save_dir='./hjx/data/export_ims_data',
    logger:logging.Logger=None
    ):
    get_datas(
        host=host,
        port=port,
        database=database,
        user=user,
        password=password,
        save_dir=save_dir,
        logger=logger
    )
pass

到此這篇關(guān)于Python讀取Hive數(shù)據(jù)庫實(shí)現(xiàn)代碼詳解的文章就介紹到這了,更多相關(guān)Python讀取Hive數(shù)據(jù)庫內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python 郵箱登錄驗(yàn)證碼功能實(shí)現(xiàn)代碼

    Python 郵箱登錄驗(yàn)證碼功能實(shí)現(xiàn)代碼

    本文介紹了結(jié)合前端校驗(yàn)和后端Redis緩存策略實(shí)現(xiàn)郵箱登錄的功能,旨在提高安全性和效率,前端校驗(yàn)郵箱格式,后端生成并發(fā)送驗(yàn)證碼,使用Redis緩存驗(yàn)證碼以提高效率和安全性,感興趣的朋友一起看看吧
    2024-12-12
  • python調(diào)用機(jī)器喇叭發(fā)出蜂鳴聲(Beep)的方法

    python調(diào)用機(jī)器喇叭發(fā)出蜂鳴聲(Beep)的方法

    這篇文章主要介紹了python調(diào)用機(jī)器喇叭發(fā)出蜂鳴聲(Beep)的方法,實(shí)例分析了Python調(diào)用winsound模塊的使用技巧,需要的朋友可以參考下
    2015-03-03
  • python基礎(chǔ)之匿名函數(shù)詳解

    python基礎(chǔ)之匿名函數(shù)詳解

    這篇文章主要介紹了python基礎(chǔ)之匿名函數(shù)詳解,文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)python基礎(chǔ)的小伙伴們有很好的幫助,需要的朋友可以參考下
    2021-04-04
  • 淺談Python中重載isinstance繼承關(guān)系的問題

    淺談Python中重載isinstance繼承關(guān)系的問題

    本篇文章主要介紹了淺談Python中重載isinstance繼承關(guān)系的問題,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-05-05
  • python如何對(duì)圖片或文件的操作

    python如何對(duì)圖片或文件的操作

    在日常編程中,我們經(jīng)常會(huì)遇到文件處理的需求,如base64與圖片的相互轉(zhuǎn)換、圖片與像素點(diǎn)的操作、本地文件與二進(jìn)制的互相轉(zhuǎn)換、計(jì)算文件的md5以及下載網(wǎng)絡(luò)文件等,這些操作對(duì)于處理多媒體數(shù)據(jù)、實(shí)現(xiàn)數(shù)據(jù)的持久化存儲(chǔ)、保證數(shù)據(jù)的完整性和安全性等方面都至關(guān)重要
    2024-09-09
  • 用 Python 定義 Schema 并生成 Parquet 文件詳情

    用 Python 定義 Schema 并生成 Parquet 文件詳情

    本文將演示兩個(gè)例子,一個(gè)是沒有層級(jí)的兩個(gè)字段,另一個(gè)是含于嵌套級(jí)別的字段,將要使用到的 Python 模塊有 pandas 和 pyarrow,感興趣是我小伙伴請(qǐng)和小編一起學(xué)習(xí)下面文章內(nèi)容吧
    2021-09-09
  • Python配置文件管理之ini和yaml文件讀取的實(shí)現(xiàn)

    Python配置文件管理之ini和yaml文件讀取的實(shí)現(xiàn)

    本文主要介紹了Python配置文件管理之ini和yaml文件讀取,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-02-02
  • python操作gmail實(shí)例

    python操作gmail實(shí)例

    這篇文章主要介紹了python操作gmail的方法,實(shí)例分析了python針對(duì)gmail操作的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-01-01
  • python樹莓派通過隊(duì)列實(shí)現(xiàn)進(jìn)程交互的程序分析

    python樹莓派通過隊(duì)列實(shí)現(xiàn)進(jìn)程交互的程序分析

    這篇博客就結(jié)合實(shí)際的python程序通過隊(duì)列實(shí)現(xiàn)進(jìn)程交互,通過程序分析需要的庫函數(shù),對(duì)python樹莓派進(jìn)程交互相關(guān)知識(shí)感興趣的朋友一起看看吧
    2021-07-07
  • 詳解pyinstaller selenium python3 chrome打包問題

    詳解pyinstaller selenium python3 chrome打包問題

    這篇文章主要介紹了詳解pyinstaller selenium python3 chrome打包問題,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10

最新評(píng)論

亚洲高清免费在线观看视频| 天天干天天爱天天色| 五十路熟女av天堂| 三级av中文字幕在线观看| 日本人竟这样玩学生妹| 天天干天天日天天谢综合156| 啪啪啪啪啪啪啪免费视频| 黄页网视频在线免费观看| 亚洲午夜伦理视频在线| 日本熟女精品一区二区三区| 久久精品视频一区二区三区四区| 狠狠躁夜夜躁人人爽天天久天啪| 自拍偷拍日韩欧美亚洲| 午夜精品九一唐人麻豆嫩草成人| 亚洲天堂有码中文字幕视频| 免费黄高清无码国产| 成人乱码一区二区三区av| 香蕉片在线观看av| 国产精品日韩欧美一区二区| 成人色综合中文字幕| 午夜激情久久不卡一区二区 | 亚洲国产最大av综合| japanese日本熟妇另类| 亚洲天堂精品福利成人av| 午夜免费观看精品视频| 和邻居少妇愉情中文字幕| 国产揄拍高清国内精品对白 | 欧美另类重口味极品在线观看| 欧美一区二区三区久久久aaa| 超碰公开大香蕉97| 日本韩国在线观看一区二区| 国产熟妇乱妇熟色T区| 青草久久视频在线观看| 欧美黑人与人妻精品| 亚洲天堂精品福利成人av| 免费在线福利小视频| 欧美日韩在线精品一区二区三| 91精品免费久久久久久| 国产精品久久综合久久| 91chinese在线视频| 色综合天天综合网国产成人| 天天操天天干天天日狠狠插 | 超碰在线观看免费在线观看| 欧美一区二区三区激情啪啪啪 | 99一区二区在线观看| 国产伊人免费在线播放| 日噜噜噜夜夜噜噜噜天天噜噜噜 | 日本韩国亚洲综合日韩欧美国产| 婷婷午夜国产精品久久久| 亚洲一级 片内射视正片| 女人精品内射国产99| 国产精品人久久久久久| 国产视频一区二区午夜| 精品久久久久久久久久久a√国产 日本女大学生的黄色小视频 | 国产成人小视频在线观看无遮挡| 中文字幕在线永久免费播放| 中文字幕高清在线免费播放| 日韩欧美亚洲熟女人妻| 久久午夜夜伦痒痒想咳嗽P| 1000部国产精品成人观看视频| 国产午夜激情福利小视频在线| av久久精品北条麻妃av观看| 久久综合老鸭窝色综合久久| 老司机99精品视频在线观看| 亚洲老熟妇日本老妇| 农村胖女人操逼视频| 国产内射中出在线观看| 亚洲精品欧美日韩在线播放| 伊人情人综合成人久久网小说| 在线观看一区二区三级| 国产黄色片在线收看| 亚洲av无硬久久精品蜜桃| 久久久久久久久久一区二区三区| 国产乱子伦一二三区| 国产精品亚洲а∨天堂免| 日韩一区二区三区三州| 含骚鸡巴玩逼逼视频| 91精品国产观看免费| 2018最新中文字幕在线观看| 亚洲成人黄色一区二区三区| 在线免费91激情四射 | 成人资源在线观看免费官网| 国产精彩对白一区二区三区| 日本一二三区不卡无| 国产麻豆乱子伦午夜视频观看| 黄色av网站免费在线| 动漫美女的小穴视频| 丰满少妇人妻xxxxx| 美女大bxxxx内射| 中文字幕人妻被公上司喝醉在线| 3D动漫精品啪啪一区二区下载| 5528327男人天堂| 国产一区二区神马久久| 中文字幕最新久久久| 五十路av熟女松本翔子| 蜜桃精品久久久一区二区| 午夜精品在线视频一区| 亚洲午夜电影在线观看| 欧美一区二区三区久久久aaa| 一区二区三区日韩久久| 欧美地区一二三专区| 自拍偷拍亚洲欧美在线视频| 日韩影片一区二区三区不卡免费 | 成人国产影院在线观看| 日本欧美视频在线观看三区| 欧美在线一二三视频| 国产日韩精品免费在线| 午夜频道成人在线91| 精品高跟鞋丝袜一区二区| 一本久久精品一区二区| 亚洲中文字幕国产日韩| 国产精品黄片免费在线观看| 成人区人妻精品一区二视频| 人妻3p真实偷拍一二区| 天天日天天干天天要| 这里有精品成人国产99| 亚国产成人精品久久久| 欧美亚洲中文字幕一区二区三区| av高潮迭起在线观看| 欧美交性又色又爽又黄麻豆| 一级黄片大鸡巴插入美女| 国产精品人久久久久久| 在线国产日韩欧美视频| 日本www中文字幕| 91国内精品自线在拍白富美| 亚洲高清视频在线不卡| 亚洲高清国产拍青青草原| 可以在线观看的av中文字幕| 久久人人做人人妻人人玩精品vr| 黄色在线观看免费观看在线| 精品av国产一区二区三区四区| 丝袜肉丝一区二区三区四区在线| 国产高清女主播在线| tube69日本少妇| AV天堂一区二区免费试看| 国产精品自拍偷拍a| 国产91嫩草久久成人在线视频| 91麻豆精品久久久久| 午夜福利人人妻人人澡人人爽| 黄色在线观看免费观看在线| 18禁免费av网站| 红杏久久av人妻一区| av完全免费在线观看av| 亚洲 自拍 色综合图| 91香蕉成人app下载| 韩国AV无码不卡在线播放 | 好太好爽好想要免费| 天码人妻一区二区三区在线看| 亚洲国产在线精品国偷产拍| 懂色av之国产精品| 99精品视频在线观看婷婷| 激情色图一区二区三区| 不卡日韩av在线观看| av视网站在线观看| 精品久久久久久久久久久99| 免费十精品十国产网站| 精品国产亚洲av一淫| 大鸡吧插逼逼视频免费看| 国产综合高清在线观看| 精品视频中文字幕在线播放| 狠狠躁夜夜躁人人爽天天久天啪| 青青青青青操视频在线观看| 日韩欧美高清免费在线 | 日本韩国亚洲综合日韩欧美国产| 色呦呦视频在线观看视频| 在线网站你懂得老司机| 快点插进来操我逼啊视频| 四虎永久在线精品免费区二区| 偷拍自拍亚洲视频在线观看| av中文字幕网址在线| 又粗又长 明星操逼小视频| 一二三区在线观看视频| 亚洲一区二区三区久久受| 在线观看视频一区麻豆| 57pao国产一区二区| okirakuhuhu在线观看| 男大肉棒猛烈插女免费视频| 亚洲中文字幕乱码区| 男人天堂色男人av| 二区中出在线观看老师 | 激情人妻校园春色亚洲欧美| 97精品人妻一区二区三区精品| 亚洲偷自拍高清视频| 国产精品大陆在线2019不卡| 91中文字幕免费在线观看| 丝袜长腿第一页在线| av日韩在线免费播放| 97a片免费在线观看| 97欧洲一区二区精品免费| 福利在线视频网址导航| 97超碰最新免费在线观看| 91国语爽死我了不卡| 2021久久免费视频| 视频在线亚洲一区二区| 青青在线视频性感少妇和隔壁黑丝| 99一区二区在线观看| 国产va精品免费观看| 国产一级麻豆精品免费| 国产在线拍揄自揄视频网站| 亚洲公开视频在线观看| 免费在线看的黄网站| 欧美地区一二三专区| 大屁股肉感人妻中文字幕在线| 九色视频在线观看免费| 精品一区二区三区三区色爱| 丝袜国产专区在线观看| 春色激情网欧美成人| 美女吃鸡巴操逼高潮视频| av在线观看网址av| 成年女人免费播放视频| 在线国产中文字幕视频| 婷婷六月天中文字幕| 骚货自慰被发现爆操| 久草视频在线看免费| 亚洲成高清a人片在线观看| 日韩精品电影亚洲一区| 在线不卡日韩视频播放| 人妻3p真实偷拍一二区| 亚洲av日韩高清hd| 国产刺激激情美女网站| 亚洲高清一区二区三区视频在线| 亚洲av日韩高清hd| 国产在线一区二区三区麻酥酥| 日本黄在免费看视频| 97少妇精品在线观看| 国产成人精品av网站| 五月天色婷婷在线观看视频免费| 狠狠地躁夜夜躁日日躁| 亚洲午夜伦理视频在线| 国产视频精品资源网站| 国产一区二区久久久裸臀| 同居了嫂子在线播高清中文| 夏目彩春在线中文字幕| 欧美精品伦理三区四区| 在线制服丝袜中文字幕| 粉嫩欧美美人妻小视频| 国产黄色a级三级三级三级| 一区二区久久成人网| 亚洲嫩模一区二区三区| 中国黄片视频一区91| 免费成人va在线观看| 狠狠躁夜夜躁人人爽天天久天啪| av新中文天堂在线网址| 2018在线福利视频| 视频在线亚洲一区二区| 男女啪啪视频免费在线观看| 欧美成人综合视频一区二区| 日本丰满熟妇BBXBBXHD| 亚洲av色图18p| 57pao国产一区二区| 好了av中文字幕在线| 18禁污污污app下载| 久草电影免费在线观看| 亚洲色偷偷综合亚洲AV伊人| 自拍偷拍亚洲欧美在线视频| 欧美精品一二三视频| 免费福利av在线一区二区三区| 揄拍成人国产精品免费看视频 | 班长撕开乳罩揉我胸好爽| 人人爱人人妻人人澡39| 亚洲在线观看中文字幕av| 国产成人一区二区三区电影网站| 欧美亚洲中文字幕一区二区三区| 一区国内二区日韩三区欧美| 成人乱码一区二区三区av| 青青青青青手机视频| 亚洲欧美综合在线探花| 国产白嫩美女一区二区| 亚洲午夜高清在线观看| 91免费黄片可看视频 | 亚洲在线观看中文字幕av| 中文字幕免费在线免费| 爱爱免费在线观看视频| 国产麻豆国语对白露脸剧情| 成人久久精品一区二区三区 | 亚洲精品午夜aaa久久| 欧美视频不卡一区四区| 在线观看视频 你懂的| 在线观看911精品国产| 我想看操逼黄色大片| 91九色国产porny蝌蚪| 国产熟妇人妻ⅹxxxx麻豆| 欧美一区二区三区激情啪啪啪| 国产高清精品极品美女| 亚洲 欧美 精品 激情 偷拍| 经典av尤物一区二区| 青青青视频自偷自拍38碰| 欧美成人综合视频一区二区 | 国产久久久精品毛片| 人人人妻人人澡人人| 免费在线播放a级片| 中文字幕高清资源站| 国产又粗又硬又大视频| 国产av自拍偷拍盛宴| 阴茎插到阴道里面的视频| 欧美乱妇无乱码一区二区| 久久精品美女免费视频| 极品性荡少妇一区二区色欲| 国产乱子伦精品视频潮优女| 午夜久久久久久久99| 97人妻无码AV碰碰视频| 国产精品国产三级国产午| 国产又粗又黄又硬又爽| 欧美日韩中文字幕欧美| 天天色天天舔天天射天天爽| 黄色的网站在线免费看| 91久久精品色伊人6882| 福利国产视频在线观看| 国产欧美精品免费观看视频| 日韩不卡中文在线视频网站| 国产高清97在线观看视频| 日本熟妇色熟妇在线观看| 热99re69精品8在线播放| 毛片一级完整版免费| 日本免费视频午夜福利视频| 大香蕉大香蕉大香蕉大香蕉大香蕉| 自拍偷拍一区二区三区图片| 久草视频中文字幕在线观看| 熟妇一区二区三区高清版| 自拍偷拍 国产资源| 91小伙伴中女熟女高潮| 久久热久久视频在线观看| 免费在线观看污污视频网站| 欧美激情精品在线观看| 青青热久免费精品视频在线观看| 伊人成人综合开心网| 鸡巴操逼一级黄色气| 无码精品一区二区三区人| 肏插流水妹子在线乐播下载| 国产福利在线视频一区| 亚洲 自拍 色综合图| 成人免费公开视频无毒| 自拍偷拍日韩欧美一区二区| 亚洲中文字字幕乱码| 18禁污污污app下载| 美女视频福利免费看| 风流唐伯虎电视剧在线观看| 国产极品精品免费视频| 亚洲精品午夜久久久久| 黄页网视频在线免费观看 | 性色蜜臀av一区二区三区| 成人国产小视频在线观看| 天天日天天爽天天爽| 97人人妻人人澡人人爽人人精品| 日韩欧美亚洲熟女人妻| 国产精品午夜国产小视频| 日韩三级电影华丽的外出| 亚洲区欧美区另类最新章节| v888av在线观看视频| 久久99久久99精品影院| 日本韩国亚洲综合日韩欧美国产| 欧美成人一二三在线网| av手机在线观播放网站| 老鸭窝在线观看一区| 精品久久婷婷免费视频| 人妻av无码专区久久绿巨人| 中文字幕日韩人妻在线三区| 国产性色生活片毛片春晓精品| 少妇人妻100系列| 精品久久久久久久久久久a√国产| 日韩av有码一区二区三区4| 福利在线视频网址导航| 国产高清在线在线视频| brazzers欧熟精品系列| 高潮视频在线快速观看国家快速| 天天干天天搞天天摸| 国产麻豆剧果冻传媒app| 欧美老鸡巴日小嫩逼| 日韩成人综艺在线播放| 天天日天天天天天天天天天天| 午夜久久香蕉电影网| 性生活第二下硬不起来| 国际av大片在线免费观看| 夜色17s精品人妻熟女| 亚洲av日韩av网站| 午夜免费观看精品视频| 欧美一区二区三区四区性视频| 日韩a级黄色小视频| jul—619中文字幕在线| 高清一区二区欧美系列| 在线网站你懂得老司机| 天天日天天干天天干天天日| 38av一区二区三区| 可以免费看的www视频你懂的| 亚洲高清免费在线观看视频| 97人妻夜夜爽二区欧美极品| 亚洲免费va在线播放| 国产麻豆剧传媒精品国产av蜜桃| 宅男噜噜噜666国产| 亚洲高清一区二区三区视频在线| 大香蕉伊人中文字幕| av老司机亚洲一区二区| 99精品视频之69精品视频| 国产免费高清视频视频| 亚洲女人的天堂av| 快点插进来操我逼啊视频| 韩国男女黄色在线观看| 自拍偷拍vs一区二区三区| 亚洲熟妇久久无码精品| 国产又粗又黄又硬又爽| 色综合天天综合网国产成人| 大鸡巴后入爆操大屁股美女| 日美女屁股黄邑视频| 亚洲午夜电影在线观看| 999九九久久久精品| 亚洲日本一区二区久久久精品| av天堂资源最新版在线看| 亚洲欧美国产综合777| 鸡巴操逼一级黄色气| 成人免费做爰高潮视频| 国产精品自拍偷拍a| 成人av天堂丝袜在线观看| 天天日夜夜操天天摸| 青娱乐极品视频青青草| 欧美精品免费aaaaaa| 日本午夜久久女同精女女| 欧美日本aⅴ免费视频| 伊人开心婷婷国产av| 亚洲中文字幕校园春色| 玩弄人妻熟妇性色av少妇| 久草福利电影在线观看| 19一区二区三区在线播放| 日本xx片在线观看| 中文字幕 亚洲av| 免费在线看的黄网站| 日韩视频一区二区免费观看| 日韩精品啪啪视频一道免费| 最新中文字幕免费视频| 久久久久久cao我的性感人妻| 日本一二三中文字幕| 亚国产成人精品久久久| 91超碰青青中文字幕| 欧美一区二区三区激情啪啪啪| 精品一线二线三线日本| 99婷婷在线观看视频| 在线免费91激情四射| 欧美黑人巨大性xxxxx猛交| 2019av在线视频| 亚洲一区制服丝袜美腿| 我想看操逼黄色大片| www日韩毛片av| 成人av在线资源网站| 日本少妇精品免费视频| 啊用力插好舒服视频| 熟女视频一区,二区,三区| 精品人妻每日一部精品| 国产97在线视频观看| 粉嫩av蜜乳av蜜臀| 绝色少妇高潮3在线观看| 19一区二区三区在线播放| 熟女人妻在线观看视频| 欧美成人综合视频一区二区| 欧美日韩亚洲国产无线码| 人妻少妇一区二区三区蜜桃| 91精品资源免费观看| 2021天天色天天干| gay gay男男瑟瑟在线网站| 又色又爽又黄又刺激av网站| 国产午夜无码福利在线看| 高清一区二区欧美系列| 18禁无翼鸟成人在线| 日韩欧美在线观看不卡一区二区| sw137 中文字幕 在线| 亚洲第一黄色在线观看| 人人人妻人人澡人人| 青青色国产视频在线| 亚洲综合一区二区精品久久| 91人妻精品一区二区在线看| 国产欧美精品一区二区高清| 在线免费视频 自拍| 成人av电影免费版| 天天操天天插天天色| 中文字幕AV在线免费看 | 三上悠亚和黑人665番号| 黄页网视频在线免费观看| 97精品人妻一区二区三区精品| 欧美日韩人妻久久精品高清国产| 中文字幕奴隷色的舞台50| 狠狠的往里顶撞h百合| 日本少妇人妻xxxxx18| 操日韩美女视频在线免费看| 国产成人综合一区2区| 一区二区三区蜜臀在线| 一区二区三区日本伦理| 成人av中文字幕一区| 国产视频网站一区二区三区| 欧美视频中文一区二区三区| 中文字幕,亚洲人妻| 日日夜夜狠狠干视频| 高清一区二区欧美系列| 欧美日韩中文字幕欧美| 99婷婷在线观看视频| gay gay男男瑟瑟在线网站| 日本精品视频不卡一二三| 国产变态另类在线观看| 久久综合老鸭窝色综合久久| 熟女人妻在线中出观看完整版| 91精品视频在线观看免费| 成人sm视频在线观看| 亚洲图片偷拍自拍区| 国内精品在线播放第一页| 福利午夜视频在线观看| 在线观看欧美黄片一区二区三区| 99精品亚洲av无码国产另类| 92福利视频午夜1000看| 人人爽亚洲av人人爽av| 国产aⅴ一线在线观看| 欧美视频一区免费在线| 国产精品久久久久网| 午夜美女少妇福利视频| 护士小嫩嫩又紧又爽20p| 色呦呦视频在线观看视频| 大陆胖女人与丈夫操b国语高清 | 日韩亚国产欧美三级涩爱| 99av国产精品欲麻豆| 少妇一区二区三区久久久| 18禁美女无遮挡免费| 亚洲欧美一区二区三区电影| 成人精品视频99第一页| 爆乳骚货内射骚货内射在线| 精品一区二区三区午夜| 九色视频在线观看免费| av在线资源中文字幕| 中文字幕日韩无敌亚洲精品| avjpm亚洲伊人久久| 三级等保密码要求条款| 亚洲 人妻 激情 中文| 夫妻在线观看视频91| 男人在床上插女人视频| mm131美女午夜爽爽爽| av老司机精品在线观看| 91社福利《在线观看| 99视频精品全部15| 黄色三级网站免费下载| 天天干天天搞天天摸| 天天干天天操天天爽天天摸 | 五月天久久激情视频| 视频一区二区在线免费播放| 欧美日韩熟女一区二区三区| av资源中文字幕在线观看| 国产aⅴ一线在线观看| 中文字幕一区二区三区蜜月| 欧美成人综合视频一区二区 | 淫秽激情视频免费观看| 日韩av有码中文字幕| 中文字幕高清在线免费播放| 亚洲人人妻一区二区三区| 婷婷久久久久深爱网| 亚洲欧美福利在线观看| 成人性爱在线看四区| 一区二区在线观看少妇| www日韩a级s片av| 91小伙伴中女熟女高潮| 无码国产精品一区二区高潮久久4| 天天躁夜夜躁日日躁a麻豆| 亚洲av无硬久久精品蜜桃| 久久国产精品精品美女| 免费无毒热热热热热热久| 中文字幕日韩无敌亚洲精品| 青青青爽视频在线播放| 欧美一区二区三区高清不卡tv| 日本黄色三级高清视频| 男女第一次视频在线观看| 日韩人妻丝袜中文字幕| 久久这里有免费精品| 伊人综合免费在线视频| 欧美第一页在线免费观看视频| 在线观看免费av网址大全| 国产精品污污污久久| 国产精品一二三不卡带免费视频| 337p日本大胆欧美人| 精品一区二区三四区| 唐人色亚洲av嫩草| 国产剧情演绎系列丝袜高跟| 成年午夜免费无码区| 亚洲av极品精品在线观看| 2021天天色天天干| 无忧传媒在线观看视频| 果冻传媒av一区二区三区| 中文字幕免费福利视频6| 久久这里只有精品热视频| 国产麻豆乱子伦午夜视频观看| 国产亚洲天堂天天一区| 91九色porny蝌蚪国产成人| 亚洲成人熟妇一区二区三区| 日韩欧美国产一区ab| 国产精品久久久久久久久福交| 夜女神免费福利视频| 北条麻妃av在线免费观看| 爱有来生高清在线中文字幕| 521精品视频在线观看| 天天干天天操天天插天天日| 在线视频这里只有精品自拍| 亚洲 清纯 国产com| 欧美久久久久久三级网| 老师啊太大了啊啊啊尻视频| 任你操任你干精品在线视频| 日本熟妇喷水xxx| 最近的中文字幕在线mv视频| 国产亚洲成人免费在线观看| av森泽佳奈在线观看| 成人影片高清在线观看| 综合激情网激情五月五月婷婷| 亚洲图片偷拍自拍区| 日韩三级黄色片网站| 国产激情av网站在线观看| 亚洲va天堂va国产va久| 精品成人啪啪18免费蜜臀| 久久永久免费精品人妻专区 | 亚洲日本一区二区久久久精品| 初美沙希中文字幕在线| 自拍偷拍 国产资源| 日韩不卡中文在线视频网站| 亚洲成人线上免费视频观看| av在线资源中文字幕| 男生舔女生逼逼的视频| 亚洲熟色妇av日韩熟色妇在线| 欧洲黄页网免费观看| 亚洲天堂av最新网址| 亚洲区美熟妇久久久久| av森泽佳奈在线观看| 国产熟妇一区二区三区av | 欧美80老妇人性视频| 免费在线观看污污视频网站| 三上悠亚和黑人665番号| 天天做天天爽夜夜做少妇| 亚洲成人情色电影在线观看| 亚洲精品高清自拍av| 亚洲第一伊人天堂网| 亚洲一区二区三区五区| 亚洲成人线上免费视频观看| 中文字幕最新久久久| av男人天堂狠狠干| av俺也去在线播放| 超污视频在线观看污污污| 久草视频在线一区二区三区资源站| 久久免看30视频口爆视频| 日韩a级黄色小视频| 亚洲熟女女同志女同| 亚洲av极品精品在线观看| eeuss鲁片一区二区三区| 不卡一不卡二不卡三| 色爱av一区二区三区| 亚洲成人午夜电影在线观看| 久久农村老妇乱69系列| 日本精品视频不卡一二三| 爱爱免费在线观看视频| 国产在线免费观看成人| 国产成人精品一区在线观看| 少妇人妻100系列| 亚洲国产欧美国产综合在线| 岛国av高清在线成人在线| 亚洲欧美激情中文字幕| 香港一级特黄大片在线播放 | 精品欧美一区二区vr在线观看| 亚洲一级 片内射视正片| 成年午夜影片国产片| 日本一区二区三区免费小视频| 直接观看免费黄网站| 青青青国产片免费观看视频| 色在线观看视频免费的| 亚洲欧美日韩视频免费观看| 自拍偷拍亚洲欧美在线视频| 夜夜骑夜夜操夜夜奸| av在线观看网址av| 黑人大几巴狂插日本少妇| 桃色视频在线观看一区二区 | 日本阿v视频在线免费观看| 免费观看国产综合视频| 美女被肏内射视频网站| 日本www中文字幕| 91精品国产黑色丝袜| 成年人免费看在线视频| 欧美地区一二三专区| 天天色天天操天天舔| 伊人网中文字幕在线视频| 男人天堂av天天操| 国产精品一区二区三区蜜臀av| 亚洲中文字幕乱码区| 姐姐的朋友2在线观看中文字幕| 99久久99一区二区三区| 国产精品黄色的av| 最新黄色av网站在线观看| 亚洲精品在线资源站| 欧美亚洲中文字幕一区二区三区 | 国产片免费观看在线观看| 在线免费观看日本伦理| 欧美在线偷拍视频免费看| av中文字幕国产在线观看| 日韩精品中文字幕福利| 国产伦精品一区二区三区竹菊| 欧美性受xx黑人性猛交| 国产精品成久久久久三级蜜臀av| 99久久激情婷婷综合五月天| 日本啪啪啪啪啪啪啪| 插小穴高清无码中文字幕| av老司机亚洲一区二区| 天天摸天天日天天操| 岛国av高清在线成人在线| 不戴胸罩引我诱的隔壁的人妻| 精品一区二区三区在线观看| 黄片色呦呦视频免费看| 91人妻人人做人人爽在线| 美女在线观看日本亚洲一区| 日韩美女搞黄视频免费| 欧美专区日韩专区国产专区| 51精品视频免费在线观看| 国产美女一区在线观看| 粗大的内捧猛烈进出爽大牛汉子| 成年人黄视频在线观看| 超碰97人人澡人人| 午夜精品在线视频一区| 男人的天堂av日韩亚洲| 国产麻豆剧果冻传媒app| 久久精品国产亚洲精品166m| 久久99久久99精品影院| 亚洲成人熟妇一区二区三区 | 福利视频广场一区二区| 男女啪啪视频免费在线观看| 天堂女人av一区二区| 日韩欧美一级精品在线观看| 91免费观看在线网站| 999久久久久999| 18禁网站一区二区三区四区| 天天日天天添天天爽| 国产高清97在线观看视频| 色呦呦视频在线观看视频| 男大肉棒猛烈插女免费视频| 欧美中文字幕一区最新网址| 日本人竟这样玩学生妹| 无码国产精品一区二区高潮久久4| 日韩特级黄片高清在线看| 在线观看av观看av| 红桃av成人在线观看| 2021国产一区二区| 欧美80老妇人性视频| 熟女91pooyn熟女| 成人午夜电影在线观看 久久| 国产老熟女伦老熟妇ⅹ| 极品粉嫩小泬白浆20p主播| 天天日天天爽天天干| a v欧美一区=区三区| 中国熟女一区二区性xx| av在线播放国产不卡| 一区二区久久成人网| 亚洲高清免费在线观看视频| 伊人综合aⅴ在线网| 欧美韩国日本国产亚洲| 日美女屁股黄邑视频| 成人av天堂丝袜在线观看 | 亚洲国产精品久久久久久6| 91亚洲国产成人精品性色| 欧美日韩一级黄片免费观看| 大香蕉玖玖一区2区| 亚洲免费在线视频网站| 91国偷自产一区二区三区精品| 欧美成人精品在线观看| 在线观看欧美黄片一区二区三区| 人妻无码中文字幕专区| 热99re69精品8在线播放| 天天日天天敢天天干| 国产女人露脸高潮对白视频| 沙月文乃人妻侵犯中文字幕在线| 中文字幕高清资源站| 色在线观看视频免费的| 美日韩在线视频免费看| nagger可以指黑人吗| 亚洲在线一区二区欧美| 97国产在线av精品| 成人高清在线观看视频| 91国产在线视频免费观看| 国产亚洲成人免费在线观看| 青娱乐在线免费视频盛宴| 欧美天堂av无线av欧美| 精内国产乱码久久久久久| 又色又爽又黄又刺激av网站| 日本免费一级黄色录像| 曰本无码人妻丰满熟妇啪啪| 亚洲偷自拍高清视频| 中文字幕在线永久免费播放| 日韩二区视频一线天婷婷五| 人妻少妇性色欲欧美日韩| japanese五十路熟女熟妇| 中文字幕一区二区三区蜜月| 日本在线一区二区不卡视频| 无套猛戳丰满少妇人妻| 精品日产卡一卡二卡国色天香| 亚洲图库另类图片区| 国产黑丝高跟鞋视频在线播放| 少妇露脸深喉口爆吞精| 粗大的内捧猛烈进出爽大牛汉子| 色婷婷久久久久swag精品| 日韩一个色综合导航| 大胸性感美女羞爽操逼毛片| 欧洲日韩亚洲一区二区三区| eeuss鲁片一区二区三区| 精品久久久久久久久久久99| 91破解版永久免费| 国产三级精品三级在线不卡| 一区二区三区久久中文字幕| 欧美另类一区二区视频| 91色网站免费在线观看| 中文字幕一区二 区二三区四区| 大鸡巴插入美女黑黑的阴毛| 高清一区二区欧美系列| 91亚洲精品干熟女蜜桃频道| www天堂在线久久| 55夜色66夜色国产精品站| 亚洲熟女久久久36d| 丝袜国产专区在线观看| 男女啪啪视频免费在线观看| 亚洲一区二区三区av网站| 福利午夜视频在线合集| 国产福利小视频大全| 久久精品国产亚洲精品166m| 97小视频人妻一区二区| 最新国产精品拍在线观看| 国产视频一区二区午夜| 亚洲av日韩精品久久久| 日本在线一区二区不卡视频| 日韩av中文在线免费观看| 中文字幕在线一区精品| 人妻素人精油按摩中出| 99热这里只有国产精品6| 第一福利视频在线观看 | av在线shipin| 一区国内二区日韩三区欧美| 亚洲 中文 自拍 另类 欧美 | 老师啊太大了啊啊啊尻视频| 久草电影免费在线观看| 日本午夜爽爽爽爽爽视频在线观看| 熟女少妇激情五十路| 在线观看操大逼视频| 亚洲欧美自拍另类图片| 都市家庭人妻激情自拍视频| jiuse91九色视频| 亚洲欧美精品综合图片小说| av在线播放国产不卡| av天堂中文免费在线| 女同性ⅹxx女同h偷拍| 男人天堂最新地址av| 日韩黄色片在线观看网站| 骚货自慰被发现爆操| 在线免费观看欧美小视频| AV天堂一区二区免费试看| av在线观看网址av| 免费黄高清无码国产| 大鸡巴操娇小玲珑的女孩逼| 亚洲激情偷拍一区二区| 99亚洲美女一区二区三区| 女同性ⅹxx女同h偷拍| 深夜男人福利在线观看| 一级黄片久久久久久久久| 91‖亚洲‖国产熟女| www天堂在线久久| 男人和女人激情视频| 岳太深了紧紧的中文字幕| 日本性感美女写真视频| 9色在线视频免费观看| 国产黄色高清资源在线免费观看| 91免费福利网91麻豆国产精品| 中出中文字幕在线观看 | 伊人综合免费在线视频| 女同性ⅹxx女同hd| 亚洲国产欧美一区二区丝袜黑人| 亚洲欧美成人综合视频| 桃色视频在线观看一区二区 | 九色精品视频在线播放| 精品一区二区三区三区88| 天天日天天日天天擦| 农村胖女人操逼视频| 亚洲欧美自拍另类图片| 亚洲一区av中文字幕在线观看| 成人影片高清在线观看| 日本女人一级免费片| 黄色黄色黄片78在线| 国产精品成久久久久三级蜜臀av| 男女第一次视频在线观看| 直接观看免费黄网站| 欧美视频不卡一区四区| 最新欧美一二三视频| 91中文字幕最新合集| 888亚洲欧美国产va在线播放| 在线可以看的视频你懂的| 亚洲国产精品黑丝美女| 黑人3p华裔熟女普通话| 天天日天天干天天干天天日| 日韩美女搞黄视频免费| 9色精品视频在线观看| 97少妇精品在线观看| 亚洲午夜电影在线观看| 黄色资源视频网站日韩| 国产成人精品一区在线观看| 日韩美在线观看视频黄| 久久久精品国产亚洲AV一| 午夜dv内射一区区| 久久精品视频一区二区三区四区 | 91久久精品色伊人6882| 中文乱理伦片在线观看| 美女福利写真在线观看视频| 日本一二三区不卡无| 换爱交换乱高清大片| 亚洲高清国产拍青青草原| 久久这里只有精彩视频免费| 大尺度激情四射网站| 蜜桃臀av蜜桃臀av| 天堂中文字幕翔田av| 国产视频网站国产视频| 亚洲va天堂va国产va久| 99热99re在线播放| 欧美日韩不卡一区不区二区| 国产av一区2区3区| 久久久制服丝袜中文字幕| 少妇被强干到高潮视频在线观看| 国产亚洲国产av网站在线| 欧美一区二区三区激情啪啪啪| 国产又粗又硬又猛的毛片视频| 日日操夜夜撸天天干| 青青青青青青草国产| 操人妻嗷嗷叫视频一区二区| 狠狠鲁狠狠操天天晚上干干| 啊啊啊视频试看人妻| 久久亚洲天堂中文对白| 三级黄色亚洲成人av| 久久精品视频一区二区三区四区| 极品性荡少妇一区二区色欲| japanese日本熟妇另类| 2022精品久久久久久中文字幕| 国产熟妇乱妇熟色T区| 99久久久无码国产精品性出奶水| 夫妻在线观看视频91| 午夜精品一区二区三区更新| 亚洲在线免费h观看网站| 日本美女成人在线视频| 人妻无码中文字幕专区| 日韩人妻xxxxx| 天天插天天狠天天操| 日韩欧美亚洲熟女人妻| 经典国语激情内射视频| 伊人网中文字幕在线视频| 日韩欧美国产精品91| 午夜精品九一唐人麻豆嫩草成人| 天天操夜夜操天天操天天操| jiujiure精品视频在线| 91极品新人『兔兔』精品新作| 国产又粗又猛又爽又黄的视频在线| 成年人免费看在线视频| 中文字幕国产专区欧美激情| 91精品国产综合久久久蜜| 亚洲一区制服丝袜美腿| 青青色国产视频在线| 国产精品手机在线看片| 国产老熟女伦老熟妇ⅹ| 天堂av中文在线最新版| 成人午夜电影在线观看 久久| 在线观看的a站 最新| 久久国产精品精品美女| 精品国产成人亚洲午夜| 久久h视频在线观看| 亚洲2021av天堂| 黄片三级三级三级在线观看| 久久久久久久精品成人热| 免费观看理论片完整版| 亚洲天堂av最新网址| 熟女视频一区,二区,三区| 欧美日韩情色在线观看| 亚洲Av无码国产综合色区| 婷婷久久久久深爱网| 亚洲人人妻一区二区三区| 亚洲护士一区二区三区| 边摸边做超爽毛片18禁色戒| 欧美日韩人妻久久精品高清国产| 日本精品视频不卡一二三| 日本裸体熟妇区二区欧美| 操人妻嗷嗷叫视频一区二区 | 2020韩国午夜女主播在线| 天天干天天操天天爽天天摸| 最新激情中文字幕视频| 午夜久久久久久久99| 黄色资源视频网站日韩| 熟女人妻一区二区精品视频| 宅男噜噜噜666免费观看| 天天躁日日躁狠狠躁躁欧美av| 亚洲一区二区三区精品乱码| 亚洲伊人色一综合网| 久久久久国产成人精品亚洲午夜| 精彩视频99免费在线| huangse网站在线观看| 丝袜国产专区在线观看| 韩国女主播精品视频网站| 国产a级毛久久久久精品| 污污小视频91在线观看| 国产精品手机在线看片| 一区二区三区欧美日韩高清播放| 欧美激情电影免费在线| 日本熟妇一区二区x x| 亚洲精品精品国产综合| 大尺度激情四射网站| 白嫩白嫩美女极品国产在线观看| 五十路人妻熟女av一区二区| 最新的中文字幕 亚洲| 超pen在线观看视频公开97| 9色精品视频在线观看| av中文字幕电影在线看| 自拍偷拍,中文字幕| 日本特级片中文字幕| 丰满熟女午夜福利视频| 国产精品久久综合久久| 九色视频在线观看免费| 黄工厂精品视频在线观看| 在线观看成人国产电影| 亚洲一区二区三区久久午夜| 99的爱精品免费视频| 天天日天天日天天射天天干| 亚洲精品av在线观看| 中文字幕在线免费第一页| 97超碰免费在线视频| 97超碰免费在线视频| 免费国产性生活视频| 国语对白xxxx乱大交| 99精品免费观看视频| 国产白嫩美女一区二区| 日本少妇精品免费视频| 特级无码毛片免费视频播放| 特大黑人巨大xxxx| 亚洲av天堂在线播放| 国产精品国产精品一区二区| 青青青青操在线观看免费| 岛国青草视频在线观看| 久久久噜噜噜久久熟女av| 免费成人av中文字幕| 都市家庭人妻激情自拍视频| 亚洲天堂成人在线观看视频网站| 年轻的人妻被夫上司侵犯| 欧美日韩国产一区二区三区三州| 国产大学生援交正在播放| 激情内射在线免费观看| 综合激情网激情五月五月婷婷| 精品视频中文字幕在线播放| 国产精品人妻66p| 综合激情网激情五月五月婷婷| 精品老妇女久久9g国产| 亚洲中文精品人人免费| 国产+亚洲+欧美+另类| 中文字幕在线免费第一页| 青青青青视频在线播放| 91人妻精品久久久久久久网站| 97精品视频在线观看| 婷婷久久一区二区字幕网址你懂得| 888亚洲欧美国产va在线播放| 2025年人妻中文字幕乱码在线| 中文字幕高清资源站| 天天躁日日躁狠狠躁躁欧美av | 男人操女人逼逼视频网站| 蜜桃精品久久久一区二区| 99精品久久久久久久91蜜桃| 看一级特黄a大片日本片黑人| 成人高清在线观看视频| 任你操视频免费在线观看| 18禁美女黄网站色大片下载| 久久久久久97三级| 亚洲综合乱码一区二区| 中文字幕日本人妻中出| 精品视频一区二区三区四区五区| 小穴多水久久精品免费看| 国产美女精品福利在线| 女同久久精品秋霞网| 欧美久久一区二区伊人| 精品国产高潮中文字幕| 国产精品午夜国产小视频| 任你操视频免费在线观看| 亚洲在线一区二区欧美| 国产美女一区在线观看| 亚洲蜜臀av一区二区三区九色| 88成人免费av网站| 亚洲 中文 自拍 另类 欧美| 超碰97免费人妻麻豆| 国产变态另类在线观看| 女同性ⅹxx女同h偷拍| 免费69视频在线看| 欧美专区日韩专区国产专区| 91小伙伴中女熟女高潮| 播放日本一区二区三区电影| 一区二区视频在线观看视频在线| 粉嫩欧美美人妻小视频| 亚洲av无女神免非久久| 国产高清女主播在线| 天天艹天天干天天操| 国产午夜激情福利小视频在线| 国产福利小视频大全| 91精品国产观看免费| 日韩人妻xxxxx| 日日操夜夜撸天天干| 天天日天天干天天舔天天射| eeuss鲁片一区二区三区| a v欧美一区=区三区| 青青草在观免费国产精品| 98精产国品一二三产区区别| 真实国产乱子伦一区二区| 全国亚洲男人的天堂| 51国产成人精品视频| 在线新三级黄伊人网| 亚洲 欧美 自拍 偷拍 在线| 日本在线不卡免费视频| 啪啪啪18禁一区二区三区 | 国产一线二线三线的区别在哪| 免费观看丰满少妇做受| 精品日产卡一卡二卡国色天香| 北条麻妃高跟丝袜啪啪| 人人人妻人人澡人人| 国产污污污污网站在线| 9色在线视频免费观看| 亚洲成人熟妇一区二区三区 | 好吊视频—区二区三区| 麻豆精品成人免费视频| 福利视频一区二区三区筱慧| 欧美久久一区二区伊人| 一区二区免费高清黄色视频| 久久久91蜜桃精品ad| 国产精品自偷自拍啪啪啪| 亚洲综合另类精品小说| 国产精品成人xxxx| 亚洲av天堂在线播放| 日本熟女50视频免费| 婷婷午夜国产精品久久久| 色偷偷伊人大杳蕉综合网| 国产刺激激情美女网站| 狠狠嗨日韩综合久久| 亚洲精品 欧美日韩| 亚洲无码一区在线影院| 看一级特黄a大片日本片黑人| 亚洲综合一区成人在线| 91麻豆精品91久久久久同性| 不卡一不卡二不卡三| 中文字幕之无码色多多| 国产精品国色综合久久| 一区二区三区另类在线 | 宅男噜噜噜666国产| 青青草原色片网站在线观看| 少妇人妻二三区视频| 国产一区av澳门在线观看| 欧美精品久久久久久影院| AV无码一区二区三区不卡| www天堂在线久久| 色偷偷伊人大杳蕉综合网| 亚洲精品亚洲人成在线导航| 天天日天天玩天天摸| 国产日本精品久久久久久久| 男人和女人激情视频| 最新中文字幕乱码在线| 精品成人啪啪18免费蜜臀| 国产成人一区二区三区电影网站| 国产福利小视频大全| 天天干夜夜操啊啊啊| 国产使劲操在线播放| 天堂资源网av中文字幕| av大全在线播放免费| 92福利视频午夜1000看| 婷婷综合亚洲爱久久| 亚洲欧美久久久久久久久| 91极品大一女神正在播放| 日本一道二三区视频久久| 免费在线黄色观看网站| 亚洲一区二区人妻av| 唐人色亚洲av嫩草| 亚洲精品无码色午夜福利理论片| 日韩美女精品视频在线观看网站| 色哟哟国产精品入口| 成年美女黄网站18禁久久| 日视频免费在线观看| 国产成人精品久久二区91| 人妻无码中文字幕专区| 国产在线观看黄色视频| 免费黄色成人午夜在线网站| 国产极品美女久久久久久| 亚洲国产精品久久久久久6| 免费男阳茎伸入女阳道视频| 国产福利小视频免费观看| gav成人免费播放| 嫩草aⅴ一区二区三区| 欧美偷拍亚洲一区二区| 懂色av之国产精品| 亚洲高清免费在线观看视频| 国产视频网站国产视频| 少妇高潮无套内谢麻豆| 日韩一个色综合导航| 精品美女久久久久久| 91精品国产综合久久久蜜| 国产三级片久久久久久久| 天天日天天干天天干天天日| 日韩三级黄色片网站| 国产女人露脸高潮对白视频| 久久久麻豆精亚洲av麻花| 91成人在线观看免费视频| 真实国模和老外性视频| 亚洲 色图 偷拍 欧美| 无码精品一区二区三区人| 亚洲区美熟妇久久久久| 久草电影免费在线观看| 91破解版永久免费| 色天天天天射天天舔| 日韩三级黄色片网站| 亚洲国产欧美国产综合在线| 中文字幕一区二 区二三区四区 | 操的小逼流水的文章| 91啪国自产中文字幕在线| 特黄老太婆aa毛毛片| 狠狠躁夜夜躁人人爽天天天天97| 18禁无翼鸟成人在线| 精品黑人巨大在线一区| 久精品人妻一区二区三区| 亚洲免费在线视频网站| 天天日天天爽天天干| 狍和女人的王色毛片| 在线国产日韩欧美视频| 成人av天堂丝袜在线观看| 黄色中文字幕在线播放| 在线观看911精品国产| 亚洲成人av一区在线| 日本少妇高清视频xxxxx| 国产 在线 免费 精品| 91精品综合久久久久3d动漫 | 人妻凌辱欧美丰满熟妇| 青青草亚洲国产精品视频| 亚洲成av人无码不卡影片一| 宅男噜噜噜666免费观看| 日本裸体熟妇区二区欧美| 中文字幕人妻av在线观看| 精品国产乱码一区二区三区乱| 天天色天天爱天天爽| 欧亚日韩一区二区三区观看视频| 精品国产高潮中文字幕| 亚洲2021av天堂| 老师啊太大了啊啊啊尻视频| 免费观看丰满少妇做受| 天堂女人av一区二区| 精品老妇女久久9g国产| 亚洲精品中文字幕下载| 三级黄色亚洲成人av| 人妻丰满熟妇综合网| 亚洲一区二区久久久人妻| 欧美亚洲偷拍自拍色图| 日本美女成人在线视频| 免费观看成年人视频在线观看| 久精品人妻一区二区三区| 国产麻豆国语对白露脸剧情 | 天天操天天操天天碰| 日本精品美女在线观看| 国产aⅴ一线在线观看| 欧美特色aaa大片| 自拍偷拍亚洲欧美在线视频| 成人性黑人一级av| 99精品视频之69精品视频| 欧美成人精品欧美一级黄色| 一区二区三区的久久的蜜桃的视频| 亚洲精品无码久久久久不卡| 91精品免费久久久久久| 天天日天天日天天擦| 插逼视频双插洞国产操逼插洞| 91成人在线观看免费视频| 91p0rny九色露脸熟女| 欧美久久久久久三级网| 91亚洲手机在线视频播放| 91久久国产成人免费网站| 青春草视频在线免费播放| 成人免费毛片aaaa| 无码日韩人妻精品久久| 免费在线福利小视频| 男生用鸡操女生视频动漫| av网址在线播放大全| 最新欧美一二三视频| 精品久久久久久久久久久a√国产| 中文字幕AV在线免费看 | 2020韩国午夜女主播在线| 都市激情校园春色狠狠| 亚洲成a人片777777| 亚洲综合一区成人在线| 日本精品视频不卡一二三| 欧美精产国品一二三产品价格| 国产视频一区在线观看| 欧洲日韩亚洲一区二区三区| 亚洲综合在线观看免费| 国产麻豆乱子伦午夜视频观看| 欧美偷拍亚洲一区二区| 人妻丝袜榨强中文字幕| 久久久久91精品推荐99| 美女视频福利免费看| 日本熟妇一区二区x x| 亚洲精品三级av在线免费观看| 久久精品亚洲国产av香蕉| 国产伊人免费在线播放| 国产综合高清在线观看| 经典国语激情内射视频| 青青草原色片网站在线观看| 欧美视频不卡一区四区| 日本高清撒尿pissing| 操日韩美女视频在线免费看| 亚洲av可乐操首页| 日韩熟女系列一区二区三区| 亚洲 欧美 自拍 偷拍 在线| 人人妻人人爱人人草| 女警官打开双腿沦为性奴| 狠狠嗨日韩综合久久| 亚洲国产第一页在线观看| 少妇高潮无套内谢麻豆| 欧洲黄页网免费观看| 亚洲精品一线二线在线观看| 欧美成人精品欧美一级黄色| 老司机99精品视频在线观看| 特大黑人巨大xxxx| 熟女人妻在线中出观看完整版| 婷婷综合亚洲爱久久| 亚洲熟女久久久36d| 大屁股熟女一区二区三区| 97香蕉碰碰人妻国产樱花| 天干天天天色天天日天天射| 78色精品一区二区三区| 精彩视频99免费在线| ka0ri在线视频| 国产激情av网站在线观看| 国产精品国产三级国产精东| 性欧美激情久久久久久久| 久久久91蜜桃精品ad| 久草免费人妻视频在线| 亚洲 色图 偷拍 欧美| 馒头大胆亚洲一区二区| 日韩精品中文字幕在线| 国产女人被做到高潮免费视频| 精内国产乱码久久久久久| 国产一区成人在线观看视频| 成人影片高清在线观看| 91成人精品亚洲国产| 欧亚乱色一区二区三区| 无码国产精品一区二区高潮久久4| 亚洲熟女女同志女同| 色综合色综合色综合色| 偷拍美女一区二区三区| 97国产在线观看高清| 中文亚洲欧美日韩无线码| 97超碰免费在线视频| 日韩av免费观看一区| 18禁美女羞羞免费网站| 激情啪啪啪啪一区二区三区| 欧美在线一二三视频| 亚洲伊人久久精品影院一美女洗澡| 视频啪啪啪免费观看| 亚洲av成人免费网站| 国产一区二区久久久裸臀| 91chinese在线视频| 337p日本大胆欧美人| 日本高清撒尿pissing| 国产成人精品av网站| 一区二区三区四区视频在线播放| 91一区精品在线观看| 久久久久国产成人精品亚洲午夜| 亚洲人妻国产精品综合| 亚洲av第国产精品| 午夜精品一区二区三区福利视频| 中文字幕一区二区三区蜜月| 天天操,天天干,天天射| 日韩在线视频观看有码在线| 曰本无码人妻丰满熟妇啪啪| 9国产精品久久久久老师| 成人av亚洲一区二区| 不戴胸罩引我诱的隔壁的人妻| 女生自摸在线观看一区二区三区| 亚国产成人精品久久久| 视频 国产 精品 熟女 | 91综合久久亚洲综合| av成人在线观看一区| 狠狠嗨日韩综合久久| 亚洲一区二区久久久人妻| 在线观看av亚洲情色| 97色视频在线观看| 日曰摸日日碰夜夜爽歪歪| 久久午夜夜伦痒痒想咳嗽P| 超碰97人人澡人人| 中文字幕人妻一区二区视频| 天码人妻一区二区三区在线看| 亚洲欧美一卡二卡三卡| 视频一区二区在线免费播放| 午夜精品亚洲精品五月色| 极品丝袜一区二区三区| 开心 色 六月 婷婷| 激情内射在线免费观看| 蜜桃久久久久久久人妻| 日日日日日日日日夜夜夜夜夜夜| 久久久极品久久蜜桃| 九九视频在线精品播放| 91免费放福利在线观看| 性感美女福利视频网站| 亚洲国产中文字幕啊啊啊不行了| 人人妻人人人操人人人爽| 亚洲免费在线视频网站| 亚洲国产精品免费在线观看| 精品久久婷婷免费视频| 大鸡吧插逼逼视频免费看 | 午夜激情久久不卡一区二区 | 亚洲日产av一区二区在线| 五月天中文字幕内射| 92福利视频午夜1000看| 成年午夜影片国产片| 91大神福利视频网| 青娱乐极品视频青青草| 人妻爱爱 中文字幕| 国产污污污污网站在线| 亚洲天天干 夜夜操| 国产精品黄页网站视频| 国产精品亚洲在线观看| 午夜精品福利一区二区三区p | caoporn蜜桃视频| 国产刺激激情美女网站| 91精品国产91青青碰| 大香蕉伊人国产在线| 99久久99久国产黄毛片| 日韩av免费观看一区| 天天躁日日躁狠狠躁av麻豆| 国产一线二线三线的区别在哪| av完全免费在线观看av| 日本性感美女视频网站| 中文字幕av第1页中文字幕| 最新黄色av网站在线观看| 韩国女主播精品视频网站| 91老师蜜桃臀大屁股| 欧美香蕉人妻精品一区二区| 人妻少妇av在线观看| 中文字幕av第1页中文字幕| 姐姐的朋友2在线观看中文字幕| 国产一区av澳门在线观看| gogo国模私拍视频| 欧美美女人体视频一区| 成人网18免费视频版国产| 一区二区久久成人网| 精品av久久久久久久| 亚洲一级av大片免费观看| gogo国模私拍视频| 午夜激情精品福利视频| 毛茸茸的大外阴中国视频| 国产男女视频在线播放| yellow在线播放av啊啊啊| 欧美亚洲中文字幕一区二区三区| 夜夜嗨av蜜臀av| 免费黄高清无码国产| 久久久麻豆精亚洲av麻花| chinese国产盗摄一区二区| 青青青青青青青青青国产精品视频| 婷婷综合蜜桃av在线| 欧美一区二区三区久久久aaa| 欧美性受xx黑人性猛交| 2018最新中文字幕在线观看| 午夜精品九一唐人麻豆嫩草成人| 99精品视频在线观看婷婷| 午夜精品福利一区二区三区p| 91九色porny国产在线| 蜜臀av久久久久久久| 成人18禁网站在线播放| 天天日天天玩天天摸| mm131美女午夜爽爽爽| 亚洲一级美女啪啪啪| 天天日天天鲁天天操| 国产成人无码精品久久久电影| 综合精品久久久久97| 中文字幕在线乱码一区二区| 熟妇一区二区三区高清版| 亚洲欧美成人综合视频| av日韩在线观看大全| 精品久久久久久久久久久a√国产| 97色视频在线观看| 欧美va不卡视频在线观看| 亚洲最大黄 嗯色 操 啊| 日本真人性生活视频免费看| 亚洲欧美成人综合在线观看| 精品亚洲国产中文自在线| 18禁无翼鸟成人在线| 99精品国产免费久久| 91精品激情五月婷婷在线| 亚洲图库另类图片区| 2020国产在线不卡视频| v888av在线观看视频| 亚洲中文字幕校园春色| 欧美日本国产自视大全| 日本欧美视频在线观看三区| 国产成人午夜精品福利| 99久久99一区二区三区| 日本一本午夜在线播放| 深夜男人福利在线观看| 成人色综合中文字幕| 午夜久久久久久久精品熟女| 日本少妇在线视频大香蕉在线观看| 东京热男人的av天堂| 99热国产精品666| 欧美久久一区二区伊人| 97国产在线av精品| 亚洲的电影一区二区三区| 可以免费看的www视频你懂的| 中文字幕奴隷色的舞台50| 4个黑人操素人视频网站精品91| 免费无码人妻日韩精品一区二区| 欧美精品一区二区三区xxxx| 亚洲精品三级av在线免费观看| 偷拍自拍国产在线视频| 人妻少妇亚洲精品中文字幕| 免费看国产又粗又猛又爽又黄视频 | 不卡精品视频在线观看| 大陆精品一区二区三区久久| 在线不卡成人黄色精品| 在线观看视频污一区| 老鸭窝日韩精品视频观看| 男人操女人的逼免费视频| 性感美女福利视频网站| 久草视频 久草视频2| 日本三极片中文字幕| 免费人成黄页网站在线观看国产| 熟女在线视频一区二区三区| 超碰在线中文字幕一区二区| 午夜美女少妇福利视频| 99精品亚洲av无码国产另类| 亚洲变态另类色图天堂网| 亚洲综合自拍视频一区| 黄工厂精品视频在线观看| 久精品人妻一区二区三区| 天天射夜夜操狠狠干| 熟女少妇激情五十路| 午夜极品美女福利视频| 清纯美女在线观看国产| 精品国产成人亚洲午夜| 天码人妻一区二区三区在线看| 九色视频在线观看免费| 自拍偷拍,中文字幕| 2019av在线视频| 日韩近亲视频在线观看| 色爱av一区二区三区| 在线播放 日韩 av| 午夜毛片不卡免费观看视频| 第一福利视频在线观看| 国产又粗又硬又猛的毛片视频| 黄色大片免费观看网站| 在线免费观看靠比视频的网站| 涩爱综合久久五月蜜臀| 热久久只有这里有精品| 女生被男生插的视频网站| 香蕉aⅴ一区二区三区| 九色视频在线观看免费| 人人在线视频一区二区| 亚洲熟妇x久久av久久| 涩爱综合久久五月蜜臀| 国产成人一区二区三区电影网站| 啪啪啪啪啪啪啪免费视频| 中文字幕免费在线免费| 18禁精品网站久久| 欧美亚洲免费视频观看| 91she九色精品国产| 强行扒开双腿猛烈进入免费版| 国产精品久久久久久久久福交 | 久久久精品999精品日本| 超碰公开大香蕉97| 亚洲国产免费av一区二区三区| 91人妻精品一区二区久久| 极品粉嫩小泬白浆20p主播| 91在线视频在线精品3| 亚洲精品午夜aaa久久| 久久精品美女免费视频| 亚洲国产免费av一区二区三区 | 欧美国产亚洲中英文字幕| 免费在线福利小视频| 在线国产中文字幕视频| 中文字幕 人妻精品| 日本熟妇喷水xxx| 美味人妻2在线播放| 日韩成人性色生活片| 最近的中文字幕在线mv视频| sejizz在线视频| 亚洲在线一区二区欧美| 在线网站你懂得老司机| 在线新三级黄伊人网| 中文字幕av第1页中文字幕| 日本五十路熟新垣里子| 欧美交性又色又爽又黄麻豆| 欧美激情精品在线观看| 精品久久久久久久久久久a√国产 日本女大学生的黄色小视频 | 97超碰最新免费在线观看| av视屏免费在线播放| 性欧美日本大妈母与子| 老司机99精品视频在线观看| 一本久久精品一区二区| 黑人巨大精品欧美视频| 99热色原网这里只有精品| 日韩av免费观看一区| 欧美韩国日本国产亚洲| 大白屁股精品视频国产| 亚洲精品乱码久久久本| 久久永久免费精品人妻专区 | 天堂女人av一区二区| 久久人人做人人妻人人玩精品vr| 亚洲 欧美 精品 激情 偷拍| 午夜在线精品偷拍一区二| 青青草视频手机免费在线观看| 99久久成人日韩欧美精品| 做爰视频毛片下载蜜桃视频1| 少妇与子乱在线观看| 亚洲精品一区二区三区老狼| 国产va精品免费观看| 日韩a级黄色小视频| 国产精品久久久黄网站| 999九九久久久精品| 最新91九色国产在线观看| 在线观看911精品国产| 在线观看视频 你懂的| 欧美久久久久久三级网| 99精品国自产在线人| 国产在线拍揄自揄视频网站| 农村胖女人操逼视频| 成人国产影院在线观看| 国产女孩喷水在线观看| 亚洲免费av在线视频| 欧美黑人与人妻精品| xxx日本hd高清| 亚洲 中文 自拍 无码| 成人性爱在线看四区| 激情啪啪啪啪一区二区三区| 丰满熟女午夜福利视频| 91人妻精品久久久久久久网站 | 99热碰碰热精品a中文| 99热99re在线播放| 日视频免费在线观看| 国产白嫩美女一区二区| 久青青草视频手机在线免费观看| 超级av免费观看一区二区三区| 亚洲熟妇x久久av久久| 日本熟妇色熟妇在线观看| 国产女人露脸高潮对白视频| 91片黄在线观看喷潮| 北条麻妃av在线免费观看| 一本一本久久a久久精品综合不卡| 日韩欧美一级精品在线观看| 真实国产乱子伦一区二区| 五十路在线观看完整版| 日本一本午夜在线播放| 熟女人妻在线中出观看完整版 | 最新中文字幕免费视频| 亚洲高清免费在线观看视频| 国产va在线观看精品| 亚洲 图片 欧美 图片| 亚洲激情唯美亚洲激情图片| 国产janese在线播放| 天天日夜夜干天天操| 日日操综合成人av| 伊人精品福利综合导航| 国产91精品拍在线观看| 午夜美女少妇福利视频| 任你操任你干精品在线视频| 黑人性生活视频免费看| 在线观看成人国产电影| 日韩成人免费电影二区| 日本一区精品视频在线观看| 在线免费91激情四射| 1000部国产精品成人观看视频| 精品欧美一区二区vr在线观看 | 在线 中文字幕 一区| 无码中文字幕波多野不卡| av黄色成人在线观看| 99精品视频在线观看婷婷| 色综合天天综合网国产成人| 2o22av在线视频| 国产精品熟女久久久久浪潮| 爱爱免费在线观看视频| 欧美亚洲一二三区蜜臀| 国产97在线视频观看| 经典国语激情内射视频| 天天射,天天操,天天说| 视频久久久久久久人妻| 国产中文精品在线观看| 天天干天天操天天玩天天射| 亚洲一区二区三区精品乱码| AV无码一区二区三区不卡| 粉嫩欧美美人妻小视频| 亚洲av男人的天堂你懂的| 成年午夜免费无码区| 午夜免费体验区在线观看| 精品久久久久久久久久久a√国产| 真实国模和老外性视频| 93人妻人人揉人人澡人人| 91精品国产91久久自产久强| 日本免费视频午夜福利视频| 亚洲成人三级在线播放| 激情小视频国产在线| 色狠狠av线不卡香蕉一区二区| 欧美一区二区三区高清不卡tv| 天天日天天舔天天射进去| 在线新三级黄伊人网| 国产视频在线视频播放| 久久麻豆亚洲精品av| 亚洲女人的天堂av| 亚洲欧美一区二区三区爱爱动图| 黑人解禁人妻叶爱071| av手机免费在线观看高潮| 69精品视频一区二区在线观看| 班长撕开乳罩揉我胸好爽| 日韩人妻丝袜中文字幕| 4个黑人操素人视频网站精品91| 大白屁股精品视频国产| 色婷婷久久久久swag精品| 欧美成人精品在线观看| 精品成人啪啪18免费蜜臀| 玩弄人妻熟妇性色av少妇| 午夜在线一区二区免费| 一区二区三区在线视频福利| 男人在床上插女人视频| 国产janese在线播放| 免费黄色成人午夜在线网站| 日本午夜福利免费视频| 欧美一区二区三区在线资源| 99精品国产aⅴ在线观看 | 亚洲va国产va欧美va在线| 久久人人做人人妻人人玩精品vr| 黄网十四区丁香社区激情五月天| 日韩美女精品视频在线观看网站| 好了av中文字幕在线| 久久精品视频一区二区三区四区 | 激情五月婷婷免费视频| 国产福利小视频二区| 色秀欧美视频第一页| 欧美中国日韩久久精品| 超碰中文字幕免费观看| 青青热久免费精品视频在线观看 | 亚洲第17页国产精品| 日韩写真福利视频在线观看| 特黄老太婆aa毛毛片| 在线国产中文字幕视频| 精品一区二区三区三区色爱| 国产又粗又硬又大视频| 美女 午夜 在线视频| 91国内视频在线观看| 成人综合亚洲欧美一区| 1000小视频在线| 99精品视频在线观看免费播放| 青春草视频在线免费播放| av高潮迭起在线观看| 日韩亚国产欧美三级涩爱| 亚洲一区二区三区久久受| 做爰视频毛片下载蜜桃视频1| 女同性ⅹxx女同hd| 中文字幕免费在线免费| 亚洲老熟妇日本老妇| 九色视频在线观看免费| 97资源人妻免费在线视频| okirakuhuhu在线观看| 夜夜嗨av蜜臀av| 青青草国内在线视频精选| 亚洲av第国产精品| 欧美80老妇人性视频| 欧美精品亚洲精品日韩在线| 亚洲av天堂在线播放| 日韩北条麻妃一区在线| 2012中文字幕在线高清| 免费观看污视频网站| 久久农村老妇乱69系列| 69精品视频一区二区在线观看| 大鸡吧插入女阴道黄色片| 国产女人叫床高潮大片视频| 人妻无码中文字幕专区| 日本韩国免费福利精品| 激情色图一区二区三区| 清纯美女在线观看国产| 一级A一级a爰片免费免会员 | 不卡精品视频在线观看| 日韩一个色综合导航| 亚洲免费国产在线日韩| 国产女人露脸高潮对白视频| 中国黄色av一级片| 中文字幕在线观看国产片| 4个黑人操素人视频网站精品91| 亚洲av可乐操首页| 女生自摸在线观看一区二区三区| 国产片免费观看在线观看| 这里有精品成人国产99| 人妻激情图片视频小说| 天天躁日日躁狠狠躁躁欧美av| 亚洲午夜高清在线观看| 日韩欧美一级aa大片| 日本精品一区二区三区在线视频。 | 大屁股熟女一区二区三区| 人妻丝袜精品中文字幕| 性欧美激情久久久久久久| 五十路熟女人妻一区二| 66久久久久久久久久久| 女同互舔一区二区三区| 欧美3p在线观看一区二区三区| 又粗又硬又猛又爽又黄的| 亚洲福利午夜久久久精品电影网 | 天堂av在线播放免费| 男人操女人的逼免费视频| 国产亚洲四十路五十路| 精品区一区二区三区四区人妻 | 爆乳骚货内射骚货内射在线| 国产麻豆剧传媒精品国产av蜜桃| 在线观看免费视频色97| 91一区精品在线观看| 男生用鸡操女生视频动漫 | 欧美精产国品一二三产品区别大吗| 国产日韩精品电影7777| 色狠狠av线不卡香蕉一区二区 | 亚洲男人让女人爽的视频| 精品av国产一区二区三区四区 | 99re久久这里都是精品视频| 日本特级片中文字幕| 欧美性感尤物人妻在线免费看| 国产麻豆精品人妻av| 丝袜美腿欧美另类 中文字幕| 午夜精品一区二区三区4| 免费黄色成人午夜在线网站| 国产一级麻豆精品免费| 亚国产成人精品久久久| 一区二区三区在线视频福利| 麻豆性色视频在线观看| 五月天色婷婷在线观看视频免费| av中文在线天堂精品| 天天干天天插天天谢| av日韩在线免费播放| 日韩欧美亚洲熟女人妻| 午夜精品福利91av| 亚洲av第国产精品| 一色桃子久久精品亚洲| 国产综合视频在线看片| 色偷偷伊人大杳蕉综合网| 国产精品sm调教视频| 偷拍自拍亚洲视频在线观看| 日韩欧美中文国产在线| av乱码一区二区三区| 欧美日韩在线精品一区二区三| 中文字幕 码 在线视频| 天天日天天添天天爽| 午夜久久久久久久精品熟女| 欧美黄片精彩在线免费观看| 青娱乐蜜桃臀av色| 日本精品美女在线观看| 黄色视频在线观看高清无码| 一区二区三区久久中文字幕| 中文字幕—97超碰网| 欧美日韩国产一区二区三区三州| 丝袜长腿第一页在线| 久久精品美女免费视频| 成人av中文字幕一区| 久久丁香花五月天色婷婷| 天天日天天干天天要| 亚洲国产成人无码麻豆艾秋| 99热99re在线播放| 亚洲国产在人线放午夜| 一区二区三区四区视频在线播放| 亚洲 欧美 精品 激情 偷拍| 老师啊太大了啊啊啊尻视频| 亚洲成人国产综合一区| 亚洲av日韩高清hd| 亚洲国产精品中文字幕网站| 中文字幕熟女人妻久久久| 国产中文精品在线观看| 特级欧美插插插插插bbbbb| 欧美区一区二区三视频| 黄色录像鸡巴插进去| 亚洲一区二区激情在线| 国产亚洲精品品视频在线| 欧美黑人巨大性xxxxx猛交| 久久久久久九九99精品| 国产欧美精品不卡在线| 日本xx片在线观看| 欧美一区二区三区在线资源 | 天天操天天操天天碰| 国产精品自偷自拍啪啪啪| 久久久精品999精品日本| 高清一区二区欧美系列| 国产福利小视频免费观看| 无码中文字幕波多野不卡| 综合页自拍视频在线播放| aaa久久久久久久久| 动色av一区二区三区| 人妻少妇精品久久久久久| 福利午夜视频在线观看| 80电影天堂网官网| 亚洲另类图片蜜臀av| 五十路熟女av天堂| 日日日日日日日日夜夜夜夜夜夜| 欧美乱妇无乱码一区二区| 亚洲精品ww久久久久久| 成人久久精品一区二区三区| 国产密臀av一区二区三| 国产精品久久久久网| 国产亚洲视频在线观看| 人妻自拍视频中国大陆| 99精品亚洲av无码国产另类| 爱爱免费在线观看视频| 亚洲欧美国产麻豆综合| 少妇一区二区三区久久久| 亚洲欧美另类自拍偷拍色图| 91九色porny蝌蚪国产成人| 亚洲一区自拍高清免费视频| 天天色天天舔天天射天天爽| 国产实拍勾搭女技师av在线| 国产aⅴ一线在线观看| 亚洲综合在线观看免费| 无忧传媒在线观看视频| 在线国产精品一区二区三区| 97色视频在线观看| 4个黑人操素人视频网站精品91| 免费十精品十国产网站| 这里只有精品双飞在线播放| 91老师蜜桃臀大屁股| 欧美精品中文字幕久久二区| 免费在线福利小视频| 亚洲精品三级av在线免费观看| 国产极品精品免费视频| 久久久91蜜桃精品ad| 熟女91pooyn熟女| 天天综合天天综合天天网| 99热这里只有国产精品6| 国产又色又刺激在线视频| 亚洲特黄aaaa片| 久久精品36亚洲精品束缚| 人妻熟女在线一区二区| 天天日天天舔天天射进去| 岛国黄色大片在线观看| 日本a级视频老女人| 喷水视频在线观看这里只有精品| 亚洲一区二区三区五区| 人妻少妇性色欲欧美日韩| 亚洲va欧美va人人爽3p| 蜜桃专区一区二区在线观看| 福利视频一区二区三区筱慧| 2020久久躁狠狠躁夜夜躁| 欧美成人精品在线观看| 2020久久躁狠狠躁夜夜躁| 操人妻嗷嗷叫视频一区二区| 欧美视频不卡一区四区| 91极品新人『兔兔』精品新作| av森泽佳奈在线观看| 日韩欧美国产精品91| 天天日天天摸天天爱| www天堂在线久久| 亚洲日本一区二区三区| 熟女人妻一区二区精品视频| 亚洲熟妇无码一区二区三区| 黄工厂精品视频在线观看 | 任我爽精品视频在线播放| 国产麻豆剧传媒精品国产av蜜桃| 亚洲 图片 欧美 图片| 亚洲图片偷拍自拍区| 天天干夜夜操啊啊啊| 成年人午夜黄片视频资源| gay gay男男瑟瑟在线网站| 99热99re在线播放| 91九色国产porny蝌蚪| 午夜免费体验区在线观看| 蜜臀成人av在线播放| 亚洲成a人片777777| 绝顶痉挛大潮喷高潮无码| 久久久久久性虐视频| 日本又色又爽又黄又粗| 精品国产午夜视频一区二区| 亚洲人妻30pwc| av破解版在线观看| 日本韩国免费一区二区三区视频 | av线天堂在线观看| 亚洲人人妻一区二区三区| 美女张开两腿让男人桶av| 最新国产精品拍在线观看| 人妻凌辱欧美丰满熟妇| 天天操天天弄天天射| 亚洲Av无码国产综合色区| 久久永久免费精品人妻专区| 二区中出在线观看老师| 91试看福利一分钟| 99精品国产免费久久| 欧美va不卡视频在线观看| 视频二区在线视频观看 | huangse网站在线观看| 精品国产污污免费网站入口自| 成人av电影免费版| 99热久久这里只有精品| 操的小逼流水的文章| 女同互舔一区二区三区| www日韩毛片av| 精彩视频99免费在线| 欧美精品激情在线最新观看视频| 久久免费看少妇高潮完整版| 国产男女视频在线播放| 一区二区麻豆传媒黄片| 国产污污污污网站在线| 精品av国产一区二区三区四区 | 国产午夜福利av导航| 亚洲精品午夜久久久久| 福利一二三在线视频观看| 在线免费视频 自拍| 99久久超碰人妻国产| av一区二区三区人妻| gav成人免费播放| 性欧美日本大妈母与子| 全国亚洲男人的天堂| 无码精品一区二区三区人| 人人妻人人澡人人爽人人dvl| 五十路在线观看完整版| 国产久久久精品毛片| 大屁股熟女一区二区三区| 75国产综合在线视频| 欧美日本在线观看一区二区| 午夜精品亚洲精品五月色| 深田咏美亚洲一区二区| 亚洲在线一区二区欧美| 东游记中文字幕版哪里可以看到| 国产在线自在拍91国语自产精品 | 国产超码片内射在线| 亚洲欧美成人综合视频| 动漫黑丝美女的鸡巴| 亚洲综合图片20p| 人妻少妇av在线观看| 青青草国内在线视频精选| 国产综合视频在线看片| 最新欧美一二三视频 | 青青青国产片免费观看视频| 亚洲超碰97人人做人人爱| 国产在线免费观看成人| 久久这里只有精品热视频 | 国产精品人妻一区二区三区网站| 在线免费观看99视频| 中文字幕中文字幕人妻| 看一级特黄a大片日本片黑人| 伊人精品福利综合导航| 无忧传媒在线观看视频| 国产成人精品av网站| 日本高清撒尿pissing| 99久久激情婷婷综合五月天| 日本免费午夜视频网站| 久久热久久视频在线观看| 天天色天天操天天透| 女同久久精品秋霞网| av日韩在线免费播放| 亚洲日本一区二区三区| 99精品国产自在现线观看| 国产熟妇乱妇熟色T区| 男人和女人激情视频| 午夜精品一区二区三区4| 国产露脸对白在线观看| 日本性感美女视频网站| 精品乱子伦一区二区三区免费播| av中文字幕福利网| 成年女人免费播放视频| 亚洲一区自拍高清免费视频| 国产一区二区三免费视频 | chinese国产盗摄一区二区 | 99热99这里精品6国产| 韩国AV无码不卡在线播放| 清纯美女在线观看国产| 日韩精品啪啪视频一道免费| 自拍偷拍亚洲另类色图| 啪啪啪啪啪啪啪啪啪啪黄色| 成人动漫大肉棒插进去视频| 三上悠亚和黑人665番号| 午夜频道成人在线91| aⅴ精产国品一二三产品| 国产精品人久久久久久| 欧美精品欧美极品欧美视频 | 日韩熟女系列一区二区三区| 日韩精品一区二区三区在线播放| 久草视频在线看免费| 夜夜操,天天操,狠狠操| 国产亚洲欧美45p| 中文字幕—97超碰网| 高清成人av一区三区| 在线成人日韩av电影| 国产白袜脚足J棉袜在线观看| 喷水视频在线观看这里只有精品| 亚洲在线免费h观看网站| 男人天堂av天天操| 2020久久躁狠狠躁夜夜躁 | av久久精品北条麻妃av观看| 另类av十亚洲av| 青青青青操在线观看免费| 99久久激情婷婷综合五月天| 干逼又爽又黄又免费的视频| 夜夜嗨av蜜臀av| 久碰精品少妇中文字幕av| 日韩av熟妇在线观看| 亚洲一区二区三区偷拍女厕91| 欧美日本在线观看一区二区| 午夜国产福利在线观看| 91破解版永久免费| www,久久久,com| 18禁美女无遮挡免费| 一级黄片久久久久久久久| 在线免费观看亚洲精品电影 | wwwxxx一级黄色片| 国产欧美精品不卡在线| 黑人乱偷人妻中文字幕| 成熟熟女国产精品一区| aaa久久久久久久久| 夏目彩春在线中文字幕| 欧美日韩一级黄片免费观看| 日韩写真福利视频在线观看| 91快播视频在线观看| 夜夜骑夜夜操夜夜奸| 人妻爱爱 中文字幕| 熟女俱乐部一二三区| 青青草国内在线视频精选| 最新日韩av传媒在线| 2020中文字幕在线播放| 亚洲国产精品黑丝美女| 18禁精品网站久久| 亚洲成人精品女人久久久| 91国语爽死我了不卡| 九色视频在线观看免费| www天堂在线久久| 伊人成人在线综合网| 中文字幕 码 在线视频| 亚洲高清视频在线不卡| 中文字幕人妻av在线观看| 女生被男生插的视频网站| 中文字幕最新久久久| 日本少妇人妻xxxxxhd| 日韩精品激情在线观看| 欧美精品 日韩国产| 激情人妻校园春色亚洲欧美| 国产日韩欧美美利坚蜜臀懂色| 免费看国产又粗又猛又爽又黄视频| 国语对白xxxx乱大交| weyvv5国产成人精品的视频| 亚洲欧美清纯唯美另类 | 超碰97人人做人人爱| 亚洲欧美综合在线探花| 老司机你懂得福利视频| 88成人免费av网站| 又色又爽又黄又刺激av网站| 中文字幕在线欧美精品| 黄色录像鸡巴插进去| 2021国产一区二区| 天天操天天弄天天射| 伊人开心婷婷国产av| 老师啊太大了啊啊啊尻视频| 国产精品污污污久久| 中文字幕午夜免费福利视频| 亚洲天堂精品福利成人av| sejizz在线视频| 青青尤物在线观看视频网站| 91社福利《在线观看| 亚洲av无硬久久精品蜜桃| 国产男女视频在线播放| 亚洲国产在线精品国偷产拍 | 亚洲欧美综合另类13p| 亚洲人妻视频在线网| 宅男噜噜噜666国产| www骚国产精品视频| 色爱av一区二区三区| 骚货自慰被发现爆操| 久久精品亚洲成在人线a| 夜夜嗨av蜜臀av| 这里只有精品双飞在线播放| 偷拍自拍亚洲视频在线观看| 国产黄色片在线收看| 九色视频在线观看免费| 欧美综合婷婷欧美综合| 爆乳骚货内射骚货内射在线 | 色综合久久无码中文字幕波多| 91精品国产91青青碰| av视屏免费在线播放| 美女福利写真在线观看视频| 青青青青青手机视频| 亚洲美女高潮喷浆视频| 亚洲最大黄 嗯色 操 啊| 国产精品自拍视频大全| 日本在线不卡免费视频| 天天摸天天日天天操| 在线免费观看日本片| 狠狠操操操操操操操操操| 91小伙伴中女熟女高潮| 久久久精品国产亚洲AV一| 亚洲伊人久久精品影院一美女洗澡| 欧美另类一区二区视频| 蜜桃色婷婷久久久福利在线| 精品美女福利在线观看| 在线观看日韩激情视频| 99精品免费观看视频| 中文字幕日韩精品日本| 2018最新中文字幕在线观看| 狠狠嗨日韩综合久久| 日本一区精品视频在线观看| 第一福利视频在线观看| 日韩美女福利视频网| 午夜精品福利91av| 激情啪啪啪啪一区二区三区| 91av中文视频在线| 精品一区二区亚洲欧美| 国产女人叫床高潮大片视频| 首之国产AV医生和护士小芳| 中文字幕AV在线免费看 | 精品少妇一二三视频在线| 超级福利视频在线观看| 日韩影片一区二区三区不卡免费| 都市激情校园春色狠狠| 日本美女性生活一级片| 青青青视频自偷自拍38碰| 日日夜夜狠狠干视频| 国产一区二区火爆视频| 777奇米久久精品一区| 天天干天天操天天爽天天摸 | 欧美日本在线视频一区| 午夜久久久久久久99| 亚洲图片偷拍自拍区| 老司机在线精品福利视频| 一色桃子人妻一区二区三区| 专门看国产熟妇的网站| 自拍偷拍亚洲另类色图| 国产精品国色综合久久| 中文字幕在线观看极品视频| rct470中文字幕在线| 亚洲护士一区二区三区| 粉嫩欧美美人妻小视频| 91久久综合男人天堂| 青娱乐最新视频在线| 黑人3p华裔熟女普通话| 欧洲欧美日韩国产在线| 天天日天天干天天搡| 亚洲护士一区二区三区| 日本免费视频午夜福利视频| 久久人人做人人妻人人玩精品vr| 国产av福利网址大全| 一区二区三区综合视频| 午夜久久久久久久99| 久久艹在线观看视频| 午夜频道成人在线91| 亚洲一级美女啪啪啪| 视频 国产 精品 熟女 | 国产精品一区二区av国| 天天夜天天日天天日| 亚洲综合在线视频可播放| 在线视频自拍第三页| 亚洲av极品精品在线观看| 色婷婷久久久久swag精品| 亚洲欧美一区二区三区电影| 亚洲精品国产久久久久久| 一区二区在线观看少妇| 激情国产小视频在线| 午夜精品在线视频一区| 免费男阳茎伸入女阳道视频 | 亚洲av一妻不如妾| gogo国模私拍视频| 丰满的子国产在线观看| 亚洲免费视频欧洲免费视频| 日本黄在免费看视频| 亚洲专区激情在线观看视频| 狠狠地躁夜夜躁日日躁| 中文字幕在线免费第一页| 阿v天堂2014 一区亚洲| 亚洲欧美另类手机在线| 色综合久久无码中文字幕波多| 亚洲1069综合男同| 亚洲另类综合一区小说| 天干天天天色天天日天天射| 黄色无码鸡吧操逼视频| 色婷婷精品大在线观看| 人妻少妇亚洲精品中文字幕| 搞黄色在线免费观看| 天天操天天干天天艹| 日本性感美女写真视频| 99精品久久久久久久91蜜桃| 亚洲 清纯 国产com| 国产不卡av在线免费| 清纯美女在线观看国产| 38av一区二区三区| 亚洲在线一区二区欧美| 93视频一区二区三区| 啊慢点鸡巴太大了啊舒服视频| 青青青国产免费视频| 久草视频福利在线首页| 亚洲中文精品人人免费| 国产精品伦理片一区二区| 国产美女一区在线观看| 91综合久久亚洲综合| 色综合久久五月色婷婷综合| 蜜桃视频17c在线一区二区| 51国产成人精品视频| 国产va在线观看精品| 欧美女同性恋免费a| 国产一区二区三免费视频| 国产高清精品一区二区三区| 国产亚洲精品品视频在线| 熟女少妇激情五十路| 欧美精品国产综合久久| 少妇ww搡性bbb91| 岳太深了紧紧的中文字幕| 青青操免费日综合视频观看| 亚洲va天堂va国产va久| 亚洲精品国产久久久久久| 超级福利视频在线观看| 中文字幕日韩91人妻在线| 青娱乐极品视频青青草| 亚洲人妻av毛片在线| 午夜极品美女福利视频| 国产精品久久久久久久久福交| 日韩北条麻妃一区在线| 精品人妻一二三区久久| 91极品大一女神正在播放| 国产日韩精品电影7777| 狠狠地躁夜夜躁日日躁| 欧美精品免费aaaaaa| 性感美女诱惑福利视频| 欧美在线精品一区二区三区视频 | 欧美精品欧美极品欧美视频 | 动漫精品视频在线观看| 久久久久久cao我的性感人妻| 久草视频在线一区二区三区资源站 | 国产久久久精品毛片| 老司机免费福利视频网| 最新91精品视频在线 | 小泽玛利亚视频在线观看| 又黄又刺激的午夜小视频| 这里有精品成人国产99| 青青草原网站在线观看| 国产又粗又硬又大视频| 夜色撩人久久7777| 欧美天堂av无线av欧美| 搡老妇人老女人老熟女| 亚洲男人让女人爽的视频| 欧美偷拍亚洲一区二区| 黄色av网站免费在线| 午夜精品久久久久久99热| av黄色成人在线观看| 老司机免费视频网站在线看| 极品性荡少妇一区二区色欲| 中文字幕—97超碰网| 日本午夜爽爽爽爽爽视频在线观看| 在线观看av2025| 在线免费观看亚洲精品电影 | 好男人视频在线免费观看网站| 欧美日韩高清午夜蜜桃大香蕉| 亚洲狠狠婷婷综合久久app| 天天夜天天日天天日| 中文字幕中文字幕 亚洲国产| 又粗又硬又猛又黄免费30| 欧美黄片精彩在线免费观看| 日韩中文字幕福利av| 免费在线观看污污视频网站| 伊人综合aⅴ在线网| 熟女人妻三十路四十路人妻斩| 日韩美女综合中文字幕pp| 不卡一不卡二不卡三| 久久美欧人妻少妇一区二区三区| 91自产国产精品视频| 开心 色 六月 婷婷| 亚洲一级特黄特黄黄色录像片| 爱有来生高清在线中文字幕| 亚洲一级美女啪啪啪| 边摸边做超爽毛片18禁色戒 | 1000部国产精品成人观看视频| 亚洲精品久久综合久| 天堂资源网av中文字幕| 精内国产乱码久久久久久| 欧美精品黑人性xxxx| 黄工厂精品视频在线观看| 老司机深夜免费福利视频在线观看| 日本福利午夜电影在线观看| 免费看国产av网站| 欧美成人黄片一区二区三区| 午夜激情久久不卡一区二区| 青青青青青青草国产| 欧洲亚洲欧美日韩综合| 日本一道二三区视频久久| 欧美精产国品一二三产品价格| 国产揄拍高清国内精品对白| 制丝袜业一区二区三区| 人人妻人人爽人人添夜| 啪啪啪啪啪啪啪免费视频| 日韩成人综艺在线播放| 在线观看黄色成年人网站 | 国产美女精品福利在线| 亚洲高清一区二区三区视频在线| 亚洲av男人的天堂你懂的| 亚洲成人激情视频免费观看了| 欧美成人猛片aaaaaaa| 国产精品成久久久久三级蜜臀av| 99久久99一区二区三区| 性色av一区二区三区久久久| 北条麻妃肉色丝袜视频| av网址国产在线观看| 国产熟妇一区二区三区av | 97精品视频在线观看| av手机免费在线观看高潮| 四川五十路熟女av| 在线观看国产网站资源| 岳太深了紧紧的中文字幕| 国产视频一区在线观看| 97资源人妻免费在线视频| 亚洲人妻视频在线网| 午夜精品一区二区三区城中村| 蜜臀av久久久久蜜臀av麻豆| 人妻熟女中文字幕aⅴ在线| 亚洲福利天堂久久久久久| 十八禁在线观看地址免费| 黄色大片免费观看网站| 中文乱理伦片在线观看| 日韩激情文学在线视频| 偷拍美女一区二区三区| 日韩激情文学在线视频| 免费在线看的黄网站| 97a片免费在线观看| 男女啪啪啪啪啪的网站| 亚洲欧美一卡二卡三卡| 熟女人妻在线中出观看完整版| 天天干天天操天天爽天天摸| 懂色av蜜桃a v| 女蜜桃臀紧身瑜伽裤| 98视频精品在线观看| 好太好爽好想要免费| 国产av一区2区3区| 精品久久久久久高潮| 欧美另类z0z变态| 久久h视频在线观看| 色花堂在线av中文字幕九九 | 午夜久久久久久久99| 人妻少妇av在线观看| 国产a级毛久久久久精品| 色婷婷久久久久swag精品| 在线国产中文字幕视频| 日本午夜福利免费视频| 久久午夜夜伦痒痒想咳嗽P| 国产欧美精品一区二区高清| 毛片av在线免费看| 青草久久视频在线观看| 美日韩在线视频免费看| 老有所依在线观看完整版| 精品久久久久久久久久中文蒉 | 狠狠地躁夜夜躁日日躁| 国产V亚洲V天堂无码欠欠|