国产无遮挡裸体免费直播视频,久久精品国产蜜臀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中文字幕在线导航| 美女 午夜 在线视频| v888av在线观看视频| 国产aⅴ一线在线观看| 密臀av一区在线观看| 亚国产成人精品久久久| 成人色综合中文字幕| 91大屁股国产一区二区| 97精品综合久久在线| 97人妻色免费视频| 国产高清女主播在线| 日本韩国免费福利精品| 久久精品久久精品亚洲人| 天天日天天爽天天爽| 久久精品国产亚洲精品166m| 91在线免费观看成人| 99精品视频在线观看婷婷| 欧美精品激情在线最新观看视频| 免费在线播放a级片| 久草极品美女视频在线观看| sw137 中文字幕 在线| 伊人开心婷婷国产av| 9久在线视频只有精品| 果冻传媒av一区二区三区 | 91人妻精品一区二区在线看| 亚洲另类图片蜜臀av| 最新国产亚洲精品中文在线| 久久久久久97三级| 人妻少妇精品久久久久久| 一区二区在线观看少妇| 蜜桃久久久久久久人妻| 亚洲午夜高清在线观看| 自拍 日韩 欧美激情| 天天操夜夜操天天操天天操| 自拍偷拍日韩欧美一区二区| 一区二区麻豆传媒黄片| 久久久久久久一区二区三| 乱亲女秽乱长久久久| 在线免费91激情四射 | 又大又湿又爽又紧A视频| 国产午夜男女爽爽爽爽爽视频| 自拍偷拍一区二区三区图片| 精品国产在线手机在线| 欧美特色aaa大片| 在线免费观看视频一二区| 成人动漫大肉棒插进去视频| 国产精品一区二区久久久av| 久久久久久性虐视频| 91精品一区二区三区站长推荐| 无码国产精品一区二区高潮久久4| 日韩无码国产精品强奸乱伦| 久久久91蜜桃精品ad| 成年人免费看在线视频| gay gay男男瑟瑟在线网站| 午夜91一区二区三区| 日本韩国在线观看一区二区| 欧美男同性恋69视频| 人妻av无码专区久久绿巨人| 伊人综合免费在线视频| 天天干夜夜操天天舔| 亚洲精品一区二区三区老狼| 高清一区二区欧美系列| 在线 中文字幕 一区| 91国内精品自线在拍白富美| 熟女人妻在线观看视频| 婷婷午夜国产精品久久久| 欧美精品一区二区三区xxxx| 黄色在线观看免费观看在线| 噜噜色噜噜噜久色超碰| 亚洲av自拍偷拍综合| 欧美日韩熟女一区二区三区| 亚洲成人情色电影在线观看| 北条麻妃肉色丝袜视频| 自拍偷拍,中文字幕| 99久久中文字幕一本人| 搡老妇人老女人老熟女| av中文字幕国产在线观看| 久久精品在线观看一区二区| 91在线视频在线精品3| 97超碰人人搞人人| 激情啪啪啪啪一区二区三区| 国产一区自拍黄视频免费观看| 中英文字幕av一区| 夜夜嗨av蜜臀av| 日韩欧美亚洲熟女人妻| 亚洲成人免费看电影| 欧美久久久久久三级网| 一区二区三区毛片国产一区| 久久麻豆亚洲精品av| 99精品一区二区三区的区| japanese日本熟妇另类| 欧美精品激情在线最新观看视频| 在线网站你懂得老司机| 免费无毒热热热热热热久| 亚洲va国产va欧美精品88| 亚洲熟妇无码一区二区三区| 噜噜色噜噜噜久色超碰| 免费费一级特黄真人片| 亚洲高清国产自产av| 久久麻豆亚洲精品av| 玩弄人妻熟妇性色av少妇| 国产女人露脸高潮对白视频| 第一福利视频在线观看| 免费十精品十国产网站| 国产真实灌醉下药美女av福利| 亚洲人成精品久久久久久久| 哥哥姐姐综合激情小说| 日本高清在线不卡一区二区| 97成人免费在线观看网站| 国产大学生援交正在播放| 一区二区久久成人网| 又大又湿又爽又紧A视频| 经典av尤物一区二区| 97人人妻人人澡人人爽人人精品| 国产亚洲欧美45p| 欧美成人小视频在线免费看| 91国内视频在线观看| 亚洲 中文 自拍 无码| 午夜激情久久不卡一区二区 | 年轻的人妻被夫上司侵犯| 男人的天堂在线黄色| 黄色视频成年人免费观看| 一区二区在线视频中文字幕 | 欧美日韩一区二区电影在线观看| 美女 午夜 在线视频| 黄色成人在线中文字幕| 果冻传媒av一区二区三区| 精品一区二区三区在线观看| 92福利视频午夜1000看| 国产欧美日韩在线观看不卡| 狠狠地躁夜夜躁日日躁| 色呦呦视频在线观看视频| 又粗又硬又猛又黄免费30| 亚洲一区二区三区偷拍女厕91| 2022天天干天天操| 在线播放 日韩 av| 国产精品精品精品999| 日本在线不卡免费视频| 99精品视频之69精品视频| 欧美在线一二三视频| 天天日天天干天天爱| 欧美熟妇一区二区三区仙踪林| 大香蕉伊人中文字幕| 最后99天全集在线观看| 日韩欧美在线观看不卡一区二区| 色天天天天射天天舔| 亚洲国产成人在线一区| 亚洲综合乱码一区二区| 日韩人妻在线视频免费| 人人超碰国字幕观看97| 亚洲精品国产久久久久久| 国产成人精品午夜福利训2021| 亚洲中文字幕乱码区| 青青青爽视频在线播放| 国产品国产三级国产普通话三级| 欧美一区二区三区久久久aaa| 动漫美女的小穴视频| yy96视频在线观看| 国产av国片精品一区二区| 精品国产污污免费网站入口自| 国产变态另类在线观看| 久久久久久97三级| 国产麻豆国语对白露脸剧情 | 午夜的视频在线观看| 91中文字幕免费在线观看| 婷婷激情四射在线观看视频| 日韩美av高清在线| 国产一区av澳门在线观看| 亚洲 中文 自拍 无码| 中文字幕第三十八页久久| 国产一区av澳门在线观看| 一区二区麻豆传媒黄片| 激情伦理欧美日韩中文字幕| 亚洲2021av天堂| 免费福利av在线一区二区三区| 丝袜国产专区在线观看| 日本a级视频老女人| 欧美亚洲偷拍自拍色图| 三级av中文字幕在线观看| 91久久人澡人人添人人爽乱| 福利一二三在线视频观看 | 欧美久久一区二区伊人| 红桃av成人在线观看| 综合激情网激情五月天| 97人妻无码AV碰碰视频| 99热这里只有精品中文| 天天干天天操天天插天天日| 久久精品国产亚洲精品166m| 午夜免费体验区在线观看| 自拍偷拍一区二区三区图片| 午夜精品福利一区二区三区p | 日本欧美视频在线观看三区| 中文字幕乱码人妻电影| 91大神福利视频网| 国产精品视频资源在线播放| 亚国产成人精品久久久| 人妻少妇中文有码精品| 99精品国产aⅴ在线观看| 91天堂精品一区二区| 精品人妻一二三区久久| 亚洲精品福利网站图片| 婷婷午夜国产精品久久久| 一区二区三区视频,福利一区二区| 青青青青青免费视频| 欧美性受xx黑人性猛交| 亚洲综合另类欧美久久| av在线资源中文字幕| 蜜桃色婷婷久久久福利在线| 11久久久久久久久久久| 99热久久极品热亚洲| 亚洲人一区二区中文字幕| 黑人借宿ntr人妻的沦陷2| 丝袜长腿第一页在线| 丰满熟女午夜福利视频| 亚洲天天干 夜夜操| 1769国产精品视频免费观看| 国产精品日韩欧美一区二区| 91中文字幕免费在线观看| 97国产福利小视频合集| 521精品视频在线观看| 亚洲男人让女人爽的视频| 香蕉91一区二区三区| 男人靠女人的逼视频| 日日夜夜精品一二三| 久久精品视频一区二区三区四区| 蜜桃色婷婷久久久福利在线| 强行扒开双腿猛烈进入免费版| 在线观看av2025| 亚洲精品成人网久久久久久小说| 一区二区在线观看少妇| 青青青青操在线观看免费| www日韩a级s片av| 午夜大尺度无码福利视频| 一本一本久久a久久精品综合不卡| 天天射夜夜操狠狠干| 人妻无码中文字幕专区| 好吊操视频这里只有精品| 绝色少妇高潮3在线观看| 亚洲精品色在线观看视频| 国产激情av网站在线观看| 好吊操视频这里只有精品| 国产黄色片蝌蚪九色91| 最近中文字幕国产在线| 端庄人妻堕落挣扎沉沦| 欧美成人综合视频一区二区 | 日韩av大胆在线观看| 九九视频在线精品播放| 天天摸天天干天天操科普| 亚洲自拍偷拍综合色| 久久久久91精品推荐99| 熟妇一区二区三区高清版| 欧美黑人巨大性xxxxx猛交| 又粗又硬又猛又黄免费30| 国产麻豆91在线视频| 五月色婷婷综合开心网4438| 精产国品久久一二三产区区别 | 久草免费人妻视频在线| 91九色国产熟女一区二区| 国产高清精品极品美女| 一区二区三区四区视频| 超鹏97历史在线观看| gogo国模私拍视频| 亚洲 清纯 国产com| 国产揄拍高清国内精品对白| 好吊操视频这里只有精品| 韩国一级特黄大片做受| 黄色大片男人操女人逼| 天堂女人av一区二区| 人妻爱爱 中文字幕| 另类av十亚洲av| 亚洲伊人av天堂有码在线| 男人的网址你懂的亚洲欧洲av| 日本人妻欲求不满中文字幕| 国产日本精品久久久久久久| 欧美香蕉人妻精品一区二区| 大鸡吧插入女阴道黄色片| 天天操天天爽天天干| 巨乳人妻日下部加奈被邻居中出| 国产97在线视频观看| 免费观看成年人视频在线观看| 人妻丝袜av在线播放网址| 最近的中文字幕在线mv视频| 国产白袜脚足J棉袜在线观看| 97小视频人妻一区二区| 国产日韩欧美视频在线导航| sejizz在线视频| 日比视频老公慢点好舒服啊| 一个人免费在线观看ww视频 | 成人激情文学网人妻| 黑人变态深video特大巨大| 五月精品丁香久久久久福利社| 国产精品成久久久久三级蜜臀av| 亚洲成人免费看电影| 在线观看的a站 最新| 青草亚洲视频在线观看| 天天操天天操天天碰| 久久这里有免费精品| 人人妻人人澡人人爽人人dvl| 亚洲免费av在线视频| 狠狠躁夜夜躁人人爽天天天天97| free性日本少妇| 亚洲 国产 成人 在线| 青青青青青免费视频| 亚洲精品中文字幕下载| 亚洲av自拍天堂网| 天干天天天色天天日天天射 | 91破解版永久免费| 亚洲精品乱码久久久本| 欧洲黄页网免费观看| 久久机热/这里只有| 99av国产精品欲麻豆| av完全免费在线观看av| 日本又色又爽又黄又粗| av网址国产在线观看| 天堂va蜜桃一区入口| 欧美乱妇无乱码一区二区| 午夜福利资源综合激情午夜福利资 | 天天日天天干天天插舔舔| 一区二区视频在线观看免费观看| 国产污污污污网站在线| 亚洲高清自偷揄拍自拍| 水蜜桃国产一区二区三区| 超污视频在线观看污污污| 亚洲成人激情视频免费观看了| 中文字幕乱码人妻电影| av在线观看网址av| 国产精品久久综合久久| 92福利视频午夜1000看| 免费观看丰满少妇做受| av俺也去在线播放| 日本午夜福利免费视频| 狠狠躁狠狠爱网站视频| 污污小视频91在线观看| 污污小视频91在线观看| 中文字幕亚洲中文字幕| av在线shipin| 免费一级特黄特色大片在线观看| 日韩一区二区电国产精品| 二区中出在线观看老师| 亚洲自拍偷拍综合色| 中文字幕在线乱码一区二区| 日韩三级黄色片网站| 天天干天天操天天玩天天射 | 美女张开两腿让男人桶av| 美女在线观看日本亚洲一区| 午夜场射精嗯嗯啊啊视频| 午夜91一区二区三区| 亚洲精品国产在线电影| 亚洲图片欧美校园春色| 日本熟女50视频免费| 亚欧在线视频你懂的| 97人人妻人人澡人人爽人人精品| 成人区人妻精品一区二视频 | 午夜频道成人在线91| 亚洲熟妇x久久av久久| 特大黑人巨大xxxx| 欧美成人综合色在线噜噜| 国产女人被做到高潮免费视频| 天天射夜夜操综合网| 亚洲欧洲av天堂综合| 国产欧美日韩在线观看不卡| 中文字幕一区二 区二三区四区| 丝袜国产专区在线观看| mm131美女午夜爽爽爽| 中文字幕AV在线免费看 | 免费费一级特黄真人片| 欧美亚洲免费视频观看| 亚洲视频在线观看高清| 欧美亚洲免费视频观看| 在线国产日韩欧美视频| 亚洲 欧美 精品 激情 偷拍 | 日本熟妇丰满厨房55| xxx日本hd高清| 久久99久久99精品影院| 国产一区av澳门在线观看| 青青青视频自偷自拍38碰| 看一级特黄a大片日本片黑人| 在线观看视频一区麻豆| 亚洲午夜伦理视频在线| 黄色录像鸡巴插进去| 久久精品在线观看一区二区 | 密臀av一区在线观看| 人人妻人人爽人人添夜| 国产精彩福利精品视频| 性感美女诱惑福利视频| 亚洲免费成人a v| 日韩欧美在线观看不卡一区二区 | 日本熟妇色熟妇在线观看| 亚洲va天堂va国产va久| 91精品国产麻豆国产| 亚洲久久午夜av一区二区| 亚洲av日韩av第一区二区三区| 国产一区二区久久久裸臀| 在线观看黄色成年人网站 | 欧洲亚洲欧美日韩综合| 在线播放国产黄色av| 护士小嫩嫩又紧又爽20p| 亚洲天天干 夜夜操| 综合国产成人在线观看| 亚洲熟妇无码一区二区三区| 日本一本午夜在线播放| 最新欧美一二三视频| 欧美性感尤物人妻在线免费看| weyvv5国产成人精品的视频| 人妻少妇亚洲精品中文字幕| 欧美一区二区三区乱码在线播放| 早川濑里奈av黑人番号| 青青草人人妻人人妻| 91p0rny九色露脸熟女| 日本午夜爽爽爽爽爽视频在线观看| 欧美中国日韩久久精品| 亚洲一级特黄特黄黄色录像片| 欧美久久久久久三级网| 11久久久久久久久久久| 丝袜长腿第一页在线| 欧美成人精品在线观看| 亚洲精品在线资源站| 国产精品大陆在线2019不卡| 国产不卡av在线免费| 阿v天堂2014 一区亚洲| 大香蕉伊人国产在线| 国产精品3p和黑人大战| 亚洲粉嫩av一区二区三区| 亚洲免费福利一区二区三区| 一级黄片久久久久久久久| 91www一区二区三区| 韩国爱爱视频中文字幕| 91免费放福利在线观看| 2021年国产精品自拍| 青青青青青操视频在线观看| 婷婷色中文亚洲网68| 一区二区三区国产精选在线播放| 护士特殊服务久久久久久久| 免费观看理论片完整版| 天天躁日日躁狠狠躁躁欧美av| 19一区二区三区在线播放| 老熟妇xxxhd老熟女| 99国产精品窥熟女精品| av天堂资源最新版在线看| 亚洲狠狠婷婷综合久久app| 亚洲视频乱码在线观看| 日本成人一区二区不卡免费在线| 激情国产小视频在线| 99视频精品全部15| 亚洲成人情色电影在线观看| 91麻豆精品91久久久久同性| 大鸡吧插逼逼视频免费看| 欧美亚洲自偷自拍 在线| 黄网十四区丁香社区激情五月天| 男人操女人的逼免费视频| av中文字幕在线导航| 99国内小视频在现欢看| 大肉大捧一进一出好爽在线视频| 大陆精品一区二区三区久久| 色在线观看视频免费的| 亚洲自拍偷拍综合色| 免费看国产又粗又猛又爽又黄视频| 97资源人妻免费在线视频| 性感美女高潮视频久久久| 午夜精品久久久久久99热 | 偷拍自拍福利视频在线观看| 天堂av在线官网中文| 国产精品亚洲在线观看| 免费国产性生活视频| 护士特殊服务久久久久久久| 日本美女成人在线视频| 97香蕉碰碰人妻国产樱花| 亚洲国产成人最新资源| 熟女人妻在线观看视频| 亚洲一区二区三区在线高清| 国产91久久精品一区二区字幕| 大鸡巴操b视频在线| 在线播放国产黄色av| 色狠狠av线不卡香蕉一区二区| 色狠狠av线不卡香蕉一区二区| 青青草国内在线视频精选| 操的小逼流水的文章| 丰满的继坶3中文在线观看| 黄色大片男人操女人逼| 无码精品一区二区三区人| 91在线免费观看成人| 人妻av无码专区久久绿巨人| av中文字幕国产在线观看| 不卡一区一区三区在线| 国产精品黄大片在线播放| 特级欧美插插插插插bbbbb| sspd152中文字幕在线| 很黄很污很色的午夜网站在线观看| 大胆亚洲av日韩av| 久久久久久cao我的性感人妻 | 蜜臀成人av在线播放| jiuse91九色视频| 国产视频在线视频播放| 91精品国产黑色丝袜| 97瑟瑟超碰在线香蕉| 老司机深夜免费福利视频在线观看| 91高清成人在线视频| 黄色中文字幕在线播放| 日本一二三区不卡无| 青青青青青青草国产| 亚洲公开视频在线观看| 91老师蜜桃臀大屁股| 青青社区2国产视频| 视频久久久久久久人妻| 欧美亚洲免费视频观看| 特一级特级黄色网片| 又大又湿又爽又紧A视频| 天天日天天鲁天天操| 成人30分钟免费视频| 久久久久久久久久性潮| 欲乱人妻少妇在线视频裸| 岛国毛片视频免费在线观看| 亚洲成人三级在线播放| 红杏久久av人妻一区| 国产自拍在线观看成人| 18禁免费av网站| 欧美日本在线观看一区二区| 日韩在线中文字幕色| 五月激情婷婷久久综合网| 色吉吉影音天天干天天操| 韩国亚洲欧美超一级在线播放视频| 天天操,天天干,天天射| 国产综合高清在线观看| 在线免费观看日本片| 高潮视频在线快速观看国家快速| 91人妻精品一区二区久久| 欧美成人精品在线观看| aaa久久久久久久久| 精品人人人妻人人玩日产欧| 黄色男人的天堂视频| 免费一级黄色av网站| 久久免看30视频口爆视频| 日本熟妇色熟妇在线观看| 美洲精品一二三产区区别| 蜜桃臀av蜜桃臀av| 91香蕉成人app下载| 青草久久视频在线观看| 青青草原色片网站在线观看| 日本一区精品视频在线观看| 欧美一区二区三区乱码在线播放| 天天日天天透天天操| 97精品视频在线观看| 亚洲欧美日韩视频免费观看| 久久香蕉国产免费天天| 自拍偷拍,中文字幕| 在线观看成人国产电影| 日本韩国免费福利精品| 人妻最新视频在线免费观看| 日本熟妇色熟妇在线观看| 亚洲欧美另类手机在线| 曰本无码人妻丰满熟妇啪啪| 日韩中文字幕在线播放第二页 | 丝袜肉丝一区二区三区四区在线看| 中国无遮挡白丝袜二区精品| 国产福利在线视频一区| 久久尻中国美女视频| 热思思国产99re| 一区二区三区四区视频在线播放| 19一区二区三区在线播放| 亚洲午夜电影之麻豆| 亚洲欧美一区二区三区爱爱动图| 97精品视频在线观看| 午夜精品亚洲精品五月色| 亚洲精品麻豆免费在线观看| 日本少妇高清视频xxxxx| 馒头大胆亚洲一区二区| 亚洲av黄色在线网站| 国产va在线观看精品| 久草视频在线看免费| 中文字幕日韩人妻在线三区| 93精品视频在线观看| 日韩一区二区电国产精品| 丝袜美腿欧美另类 中文字幕| 天天干夜夜操天天舔| 91九色porny国产蝌蚪视频| 久久一区二区三区人妻欧美| 日本av在线一区二区三区| 国产综合精品久久久久蜜臀| 偷拍自拍亚洲视频在线观看| 91试看福利一分钟| 国产麻豆剧果冻传媒app| 免费黄页网站4188| 国产成人小视频在线观看无遮挡| 阿v天堂2014 一区亚洲| 亚洲免费av在线视频| 最后99天全集在线观看| 成年人午夜黄片视频资源| 影音先锋女人av噜噜色| 欧亚日韩一区二区三区观看视频 | 欧美麻豆av在线播放| 日本人妻精品久久久久久| 亚洲视频乱码在线观看| 成人精品视频99第一页| 国产一级麻豆精品免费| 99热国产精品666| 99热久久这里只有精品8| 日韩成人免费电影二区| 特大黑人巨大xxxx| 日韩av中文在线免费观看| 日本性感美女写真视频| 精品国产高潮中文字幕| 亚洲av日韩av网站| 国产又色又刺激在线视频| 国内自拍第一页在线观看| 清纯美女在线观看国产| 中文字幕中文字幕 亚洲国产| 日韩北条麻妃一区在线| 亚洲国产第一页在线观看| 国产一级麻豆精品免费| 大陆精品一区二区三区久久| 2022中文字幕在线| 亚洲免费福利一区二区三区| 最新中文字幕乱码在线| 成人H精品动漫在线无码播放| 热99re69精品8在线播放| 亚洲粉嫩av一区二区三区| 国产午夜福利av导航 | 五十路熟女人妻一区二区9933| 亚洲男人让女人爽的视频| 国产极品精品免费视频 | 性色av一区二区三区久久久| 青草亚洲视频在线观看| 欧美一区二区三区激情啪啪啪 | 中文亚洲欧美日韩无线码 | 精品久久久久久久久久久久人妻| 青青操免费日综合视频观看| 91久久综合男人天堂| 国产妇女自拍区在线观看| 狠狠躁狠狠爱网站视频| 亚洲精品高清自拍av| 熟女在线视频一区二区三区| 五月婷婷在线观看视频免费| 日韩av中文在线免费观看| 蜜桃久久久久久久人妻| 一区二区三区视频,福利一区二区 丰满的子国产在线观看 | 亚洲另类在线免费观看| 日韩三级电影华丽的外出| 亚洲中文精品字幕在线观看| 国产白嫩美女一区二区| 91久久精品色伊人6882| 日韩美在线观看视频黄| 国产精品久久久黄网站| 无码国产精品一区二区高潮久久4| 青草久久视频在线观看| 狍和女人的王色毛片| 日韩a级精品一区二区| 岛国黄色大片在线观看| 亚洲一区二区三区精品乱码| 亚洲2021av天堂| 美女 午夜 在线视频| 伊人精品福利综合导航| 精品国产午夜视频一区二区| 日韩精品中文字幕播放| 污污小视频91在线观看| 中文字幕—97超碰网| 粉嫩欧美美人妻小视频| 在线免费视频 自拍| 欧美成人一二三在线网| 中文字幕在线第一页成人| 97精品视频在线观看| 国产极品精品免费视频| 欧洲国产成人精品91铁牛tv| 亚洲欧美激情中文字幕| 香蕉片在线观看av| 国产美女午夜福利久久| 男人的天堂一区二区在线观看| 亚洲精品成人网久久久久久小说 | 精品成人啪啪18免费蜜臀| www骚国产精品视频| 国产91精品拍在线观看| 老师让我插进去69AV| 精品av国产一区二区三区四区| 92福利视频午夜1000看 | 青青青青青青青青青青草青青 | 55夜色66夜色国产精品站| 一级A一级a爰片免费免会员| 国产亚洲视频在线二区| 欧美一级视频一区二区| 国产亚洲精品视频合集| 欧美成人黄片一区二区三区 | 免费看国产又粗又猛又爽又黄视频| 人妻丝袜精品中文字幕| 国产视频一区二区午夜| 成人24小时免费视频| 日韩精品啪啪视频一道免费| 久久久久91精品推荐99| 亚洲公开视频在线观看| 国产伦精品一区二区三区竹菊| 男人的网址你懂的亚洲欧洲av| 日本av高清免费网站| 成年人午夜黄片视频资源| 日本人妻少妇18—xx| 国产一区二区久久久裸臀| 免费看美女脱光衣服的视频| 只有精品亚洲视频在线观看| 日韩美av高清在线| 成人av在线资源网站| 亚洲av无女神免非久久| 91在线视频在线精品3| 国产视频一区在线观看| 黄色片年轻人在线观看| 91精品国产高清自在线看香蕉网 | 精品久久久久久久久久久a√国产| 欧美精产国品一二三区| 最新97国产在线视频| 免费大片在线观看视频网站| 中文字幕 人妻精品| 精品久久久久久久久久久a√国产| 福利在线视频网址导航| 欧美精品久久久久久影院| 日韩不卡中文在线视频网站| sw137 中文字幕 在线| 免费手机黄页网址大全| 硬鸡巴动态操女人逼视频| 大胆亚洲av日韩av| eeuss鲁片一区二区三区| 欧美va不卡视频在线观看| 日日摸夜夜添夜夜添毛片性色av| 在线国产中文字幕视频| 男人天堂av天天操| 国产变态另类在线观看| 亚洲 欧美 精品 激情 偷拍| 狠狠躁夜夜躁人人爽天天天天97| 亚洲免费视频欧洲免费视频| 国产V亚洲V天堂无码欠欠| 成人免费做爰高潮视频| 亚洲av第国产精品| 亚洲熟妇无码一区二区三区| 91久久人澡人人添人人爽乱| 国产精品午夜国产小视频| 午夜精品一区二区三区城中村| 精品久久婷婷免费视频| 人人在线视频一区二区| 成人高清在线观看视频| 啪啪啪操人视频在线播放| 久久久制服丝袜中文字幕| av在线shipin| 91精品免费久久久久久| 亚洲精品久久综合久| 9久在线视频只有精品| 蜜桃视频入口久久久| 亚洲成人午夜电影在线观看| 99热久久这里只有精品8| 成人30分钟免费视频| 国产亚洲成人免费在线观看 | 日韩视频一区二区免费观看| 男人在床上插女人视频| 人妻少妇精品久久久久久| 影音先锋女人av噜噜色| 97黄网站在线观看| 国产九色91在线视频| 精品一区二区三区欧美| 激情啪啪啪啪一区二区三区| 欧洲亚洲欧美日韩综合| 青娱乐蜜桃臀av色| yellow在线播放av啊啊啊| 成人精品在线观看视频| 国产va精品免费观看| 天堂av在线最新版在线| 一区国内二区日韩三区欧美| 在线播放国产黄色av| 青青在线视频性感少妇和隔壁黑丝 | 久久久久久久精品成人热| 国产性生活中老年人视频网站| 国产激情av网站在线观看| 免费黄页网站4188| 中文字幕 人妻精品| 成人24小时免费视频| 国产精品国产三级国产精东| 在线制服丝袜中文字幕| 2021天天色天天干| 中文字幕在线视频一区二区三区| 成人精品在线观看视频| 亚洲av黄色在线网站| 色偷偷伊人大杳蕉综合网 | 少妇人妻二三区视频| 国产真实乱子伦a视频 | 日本在线不卡免费视频| 久久农村老妇乱69系列| 五月天久久激情视频| 蜜臀成人av在线播放| 久青青草视频手机在线免费观看 | 在线视频自拍第三页| 亚洲美女美妇久久字幕组| 精品国产污污免费网站入口自| 青青青视频自偷自拍38碰| 亚洲天堂第一页中文字幕| 日韩人妻xxxxx| 国产三级片久久久久久久| 班长撕开乳罩揉我胸好爽| 狠狠嗨日韩综合久久| 久久午夜夜伦痒痒想咳嗽P| 在线观看视频网站麻豆| 日本性感美女三级视频| 亚洲图库另类图片区| 日本精品一区二区三区在线视频。 | 丝袜亚洲另类欧美变态| 欧美一区二区三区四区性视频| 欧美在线精品一区二区三区视频 | 亚洲欧美福利在线观看| 午夜91一区二区三区| 五月激情婷婷久久综合网| 天天通天天透天天插| wwwxxx一级黄色片| 亚洲成人午夜电影在线观看| 66久久久久久久久久久| 亚洲老熟妇日本老妇| 天天日天天玩天天摸| 日本熟女50视频免费| 久草视频在线一区二区三区资源站| 粉嫩小穴流水视频在线观看| 中文字幕在线欧美精品| 100%美女蜜桃视频| 欧美伊人久久大香线蕉综合| 色花堂在线av中文字幕九九| 免费福利av在线一区二区三区| 亚洲人妻30pwc| 亚洲在线一区二区欧美| 日韩欧美高清免费在线| 日本午夜福利免费视频| 亚洲av色香蕉一区二区三区| 啊啊好大好爽啊啊操我啊啊视频 | av一本二本在线观看| 日韩人妻xxxxx| 9久在线视频只有精品| 日韩一区二区电国产精品| 91精品视频在线观看免费| 天堂av在线播放免费| 最新国产亚洲精品中文在线| av天堂中文字幕最新| 欧洲国产成人精品91铁牛tv| 93视频一区二区三区| 久久久久久9999久久久久| avjpm亚洲伊人久久| 国产黄色大片在线免费播放| 亚洲男人让女人爽的视频| 天天操夜夜操天天操天天操| 精品美女福利在线观看| 中文字幕之无码色多多| 亚洲一级av大片免费观看| av天堂中文字幕最新| 777奇米久久精品一区| 和邻居少妇愉情中文字幕| 亚洲熟女女同志女同| 精品国产乱码一区二区三区乱| 大香蕉日本伊人中文在线| 中文字幕人妻三级在线观看| 四川乱子伦视频国产vip| 色婷婷精品大在线观看| 成人av在线资源网站| 久精品人妻一区二区三区| 中文字幕免费福利视频6| av资源中文字幕在线观看| 999九九久久久精品| 天天躁夜夜躁日日躁a麻豆| 日日操综合成人av| 91精品免费久久久久久| 人人人妻人人澡人人| nagger可以指黑人吗| 国产综合高清在线观看| 免费成人av中文字幕| 亚洲欧洲一区二区在线观看| av天堂中文字幕最新| 偷拍自拍亚洲视频在线观看| 欧美熟妇一区二区三区仙踪林| 精品美女福利在线观看| 一区二区三区欧美日韩高清播放| 一区二区三区另类在线| 男人插女人视频网站| 久久精品亚洲成在人线a| 中国把吊插入阴蒂的视频| 亚洲午夜电影之麻豆| 2020韩国午夜女主播在线| 91中文字幕最新合集| 成人av久久精品一区二区| 888欧美视频在线| 亚洲变态另类色图天堂网| 又大又湿又爽又紧A视频| 高潮视频在线快速观看国家快速| 成人亚洲国产综合精品| 三级等保密码要求条款| 青春草视频在线免费播放| 亚洲 国产 成人 在线| 好男人视频在线免费观看网站| 亚洲成人熟妇一区二区三区| 五月精品丁香久久久久福利社| 久久久久国产成人精品亚洲午夜| av天堂中文免费在线| 老司机欧美视频在线看| 男女啪啪视频免费在线观看| 日韩欧美中文国产在线 | 亚洲午夜电影之麻豆| 99re6热在线精品| 久久艹在线观看视频| 孕妇奶水仑乱A级毛片免费看| 国产伊人免费在线播放| 熟妇一区二区三区高清版| 亚洲伊人色一综合网| 成人H精品动漫在线无码播放| 国产精品一区二区av国| 国产av福利网址大全| 蜜桃精品久久久一区二区| 阴茎插到阴道里面的视频| 大白屁股精品视频国产| 国产三级片久久久久久久| 宅男噜噜噜666国产| 国产aⅴ一线在线观看| 亚洲国产精品免费在线观看| 欧美一区二区三区高清不卡tv | 久久久久久cao我的性感人妻| 亚洲青青操骚货在线视频| 在线可以看的视频你懂的| 欧美性受xx黑人性猛交| 欧美日韩熟女一区二区三区| 18禁美女无遮挡免费| 东游记中文字幕版哪里可以看到| 天天干天天操天天扣| 免费无码人妻日韩精品一区二区| 男人天堂最新地址av| 天天干天天操天天扣| 一区二区三区在线视频福利| 沈阳熟妇28厘米大战黑人| 亚洲欧美日韩视频免费观看| 国产极品美女久久久久久| 亚洲免费成人a v| 97人妻无码AV碰碰视频| 中文字幕av男人天堂| 天天做天天干天天舔| 最近中文2019年在线看| 天堂av狠狠操蜜桃| 国产极品精品免费视频| 成人伊人精品色xxxx视频| 国产九色91在线观看精品| 日本女大学生的黄色小视频| 成年人中文字幕在线观看| 亚洲免费在线视频网站| 国产极品精品免费视频 | 超级av免费观看一区二区三区| 日本韩国免费福利精品| 日韩欧美一级黄片亚洲| 精内国产乱码久久久久久| 日本少妇的秘密免费视频| 国产免费av一区二区凹凸四季| 唐人色亚洲av嫩草| 国产成人精品久久二区91| 88成人免费av网站| 欧美一区二区三区激情啪啪啪| 女生被男生插的视频网站| 婷婷久久久综合中文字幕| 天堂va蜜桃一区入口| 三级等保密码要求条款| 久久精品国产23696| 国产亚洲欧美视频网站| 毛茸茸的大外阴中国视频| 亚洲人妻30pwc| 国产亚洲欧美视频网站| 黑人大几巴狂插日本少妇| 亚洲综合图片20p| 精品美女久久久久久| 又黄又刺激的午夜小视频| 激情伦理欧美日韩中文字幕| 免费观看国产综合视频| 久久久久久久久久久久久97| 2020久久躁狠狠躁夜夜躁| 国产一区二区欧美三区| 午夜激情精品福利视频| 亚洲码av无色中文| 日本丰满熟妇大屁股久久| 久久精品久久精品亚洲人| 午夜福利人人妻人人澡人人爽| 亚洲成人黄色一区二区三区| 80电影天堂网官网| 人人妻人人爽人人添夜| 中文字幕在线永久免费播放| 视频一区二区在线免费播放| 视频 国产 精品 熟女 | 在线免费观看av日韩| 中文字幕AV在线免费看 | 2018在线福利视频| 亚洲伊人色一综合网| 日本性感美女写真视频| 亚洲1069综合男同| 动漫黑丝美女的鸡巴| 嫩草aⅴ一区二区三区| 亚洲激情偷拍一区二区| 啪啪啪18禁一区二区三区 | 和邻居少妇愉情中文字幕| 久久这里只有精彩视频免费| 100%美女蜜桃视频| 韩国爱爱视频中文字幕| 亚洲推理片免费看网站| 国内自拍第一页在线观看| 亚国产成人精品久久久| 中文人妻AV久久人妻水| 一二三中文乱码亚洲乱码one | 91免费放福利在线观看| jiuse91九色视频| 在线国产精品一区二区三区| 国产女孩喷水在线观看| 国产精品一二三不卡带免费视频 | 18禁精品网站久久| 熟妇一区二区三区高清版| av完全免费在线观看av| 青青青青爽手机在线| 国产aⅴ一线在线观看| 婷婷激情四射在线观看视频| 韩国黄色一级二级三级| 国产亚洲精品视频合集| 性感美女高潮视频久久久| 2022国产综合在线干| 自拍偷拍,中文字幕| 欧美日韩亚洲国产无线码| 瑟瑟视频在线观看免费视频| 日噜噜噜夜夜噜噜噜天天噜噜噜| 啪啪啪啪啪啪啪啪av| 一区二区三区视频,福利一区二区| 11久久久久久久久久久| 午夜成午夜成年片在线观看 | 97超碰免费在线视频| 一区二区三区视频,福利一区二区| 自拍偷拍 国产资源| av一本二本在线观看| 动漫av网站18禁| 伊人日日日草夜夜草| 国产女人叫床高潮大片视频| 天天日天天干天天爱| 日韩精品啪啪视频一道免费| 视频一区二区综合精品| 在线视频自拍第三页| 国产日韩一区二区在线看 | 亚洲综合另类精品小说| 亚洲日产av一区二区在线| 亚洲成av人无码不卡影片一| av大全在线播放免费| 大香蕉福利在线观看| 亚洲欧美在线视频第一页| 天天日天天日天天射天天干| 边摸边做超爽毛片18禁色戒| 乱亲女秽乱长久久久| 亚洲成人熟妇一区二区三区| 天堂av在线官网中文| 在线免费观看亚洲精品电影| 欧美国产亚洲中英文字幕| 国产aⅴ一线在线观看| 亚洲av可乐操首页| 精品日产卡一卡二卡国色天香| av在线资源中文字幕| 乱亲女秽乱长久久久| 国产精品成人xxxx| 老熟妇凹凸淫老妇女av在线观看| 中文字幕日本人妻中出| 在线免费观看亚洲精品电影| 天天日天天鲁天天操| 国产精品黄色的av| 国产精品成人xxxx| 女同久久精品秋霞网| 亚洲人妻视频在线网| 天码人妻一区二区三区在线看| 青草久久视频在线观看| 精品视频一区二区三区四区五区| 人人爱人人妻人人澡39| 色哟哟在线网站入口| 97成人免费在线观看网站| AV天堂一区二区免费试看| 久久热久久视频在线观看| 日本性感美女视频网站| 一级a看免费观看网站| 亚洲精品久久综合久| 中文字幕人妻一区二区视频| 国产高清97在线观看视频| 久久99久久99精品影院| 国产综合精品久久久久蜜臀| 老司机福利精品视频在线| 中文字幕在线永久免费播放| 第一福利视频在线观看| 亚洲成人黄色一区二区三区| 狠狠操操操操操操操操操| 日韩a级精品一区二区| 午夜激情久久不卡一区二区| 免费一级黄色av网站| 午夜久久久久久久99| 激情人妻校园春色亚洲欧美| 大香蕉日本伊人中文在线| 97瑟瑟超碰在线香蕉| 9色在线视频免费观看| 午夜精品一区二区三区更新| 特一级特级黄色网片| 成人福利视频免费在线| 国产九色91在线观看精品| 最后99天全集在线观看| 大鸡八强奸视频在线观看| 欧美天堂av无线av欧美| 国产av国片精品一区二区| 欧美成人精品在线观看| 久久久极品久久蜜桃| 欧美另类z0z变态| 91传媒一区二区三区| 人妻丝袜诱惑我操她视频| 中文字幕日韩无敌亚洲精品| 午夜精品久久久久久99热| 日本女人一级免费片| 亚洲欧美人精品高清| 人妻少妇精品久久久久久| 亚洲成人午夜电影在线观看| 综合精品久久久久97| 激情综合治理六月婷婷| 日韩美女福利视频网| 中文字幕在线观看极品视频| 青草久久视频在线观看| 日本美女成人在线视频| 农村胖女人操逼视频| 丰满少妇翘臀后进式| 亚洲熟妇x久久av久久| 在线观看的黄色免费网站| 六月婷婷激情一区二区三区| 一区国内二区日韩三区欧美| 在线观看911精品国产| 国产美女午夜福利久久| 国产麻豆剧传媒精品国产av蜜桃| 亚洲av可乐操首页| 天堂av在线官网中文| 久青青草视频手机在线免费观看| 国产麻豆精品人妻av| 手机看片福利盒子日韩在线播放| 边摸边做超爽毛片18禁色戒| 亚洲男人的天堂a在线| 老鸭窝在线观看一区| 美女张开两腿让男人桶av| 在线免费观看视频一二区| 大学生A级毛片免费视频| 91色秘乱一区二区三区| 亚洲日本一区二区久久久精品| 中文字幕乱码av资源| 中文字幕在线观看极品视频| 91久久国产成人免费网站| 91国内精品久久久久精品一| 午夜精品一区二区三区城中村| 91久久精品色伊人6882| 五十路丰满人妻熟妇| 午夜dv内射一区区| 一区二区三区日本伦理| 99精品国自产在线人| av中文字幕电影在线看| 日本少妇的秘密免费视频| 午夜精品久久久久久99热| 国产性色生活片毛片春晓精品| 狠狠地躁夜夜躁日日躁| 99精品一区二区三区的区| 国产之丝袜脚在线一区二区三区| www,久久久,com| 免费高清自慰一区二区三区网站| 精彩视频99免费在线| eeuss鲁片一区二区三区| 国产男女视频在线播放| 男人天堂色男人av| 成年人中文字幕在线观看| 粉嫩av蜜乳av蜜臀| 2025年人妻中文字幕乱码在线| 欧美久久久久久三级网| 早川濑里奈av黑人番号| 2020av天堂网在线观看| 国产普通话插插视频| 自拍偷拍,中文字幕| 五月精品丁香久久久久福利社| 天堂va蜜桃一区入口| 黑人性生活视频免费看| 国产精品一区二区三区蜜臀av | jiujiure精品视频在线| 久草视频中文字幕在线观看| 年轻的人妻被夫上司侵犯| 91麻豆精品秘密入口在线观看| 在线视频国产欧美日韩| 国产成人精品久久二区91 | 制服丝袜在线人妻中文字幕| 免费福利av在线一区二区三区| www骚国产精品视频| 免费手机黄页网址大全| 亚洲伊人久久精品影院一美女洗澡| 一区二区视频在线观看视频在线| 色97视频在线播放| 欧美偷拍自拍色图片| 97人妻总资源视频| 性色蜜臀av一区二区三区| 日本人妻欲求不满中文字幕| 熟女在线视频一区二区三区| 国产精选一区在线播放| 爆乳骚货内射骚货内射在线| 日韩精品中文字幕在线| 中文字幕高清资源站| 男生舔女生逼逼的视频| 亚洲一区制服丝袜美腿 | 97超碰国语国产97超碰| 馒头大胆亚洲一区二区| 亚洲卡1卡2卡三卡四老狼| 狠狠的往里顶撞h百合| 91精品免费久久久久久| 日本午夜爽爽爽爽爽视频在线观看 | 国产老熟女伦老熟妇ⅹ| 97超碰人人搞人人| 国产精品久久9999| 欧亚日韩一区二区三区观看视频| 黄网十四区丁香社区激情五月天| 亚洲精品麻豆免费在线观看| 98精产国品一二三产区区别| 福利在线视频网址导航| 啪啪啪操人视频在线播放| 亚洲国产美女一区二区三区软件| 韩国黄色一级二级三级| 在线成人日韩av电影| 免费在线看的黄网站| 亚洲国产精品中文字幕网站| 好吊视频—区二区三区| 精品一区二区三区欧美| 青娱乐在线免费视频盛宴| 欧亚日韩一区二区三区观看视频 | 粗大的内捧猛烈进出爽大牛汉子| 亚洲卡1卡2卡三卡四老狼| 91p0rny九色露脸熟女| 亚洲精品中文字幕下载| 狠狠操操操操操操操操操| 青青青视频手机在线观看| 五月天色婷婷在线观看视频免费| 亚洲精品精品国产综合| 久久丁香花五月天色婷婷| 成年人啪啪视频在线观看| 国产午夜福利av导航| 黄色片年轻人在线观看| 亚洲激情偷拍一区二区| 天天想要天天操天天干| 中文字幕av一区在线观看| 插逼视频双插洞国产操逼插洞| 中文字幕第1页av一天堂网| 青青青青青操视频在线观看| 无忧传媒在线观看视频| av视网站在线观看| 人妻少妇性色欲欧美日韩| 国产成人精品一区在线观看| 久久热久久视频在线观看| 美女被肏内射视频网站| 天天日天天敢天天干| 久久久极品久久蜜桃| 被大鸡吧操的好舒服视频免费| 天天干天天搞天天摸| 免费看国产又粗又猛又爽又黄视频| 日本女人一级免费片| 亚洲中文字幕国产日韩| 免费手机黄页网址大全| 大香蕉伊人国产在线| 91国内视频在线观看| 天天射夜夜操狠狠干| 亚洲av一妻不如妾| 韩国爱爱视频中文字幕| 38av一区二区三区| 国产欧美精品不卡在线| 日本熟女精品一区二区三区| 亚洲一区制服丝袜美腿| 国产精品久久久久网| 成人性爱在线看四区| 老师让我插进去69AV| 高清一区二区欧美系列| 青青草国内在线视频精选| wwwxxx一级黄色片| 亚洲 欧美 精品 激情 偷拍 | 免费岛国喷水视频在线观看 | 任我爽精品视频在线播放| 亚洲av人人澡人人爽人人爱| 91色九色porny| 欧洲欧美日韩国产在线| 99久久超碰人妻国产| 天天干天天操天天扣| 亚洲人一区二区中文字幕| 99久久成人日韩欧美精品| 亚洲高清国产一区二区三区| 大肉大捧一进一出好爽在线视频| 97国产福利小视频合集| 国产又色又刺激在线视频| 搡老妇人老女人老熟女| 岛国av高清在线成人在线| 欧美在线一二三视频| 亚洲人妻av毛片在线| rct470中文字幕在线| 晚上一个人看操B片| 美女操逼免费短视频下载链接| 桃色视频在线观看一区二区 | 午夜在线观看岛国av,com| 成年人午夜黄片视频资源| 伊人成人在线综合网| 在线新三级黄伊人网| 国产精品自偷自拍啪啪啪| 国产a级毛久久久久精品| 在线免费观看国产精品黄色| 国产精品入口麻豆啊啊啊| 黄片色呦呦视频免费看| 亚洲1069综合男同| 久久国产精品精品美女| 美女福利视频网址导航| 熟女人妻三十路四十路人妻斩| 欧美老鸡巴日小嫩逼| 在线视频国产欧美日韩| 日韩熟女系列一区二区三区| 亚洲久久午夜av一区二区| av高潮迭起在线观看| 欧美爆乳肉感大码在线观看| 狠狠地躁夜夜躁日日躁| 国产黄色a级三级三级三级| 神马午夜在线观看视频| 久久永久免费精品人妻专区 | 国产精品黄色的av| 中文字幕人妻被公上司喝醉在线| 一区二区三区的久久的蜜桃的视频| 日韩特级黄片高清在线看| 超碰公开大香蕉97| www,久久久,com| 国产免费高清视频视频| 日本熟妇丰满厨房55| 99久久激情婷婷综合五月天| 日本三极片视频网站观看| 精品国产亚洲av一淫| 亚洲国产香蕉视频在线播放| 中文字幕av第1页中文字幕| 日韩a级精品一区二区| 初美沙希中文字幕在线| 亚洲激情唯美亚洲激情图片| 阿v天堂2014 一区亚洲| 黑人解禁人妻叶爱071| 国产麻豆精品人妻av| 天天日天天天天天天天天天天| 在线观看欧美黄片一区二区三区| 狠狠鲁狠狠操天天晚上干干| 蜜臀av久久久久蜜臀av麻豆| 新婚人妻聚会被中出| 91亚洲国产成人精品性色| 久久精品国产999| 大学生A级毛片免费视频| 国产成人自拍视频在线免费观看| 在线网站你懂得老司机| 国产视频一区二区午夜| 亚洲伊人久久精品影院一美女洗澡| 影音先锋女人av噜噜色| 日韩av有码一区二区三区4| 99久久超碰人妻国产| 蝴蝶伊人久久中文娱乐网| 性生活第二下硬不起来| 国产高清在线观看1区2区| 久久精品在线观看一区二区| 亚洲成人免费看电影| 99的爱精品免费视频| 99人妻视频免费在线| 亚洲成人av一区久久| 成人激情文学网人妻| 亚洲午夜在线视频福利| 国产精品亚洲а∨天堂免| 男人的天堂av日韩亚洲| 91精品国产麻豆国产| 欧美黑人巨大性xxxxx猛交| 精品人妻一二三区久久| 日韩精品中文字幕福利| 久久永久免费精品人妻专区 | 美女福利写真在线观看视频| 白白操白白色在线免费视频| 自拍偷拍日韩欧美一区二区| 人妻少妇中文有码精品| 亚洲 中文 自拍 另类 欧美| 免费成人av中文字幕| 亚洲黄色av网站免费播放| 精品高跟鞋丝袜一区二区| 一区二区三区激情在线| 狠狠鲁狠狠操天天晚上干干| 精品成人啪啪18免费蜜臀| 欧美视频综合第一页| 青青青青爽手机在线| 久精品人妻一区二区三区| 在线 中文字幕 一区| 快插进小逼里大鸡吧视频| 色综合久久久久久久久中文| 亚洲国产在线精品国偷产拍| 少妇ww搡性bbb91| 一区二区三区另类在线| 亚洲欧洲一区二区在线观看| 国产乱子伦精品视频潮优女| 国产男女视频在线播放| 国产综合高清在线观看| 中文字幕中文字幕人妻| 自拍偷拍 国产资源| 日本人妻少妇18—xx| 日韩特级黄片高清在线看| 精品美女久久久久久| 日本性感美女视频网站| 国产又色又刺激在线视频 | 成人高清在线观看视频| 成人国产小视频在线观看| 一区二区三区 自拍偷拍| 日本熟妇丰满厨房55| 超碰中文字幕免费观看| 五月婷婷在线观看视频免费| 国产欧美精品不卡在线| 顶级尤物粉嫩小尤物网站| 自拍偷拍vs一区二区三区| 婷婷综合蜜桃av在线| 国产一级麻豆精品免费| 国产午夜福利av导航| 亚洲国产精品久久久久蜜桃| 国产麻豆乱子伦午夜视频观看| av中文字幕电影在线看| 精品亚洲国产中文自在线| 国产精品久久久久久久女人18| 日本丰满熟妇大屁股久久| 福利午夜视频在线观看| 无套猛戳丰满少妇人妻| 91av中文视频在线| 亚洲视频在线观看高清| 国产男女视频在线播放| 一区二区三区四区中文| 欧美性感尤物人妻在线免费看| 操操网操操伊剧情片中文字幕网| 蜜桃视频入口久久久| 18禁免费av网站| 日韩欧美亚洲熟女人妻| 亚洲麻豆一区二区三区| 国产黑丝高跟鞋视频在线播放| 一区二区三区另类在线| 美女在线观看日本亚洲一区| 国产精品人妻66p| 中文字母永久播放1区2区3区| av俺也去在线播放| 亚洲一区二区三区在线高清| 人人超碰国字幕观看97| 久草视频中文字幕在线观看| 不卡日韩av在线观看| 亚洲av色香蕉一区二区三区| 久久久噜噜噜久久熟女av| 亚洲欧美精品综合图片小说| 成人精品在线观看视频| 99热99这里精品6国产| 欧美中文字幕一区最新网址| 亚洲成人线上免费视频观看| 精产国品久久一二三产区区别 | 韩国AV无码不卡在线播放| 在线免费观看国产精品黄色| 日日夜夜精品一二三| 国产在线观看免费人成短视频| 91麻豆精品91久久久久同性| av完全免费在线观看av| 久久h视频在线观看| 久久久精品精品视频视频| 一区二区三区四区中文| 久久精品美女免费视频| 国产在线观看免费人成短视频| 欧美熟妇一区二区三区仙踪林| 日本特级片中文字幕| 国产精品伦理片一区二区| 精品一区二区三四区| 中文字幕av第1页中文字幕| 亚洲人妻30pwc| 日本一二三中文字幕| 一区二区三区激情在线| 人妻少妇亚洲精品中文字幕| 日韩欧美一级aa大片| 视频一区 视频二区 视频| 免费av岛国天堂网站| 四川乱子伦视频国产vip| 亚洲男人在线天堂网| caoporm超碰国产| 国产精品自拍视频大全| 欧美专区日韩专区国产专区| 日韩欧美在线观看不卡一区二区| 日本午夜爽爽爽爽爽视频在线观看| 自拍偷拍一区二区三区图片| 91色秘乱一区二区三区| 秋霞午夜av福利经典影视| 中国黄色av一级片| 大骚逼91抽插出水视频| 久草电影免费在线观看| 黑人3p华裔熟女普通话| 国产va精品免费观看| 亚洲午夜电影之麻豆| 福利午夜视频在线观看| 日韩欧美在线观看不卡一区二区| 国产片免费观看在线观看| 亚洲va国产va欧美va在线| 老司机福利精品视频在线| 91九色国产porny蝌蚪| 欧美视频中文一区二区三区| 午夜精品九一唐人麻豆嫩草成人| 99热国产精品666| 99一区二区在线观看| 91www一区二区三区| 超污视频在线观看污污污 | 日韩人妻xxxxx| 亚洲欧美精品综合图片小说| 91国内精品久久久久精品一| 天天操天天干天天艹| 宅男噜噜噜666免费观看| 国产高清97在线观看视频| 激情小视频国产在线| 91国产在线视频免费观看| 青青青青青青青青青国产精品视频| 欧美精品欧美极品欧美视频| 久草福利电影在线观看| 亚洲欧美色一区二区| 精品一区二区三四区| 超碰97人人澡人人| 国产性色生活片毛片春晓精品| 中文字幕人妻三级在线观看| 青青青国产免费视频| 伊人综合免费在线视频| 99精品国产aⅴ在线观看| 中文字幕高清资源站| 97超碰国语国产97超碰| 国产精品久久久久久美女校花| 亚洲 中文 自拍 另类 欧美| 青青色国产视频在线| 绝顶痉挛大潮喷高潮无码 | 国产亚洲视频在线二区| 香港三日本三韩国三欧美三级| 女同互舔一区二区三区| 国产精品久久久黄网站| 亚洲一区二区三区偷拍女厕91| 亚洲av天堂在线播放| 欧美成人黄片一区二区三区 | 久草电影免费在线观看| 亚洲精品国偷自产在线观看蜜桃| 日本熟女50视频免费| 在线观看av亚洲情色| 一级A一级a爰片免费免会员| 超污视频在线观看污污污| 国产午夜亚洲精品麻豆| 日本av在线一区二区三区| 中文 成人 在线 视频| 人妻久久无码中文成人| 日本一区精品视频在线观看| 自拍偷拍亚洲精品第2页| 久久美欧人妻少妇一区二区三区| 天天躁日日躁狠狠躁躁欧美av| 青青青青青免费视频| 又粗又硬又猛又黄免费30| 93人妻人人揉人人澡人人| 欧美成一区二区三区四区| 国产极品精品免费视频| 啪啪啪啪啪啪啪免费视频| 国产精品久久9999| 成人性爱在线看四区| 久久农村老妇乱69系列| 欧美亚洲偷拍自拍色图| 国产麻豆乱子伦午夜视频观看| 欧美精品国产综合久久| 大鸡巴操b视频在线| 最新日韩av传媒在线| 毛片av在线免费看| 97人妻总资源视频| 亚洲av极品精品在线观看| 蜜桃臀av蜜桃臀av| 又色又爽又黄的美女裸体| 黑人巨大精品欧美视频| mm131美女午夜爽爽爽| 欧美成人综合色在线噜噜| 亚洲欧美人精品高清| 黄色无码鸡吧操逼视频| 国产大鸡巴大鸡巴操小骚逼小骚逼| 国产一区二区在线欧美| 天天做天天爽夜夜做少妇| 晚上一个人看操B片| 久久久人妻一区二区| 欧美亚洲免费视频观看| 9国产精品久久久久老师| 在线观看av2025| 国产男女视频在线播放| 欲满人妻中文字幕在线| 久久久久久cao我的性感人妻| 大学生A级毛片免费视频| 欧美亚洲免费视频观看| 人妻另类专区欧美制服| 午夜在线精品偷拍一区二| 亚洲av一妻不如妾| 色花堂在线av中文字幕九九| 韩国亚洲欧美超一级在线播放视频 | 大鸡巴后入爆操大屁股美女| 亚洲欧洲一区二区在线观看| 97人人模人人爽人人喊| 超碰公开大香蕉97| 11久久久久久久久久久| 女同性ⅹxx女同hd| 国产剧情演绎系列丝袜高跟| 99re国产在线精品| 欧美一区二区三区在线资源 | 国产janese在线播放| 91麻豆精品久久久久| 日韩欧美在线观看不卡一区二区| 黑人进入丰满少妇视频| 韩国爱爱视频中文字幕| 在线观看亚洲人成免费网址| 91chinese在线视频| 人妻少妇精品久久久久久| 97小视频人妻一区二区| 日本在线不卡免费视频| 人人妻人人爽人人澡人人精品| 五月天久久激情视频| 日韩欧美国产精品91| 欧美少妇性一区二区三区| 粉嫩av蜜乳av蜜臀| 无码日韩人妻精品久久| 超黄超污网站在线观看| 91精品国产观看免费| 国内精品在线播放第一页| 啪啪啪18禁一区二区三区| 天天日天天透天天操| 38av一区二区三区| av日韩在线观看大全| 亚洲国产香蕉视频在线播放| 欧美日韩激情啪啪啪| av手机在线观播放网站| 亚洲蜜臀av一区二区三区九色| 午夜精品久久久久久99热| 人妻在线精品录音叫床| gogo国模私拍视频| 在线亚洲天堂色播av电影| 亚洲午夜电影在线观看| 青青青国产免费视频| 欧美国产亚洲中英文字幕| 夫妻在线观看视频91| 亚洲高清视频在线不卡| 97国产在线av精品| 成年午夜影片国产片| 丰满少妇翘臀后进式| 亚洲欧洲av天堂综合| 国产免费高清视频视频| 欧美黄片精彩在线免费观看 | 国产真实灌醉下药美女av福利| 中国熟女一区二区性xx| 一区二区三区久久久91| 国产视频一区在线观看| 国产熟妇人妻ⅹxxxx麻豆| 人妻久久无码中文成人| 天天躁日日躁狠狠躁躁欧美av| 日本性感美女三级视频| av视网站在线观看| 日韩精品二区一区久久| 色哟哟国产精品入口| 久久麻豆亚洲精品av| 中文字幕人妻av在线观看| www天堂在线久久| 一个人免费在线观看ww视频| 亚洲免费福利一区二区三区| 操日韩美女视频在线免费看| 亚洲无线观看国产高清在线| h国产小视频福利在线观看| 亚洲av无女神免非久久| 黑人乱偷人妻中文字幕| 久久久久只精品国产三级| 亚洲精品av在线观看| 日韩av熟妇在线观看| 亚洲精品午夜aaa久久| 亚洲另类综合一区小说| 国产V亚洲V天堂无码欠欠| 日韩a级黄色小视频| 青青青青操在线观看免费| 老熟妇xxxhd老熟女| 成年午夜影片国产片| 色哟哟国产精品入口| 欧美在线精品一区二区三区视频| 色花堂在线av中文字幕九九 | 粉嫩av蜜乳av蜜臀| 日韩av大胆在线观看| 久久亚洲天堂中文对白| 国产中文字幕四区在线观看| 亚洲国产成人av在线一区| 抽查舔水白紧大视频| 啊啊啊视频试看人妻| 亚洲中文字字幕乱码| 久久久久只精品国产三级| 欧美国产亚洲中英文字幕| 人妻熟女在线一区二区| 99re6热在线精品| 人妻无码中文字幕专区| 五十路人妻熟女av一区二区| 2021久久免费视频| 自拍偷拍亚洲欧美在线视频| 成人24小时免费视频| 亚洲欧美色一区二区| 欧美精品黑人性xxxx| 日韩成人性色生活片| 黄色在线观看免费观看在线| 国产亚洲天堂天天一区| 日韩在线视频观看有码在线| 亚洲人妻国产精品综合| 亚洲欧美一区二区三区电影| 欧美日韩人妻久久精品高清国产| 99精品国自产在线人| 内射久久久久综合网| 在线观看免费视频网| 天天操,天天干,天天射| 国产精品中文av在线播放| 不戴胸罩引我诱的隔壁的人妻| 日韩欧美高清免费在线| 欧洲日韩亚洲一区二区三区 | 大香蕉日本伊人中文在线| 国产密臀av一区二区三| 真实国产乱子伦一区二区| 9国产精品久久久久老师| 岛国av高清在线成人在线| 国产高清女主播在线| 伊人精品福利综合导航| 精品一区二区三区在线观看| 成人资源在线观看免费官网| 欧美精品 日韩国产| 天天色天天舔天天射天天爽 | 欧美精品久久久久久影院| 99人妻视频免费在线| 日本一二三区不卡无| 99热久久这里只有精品8| 日韩人妻丝袜中文字幕| 任你操任你干精品在线视频| 天天日天天添天天爽| 9色在线视频免费观看| 日韩欧美国产一区不卡| 香蕉aⅴ一区二区三区| 精品久久久久久久久久中文蒉 | 天天躁夜夜躁日日躁a麻豆| 任我爽精品视频在线播放| 内射久久久久综合网| 亚洲天天干 夜夜操| 天天艹天天干天天操| 色综合久久无码中文字幕波多| 大鸡巴操娇小玲珑的女孩逼| 女生自摸在线观看一区二区三区 | 日韩熟女av天堂系列| 免费观看理论片完整版| 国产欧美日韩第三页| av乱码一区二区三区| 97国产在线av精品| 偷青青国产精品青青在线观看| 大香蕉福利在线观看| 欧美韩国日本国产亚洲| 欧美亚洲少妇福利视频| 动漫美女的小穴视频| 黄色视频成年人免费观看| 久草极品美女视频在线观看| 2021天天色天天干| 日本一本午夜在线播放| 任你操任你干精品在线视频| 一区二区三区综合视频| 国产超码片内射在线| 唐人色亚洲av嫩草| 操操网操操伊剧情片中文字幕网| 国产精品女邻居小骚货| 欧美在线偷拍视频免费看| 深夜男人福利在线观看| 天天躁夜夜躁日日躁a麻豆| 国产精品3p和黑人大战| 久久尻中国美女视频| 国产亚洲成人免费在线观看| av中文字幕电影在线看| 大陆胖女人与丈夫操b国语高清| 欧美视频一区免费在线| 国产精品久久9999| 欧美精品激情在线最新观看视频| 亚洲第一黄色在线观看| 亚洲一区自拍高清免费视频| 九九热99视频在线观看97| 黑人变态深video特大巨大| 91国产在线免费播放| 97精品视频在线观看| 沙月文乃人妻侵犯中文字幕在线| 国产精品久久综合久久| 国产精品系列在线观看一区二区| 久久久制服丝袜中文字幕| 日本又色又爽又黄又粗| 麻豆性色视频在线观看| 天堂女人av一区二区| 综合一区二区三区蜜臀| 亚洲人人妻一区二区三区| 日本人竟这样玩学生妹| 国产乱弄免费视频观看| 欧美日韩在线精品一区二区三| 夜夜嗨av一区二区三区中文字幕| av日韩在线免费播放| 喷水视频在线观看这里只有精品| 中文字幕成人日韩欧美| 欧美精品一区二区三区xxxx| 久草电影免费在线观看| 久久香蕉国产免费天天| 亚洲欧美一卡二卡三卡| 亚洲在线观看中文字幕av| 中文字幕视频一区二区在线观看| 欧美一区二区中文字幕电影 | 国产精品女邻居小骚货| 中文字幕在线永久免费播放| 国产成人精品一区在线观看| 国产熟妇人妻ⅹxxxx麻豆| 中文字幕无码一区二区免费| 国产精品一区二区久久久av| 日韩欧美一级黄片亚洲| 偷拍自拍福利视频在线观看| 2018最新中文字幕在线观看| 欧美另类重口味极品在线观看| 成人av电影免费版| 天天干夜夜操啊啊啊| 动色av一区二区三区| 岛国青草视频在线观看| 亚洲精品福利网站图片| 午夜dv内射一区区| 伊人日日日草夜夜草| 亚洲天堂av最新网址| 好了av中文字幕在线| 2019av在线视频| 新婚人妻聚会被中出| 少妇人妻久久久久视频黄片| 国产一区二区欧美三区| 91色九色porny| 99精品免费久久久久久久久a| 99精品免费观看视频 | 最新91九色国产在线观看| 熟女国产一区亚洲中文字幕| 日韩人妻xxxxx| 国产高清精品一区二区三区| 中文字幕日韩人妻在线三区| 在线观看欧美黄片一区二区三区| 亚洲公开视频在线观看| 乱亲女秽乱长久久久| 偷拍自拍亚洲视频在线观看| 这里有精品成人国产99| 久久人人做人人妻人人玩精品vr| 青青草原网站在线观看| 男人天堂色男人av| 天天日天天添天天爽| 欧美男同性恋69视频| 国产麻豆剧果冻传媒app| 啊啊好慢点插舔我逼啊啊啊视频| 欧美精品久久久久久影院| 亚洲图库另类图片区| 美女少妇亚洲精选av| 国产精品系列在线观看一区二区| 深夜男人福利在线观看| 91成人在线观看免费视频| 国产成人精品午夜福利训2021| 韩国爱爱视频中文字幕| 播放日本一区二区三区电影| 曰本无码人妻丰满熟妇啪啪| 熟女人妻在线观看视频| 天天色天天操天天透| 亚洲男人的天堂a在线| 国产精品视频男人的天堂| 日本乱人一区二区三区| 98视频精品在线观看| 自拍偷拍日韩欧美一区二区| 成人免费公开视频无毒 | 亚洲图库另类图片区| 成人高潮aa毛片免费| 白白操白白色在线免费视频| 青草青永久在线视频18| 4个黑人操素人视频网站精品91| 97瑟瑟超碰在线香蕉| 中文字幕乱码人妻电影| 亚洲一区二区三区久久午夜| 亚洲一区二区三区偷拍女厕91| 少妇一区二区三区久久久| av中文在线天堂精品| 五月婷婷在线观看视频免费| 午夜精品久久久久久99热| 国产精品成人xxxx| 在线观看成人国产电影| 色噜噜噜噜18禁止观看| 美女av色播在线播放| 国产精品日韩欧美一区二区| 亚洲综合一区成人在线| 日韩a级黄色小视频| 99亚洲美女一区二区三区| 欧美日韩熟女一区二区三区| 3344免费偷拍视频| 久久热这里这里只有精品| 午夜精品久久久久麻豆影视| 欧美精产国品一二三产品区别大吗| 青青青青青操视频在线观看| 成人色综合中文字幕| 粉嫩av蜜乳av蜜臀| 国产大学生援交正在播放| 日本在线一区二区不卡视频| 天天干天天操天天摸天天射| 97精品综合久久在线| 国产在线观看黄色视频| 一色桃子久久精品亚洲| 女生被男生插的视频网站| 91p0rny九色露脸熟女| 老司机免费福利视频网| 2018在线福利视频| 91www一区二区三区| 亚洲精品国品乱码久久久久| 国产伊人免费在线播放| 中字幕人妻熟女人妻a62v网| 免费十精品十国产网站| 国产91久久精品一区二区字幕| 久久久久久久亚洲午夜综合福利 | 国产丰满熟女成人视频| 高潮喷水在线视频观看| 成人福利视频免费在线| 大屁股熟女一区二区三区| 偷拍3456eee| 高清成人av一区三区| 91免费黄片可看视频| 国产一级精品综合av| 亚洲男人在线天堂网| 天天操天天操天天碰| 亚洲熟女女同志女同| 在线亚洲天堂色播av电影| 亚洲少妇人妻无码精品| 不戴胸罩引我诱的隔壁的人妻| 动色av一区二区三区| 亚洲人妻av毛片在线| av网站色偷偷婷婷网男人的天堂| 亚洲成人熟妇一区二区三区| 天天干天天操天天摸天天射 | 中文字幕人妻av在线观看| 88成人免费av网站| 日本欧美视频在线观看三区| 换爱交换乱高清大片| 亚洲国产美女一区二区三区软件| 久久www免费人成一看片| 国产美女一区在线观看| 亚洲精品在线资源站| 岛国青草视频在线观看| 在线观看成人国产电影| 不卡一不卡二不卡三| 欧美地区一二三专区| 男生舔女生逼逼视频| 亚洲国产香蕉视频在线播放| 国产夫妻视频在线观看免费| 2022中文字幕在线| 91国语爽死我了不卡| 深田咏美亚洲一区二区| 93人妻人人揉人人澡人人| 亚洲另类伦春色综合小| 亚洲高清一区二区三区视频在线| 狠狠躁狠狠爱网站视频| 国产女人被做到高潮免费视频| 高潮喷水在线视频观看| 黄色黄色黄片78在线| 青草久久视频在线观看| 国产麻豆乱子伦午夜视频观看| av手机免费在线观看高潮| 欧美精品免费aaaaaa| 亚洲偷自拍高清视频| 日韩加勒比东京热二区| 日本美女性生活一级片| 中文字幕最新久久久| 91国偷自产一区二区三区精品| 阿v天堂2014 一区亚洲| 粉嫩av蜜乳av蜜臀| 中文字幕人妻一区二区视频| 懂色av蜜桃a v| 日韩二区视频一线天婷婷五| 初美沙希中文字幕在线| 插逼视频双插洞国产操逼插洞| av资源中文字幕在线观看| 大鸡吧插逼逼视频免费看 | 一区二区三区国产精选在线播放| 天天色天天爱天天爽| 欧美偷拍亚洲一区二区| 亚洲av日韩av网站| 亚洲国产欧美国产综合在线| 巨乳人妻日下部加奈被邻居中出 | 大白屁股精品视频国产| 欧美视频中文一区二区三区| 国产日韩av一区二区在线| 婷婷综合亚洲爱久久| 在线亚洲天堂色播av电影| 亚洲欧洲一区二区在线观看| 91精品国产麻豆国产| 亚洲一级 片内射视正片| japanese日本熟妇另类| 男生舔女生逼逼视频| 日本av在线一区二区三区| 国产在线拍揄自揄视频网站| 岛国一区二区三区视频在线| 小穴多水久久精品免费看| 亚洲成人情色电影在线观看| 2025年人妻中文字幕乱码在线| 粗大的内捧猛烈进出爽大牛汉子| 亚洲视频在线观看高清| 早川濑里奈av黑人番号| 97人妻色免费视频| 天天射,天天操,天天说| 91免费观看在线网站| 色伦色伦777国产精品| 国产91嫩草久久成人在线视频| 青青社区2国产视频| 成人av中文字幕一区| 在线观看国产网站资源| 十八禁在线观看地址免费| 欧洲日韩亚洲一区二区三区| 男大肉棒猛烈插女免费视频| 久久久人妻一区二区| 欧美第一页在线免费观看视频| 久久久久久国产精品| 色综合久久五月色婷婷综合| 亚洲精品色在线观看视频| 偷拍美女一区二区三区| 特级无码毛片免费视频播放 | 亚洲欧美成人综合视频| 2022国产精品视频| 亚洲狠狠婷婷综合久久app| 欧美性感尤物人妻在线免费看| 日本高清在线不卡一区二区 | 亚洲麻豆一区二区三区| 欧美老妇精品另类不卡片| 视频一区二区在线免费播放| 亚洲精品无码色午夜福利理论片| 18禁免费av网站| 在线免费观看av日韩| 91国内视频在线观看| 1769国产精品视频免费观看| 精品一区二区三区午夜| 免费观看丰满少妇做受| 日本高清撒尿pissing| 日韩精品二区一区久久| 中文字幕欧美日韩射射一| 精品久久久久久久久久久a√国产| 国产无遮挡裸体免费直播视频| 国产欧美日韩在线观看不卡| 国产精品一区二区三区蜜臀av| 人人超碰国字幕观看97| 啊啊好慢点插舔我逼啊啊啊视频| rct470中文字幕在线| 最新97国产在线视频| 国产伊人免费在线播放| 女生被男生插的视频网站| 瑟瑟视频在线观看免费视频| 亚洲精品三级av在线免费观看| 精品久久婷婷免费视频| 999九九久久久精品| 一区二区三区日韩久久| 蜜臀成人av在线播放| 国产精品人久久久久久| 日本一二三中文字幕| 天天干天天搞天天摸| 日韩欧美一级aa大片| 亚洲欧美一区二区三区电影| 国产成人无码精品久久久电影| 亚洲av黄色在线网站| 91精品一区二区三区站长推荐| 国产夫妻视频在线观看免费| 国产欧美日韩在线观看不卡| 久久永久免费精品人妻专区 | 视频在线亚洲一区二区| 精品黑人巨大在线一区| 天天色天天舔天天射天天爽 | 搞黄色在线免费观看| 在线免费91激情四射| 91精品国产观看免费| 一区二区三区另类在线| 97青青青手机在线视频| 99av国产精品欲麻豆| 黄色大片免费观看网站| 国产精品欧美日韩区二区| 亚洲综合另类欧美久久| 免费看美女脱光衣服的视频| 午夜精彩视频免费一区| 人人爽亚洲av人人爽av| 国产三级片久久久久久久| 激情人妻校园春色亚洲欧美| 激情人妻校园春色亚洲欧美| 青青青青在线视频免费观看| 亚洲卡1卡2卡三卡四老狼| 粉嫩欧美美人妻小视频| 亚洲 人妻 激情 中文| AV天堂一区二区免费试看| 啊啊好慢点插舔我逼啊啊啊视频| 一区二区三区av高清免费| 黑人性生活视频免费看| 亚洲伊人av天堂有码在线| 丰满少妇人妻xxxxx| 91麻豆精品秘密入口在线观看| 亚洲精品麻豆免费在线观看| 亚洲一区二区三区av网站| 欧美偷拍亚洲一区二区| 加勒比视频在线免费观看| 在线免费91激情四射 | 国产1区,2区,3区| 免费一级特黄特色大片在线观看 | 国产成人精品亚洲男人的天堂| 五十路熟女人妻一区二| 色哟哟国产精品入口| 玖玖一区二区在线观看| 日韩欧美一级精品在线观看| 青青草人人妻人人妻| 大香蕉伊人中文字幕| 风流唐伯虎电视剧在线观看| 成年午夜影片国产片| 天天日天天操天天摸天天舔 | 天天日天天爽天天干| 在线观看国产免费麻豆| sspd152中文字幕在线| 婷婷综合亚洲爱久久| asmr福利视频在线观看| 大香蕉福利在线观看| 亚洲女人的天堂av| 女人精品内射国产99| 国产一区二区三免费视频| 亚洲免费福利一区二区三区| 国产亚洲精品品视频在线| 中国产一级黄片免费视频播放| 少妇人妻二三区视频 | 亚洲精品av在线观看| 男女啪啪啪啪啪的网站| 精品区一区二区三区四区人妻| 亚洲男人在线天堂网| 在线制服丝袜中文字幕| 久久久精品国产亚洲AV一| 欧美精品黑人性xxxx| 99国内小视频在现欢看| 国产亚洲成人免费在线观看| 最新91精品视频在线| 馒头大胆亚洲一区二区| 一区二区三区在线视频福利| 中国熟女一区二区性xx| 亚洲国产欧美一区二区丝袜黑人| 成年人的在线免费视频| 在线播放 日韩 av| 国产成人精品午夜福利训2021| 97人妻人人澡爽人人精品| 熟女人妻在线观看视频| 久久热久久视频在线观看| 888欧美视频在线| 瑟瑟视频在线观看免费视频| 欧美中文字幕一区最新网址| 日韩美女精品视频在线观看网站| 亚洲天堂成人在线观看视频网站| 国产综合精品久久久久蜜臀| 亚洲欧美综合在线探花| 人妻熟女在线一区二区| 国产剧情演绎系列丝袜高跟| 欧美亚洲国产成人免费在线 | 午夜频道成人在线91| 国产一区成人在线观看视频| 国产伦精品一区二区三区竹菊| 日本中文字幕一二区视频| 又色又爽又黄的美女裸体| 唐人色亚洲av嫩草| 色婷婷六月亚洲综合香蕉| 人人妻人人人操人人人爽| 自拍偷拍,中文字幕| 91免费观看国产免费| 美女 午夜 在线视频| 动漫美女的小穴视频| 国产福利小视频大全| 亚洲国产香蕉视频在线播放| 福利视频网久久91| 国产精品自拍偷拍a| 亚洲午夜电影之麻豆| 久久热久久视频在线观看| 亚洲精品国偷自产在线观看蜜桃| 国产V亚洲V天堂无码欠欠| v888av在线观看视频| 久草视频中文字幕在线观看| 国产精品亚洲在线观看| 香港三日本三韩国三欧美三级| 亚洲免费在线视频网站| 999九九久久久精品| 亚洲男人的天堂a在线| 国产成人精品福利短视频| 75国产综合在线视频| 在线观看国产免费麻豆| 啊慢点鸡巴太大了啊舒服视频| 晚上一个人看操B片| lutube在线成人免费看| 大香蕉伊人国产在线| 欧美在线精品一区二区三区视频 | 亚洲狠狠婷婷综合久久app| 日比视频老公慢点好舒服啊| 大鸡巴后入爆操大屁股美女| 1区2区3区4区视频在线观看| 人人妻人人爽人人添夜| av高潮迭起在线观看| 国产大鸡巴大鸡巴操小骚逼小骚逼| 日本裸体熟妇区二区欧美| 激情国产小视频在线| 91亚洲手机在线视频播放| 一本久久精品一区二区| 亚洲偷自拍高清视频| 日韩欧美一级黄片亚洲| 日本18禁久久久久久| 又黄又刺激的午夜小视频| 天堂va蜜桃一区入口| 不卡一区一区三区在线| 国产成人午夜精品福利| 人妻少妇精品久久久久久| 国产精品一区二区久久久av| 国产精品三级三级三级| 精品美女福利在线观看| 在线观看视频网站麻豆| 国产av自拍偷拍盛宴| 亚洲成人国产综合一区| 班长撕开乳罩揉我胸好爽| 最新激情中文字幕视频| 久精品人妻一区二区三区| 黄色成年网站午夜在线观看| 亚洲欧美一区二区三区爱爱动图| 天天操天天射天天操天天天| 免费看国产av网站| 国产综合视频在线看片| 亚洲av成人免费网站| 久久久麻豆精亚洲av麻花| 国产精品一区二区久久久av| 伊人成人综合开心网| 久草视频中文字幕在线观看| 欧美黑人与人妻精品| 久久久制服丝袜中文字幕| 97资源人妻免费在线视频| 午夜毛片不卡免费观看视频| 含骚鸡巴玩逼逼视频| 丰满熟女午夜福利视频| 国产高清在线观看1区2区| 一区二区三区av高清免费| 九九视频在线精品播放| 99国内小视频在现欢看| 视频 一区二区在线观看| 日韩美在线观看视频黄| 黑人解禁人妻叶爱071| yellow在线播放av啊啊啊| 欧美精品免费aaaaaa| 毛片一级完整版免费| 红杏久久av人妻一区| 日本韩国亚洲综合日韩欧美国产| av高潮迭起在线观看| 天天操天天干天天日狠狠插 | 亚洲欧美福利在线观看| 亚洲精品国品乱码久久久久| 在线免费观看日本片| 亚洲国产成人最新资源| 天天操天天操天天碰| 天美传媒mv视频在线观看| 淫秽激情视频免费观看| 久草视频在线看免费| 欧美黑人与人妻精品| 五色婷婷综合狠狠爱| 五月婷婷在线观看视频免费| 亚洲成人激情av在线| 美味人妻2在线播放| 成人福利视频免费在线| 亚洲午夜电影在线观看| 3337p日本欧洲大胆色噜噜| 新97超碰在线观看| 粉嫩欧美美人妻小视频| 99久久久无码国产精品性出奶水| 日韩加勒比东京热二区| 日本熟妇丰满厨房55| 日韩一区二区三区三州| 噜噜色噜噜噜久色超碰| 免费男阳茎伸入女阳道视频| 成年美女黄网站18禁久久| 51国产偷自视频在线播放| 视频一区 视频二区 视频| 欧美成人一二三在线网| av老司机亚洲一区二区| 欧美80老妇人性视频| av手机在线观播放网站| 91国产在线视频免费观看| 欧美va不卡视频在线观看 | 丝袜美腿欧美另类 中文字幕| 中文字幕第三十八页久久| 都市激情校园春色狠狠| 老鸭窝日韩精品视频观看| 啊啊好大好爽啊啊操我啊啊视频 | 区一区二区三国产中文字幕| 农村胖女人操逼视频| 91av精品视频在线| 国产性感美女福利视频| 日韩欧美亚洲熟女人妻| 又粗又硬又猛又爽又黄的| 丝袜肉丝一区二区三区四区在线 | 亚洲另类图片蜜臀av| 国产极品精品免费视频| 无码国产精品一区二区高潮久久4| 国产自拍黄片在线观看| 六月婷婷激情一区二区三区| 欧美日本国产自视大全| 一区二区三区欧美日韩高清播放| 一二三中文乱码亚洲乱码one| 日本熟妇色熟妇在线观看| 欧美专区第八页一区在线播放| 亚洲麻豆一区二区三区| 51国产成人精品视频| 青青草原网站在线观看| 99精品一区二区三区的区| 日本韩国免费福利精品| 亚洲精品欧美日韩在线播放| 亚洲欧美国产综合777| 亚洲专区激情在线观看视频| 涩爱综合久久五月蜜臀| 男生舔女生逼逼视频| 欧美色呦呦最新网址| 中文字幕在线免费第一页| jiuse91九色视频| 天天操天天干天天插| 久久久极品久久蜜桃| 亚洲午夜福利中文乱码字幕| 亚洲av香蕉一区区二区三区犇| 天天操天天操天天碰| 福利午夜视频在线合集| 午夜精品一区二区三区福利视频| 亚洲免费在线视频网站| 亚洲一区二区三区uij| 75国产综合在线视频| 日本成人不卡一区二区| 老鸭窝在线观看一区| 久久久久久久亚洲午夜综合福利| 亚洲天堂有码中文字幕视频| 欧美日本在线视频一区| 日韩特级黄片高清在线看| 青青操免费日综合视频观看| 青青青青在线视频免费观看| 一级A一级a爰片免费免会员| 国产精品一区二区av国| 成人亚洲精品国产精品| 亚洲av无乱一区二区三区性色| 一区二区三区精品日本| 91在线视频在线精品3| 99精品久久久久久久91蜜桃| 国产变态另类在线观看| 天天日天天添天天爽| 亚洲国产欧美一区二区三区久久| 欧美视频不卡一区四区| 欧美精产国品一二三产品区别大吗| 日韩中文字幕在线播放第二页| 青青青青青青青青青青草青青| 欧美爆乳肉感大码在线观看 | 亚洲欧美激情中文字幕| 国产女人被做到高潮免费视频| 国产91嫩草久久成人在线视频| 91精品国产高清自在线看香蕉网 | 视频一区 二区 三区 综合| 无码国产精品一区二区高潮久久4| 熟女少妇激情五十路| 免费岛国喷水视频在线观看| 亚洲国产精品黑丝美女| 久久永久免费精品人妻专区| 欧美日韩在线精品一区二区三| 精品老妇女久久9g国产| 91亚洲国产成人精品性色| 在线观看的黄色免费网站| 日噜噜噜夜夜噜噜噜天天噜噜噜| 1区2区3区4区视频在线观看| 国产高清女主播在线| 欧美亚洲免费视频观看| 亚洲国产欧美一区二区三区…| 欧美精品伦理三区四区| 日韩亚洲高清在线观看| 青青草精品在线视频观看| av高潮迭起在线观看| 亚洲在线观看中文字幕av| 青青草原色片网站在线观看| 精品亚洲在线免费观看| 国产美女午夜福利久久| 欧美精品资源在线观看| 色哟哟国产精品入口| 少妇露脸深喉口爆吞精| 色综合天天综合网国产成人| 一区二区三区久久中文字幕| 大香蕉大香蕉在线看| 欧美日本国产自视大全| 中字幕人妻熟女人妻a62v网| 97成人免费在线观看网站| 日韩在线中文字幕色| 少妇被强干到高潮视频在线观看| 欧美特色aaa大片| 精品老妇女久久9g国产| 91av精品视频在线| 青青社区2国产视频| 国产乱子伦精品视频潮优女| 午夜dv内射一区区| 成人性爱在线看四区| 色天天天天射天天舔| 成人av久久精品一区二区| okirakuhuhu在线观看| 国产a级毛久久久久精品| 日本性感美女视频网站| 久久艹在线观看视频| 亚洲欧美久久久久久久久| 2022国产精品视频| 国产黄网站在线观看播放| 亚洲一级av无码一级久久精品| 久久午夜夜伦痒痒想咳嗽P| 色婷婷六月亚洲综合香蕉| 99精品免费观看视频| 特黄老太婆aa毛毛片| 一区二区三区毛片国产一区| 中文字幕人妻一区二区视频| 女同性ⅹxx女同h偷拍| 欧美精品免费aaaaaa| 日韩成人性色生活片| 在线免费91激情四射 | 国产白嫩美女一区二区| 91she九色精品国产| 亚洲自拍偷拍综合色| 亚洲天天干 夜夜操| 最近中文2019年在线看| 91精品国产观看免费| 1000小视频在线| 国产精品国产精品一区二区| 欧美日韩国产一区二区三区三州 | 久久久精品精品视频视频| 国产精品黄片免费在线观看| 97人妻色免费视频| 亚洲粉嫩av一区二区三区| 狠狠操操操操操操操操操| 国产成人精品av网站| xxx日本hd高清| 欧美在线一二三视频| 免费大片在线观看视频网站| 55夜色66夜色国产精品站| 视频一区二区综合精品| 亚洲精品国产久久久久久| 日本少妇的秘密免费视频| 女蜜桃臀紧身瑜伽裤| 欧美视频中文一区二区三区| 午夜毛片不卡免费观看视频 | 人妻少妇一区二区三区蜜桃| 北条麻妃av在线免费观看| 青青草在观免费国产精品| 中文字幕在线观看国产片| 国产亚洲成人免费在线观看 | av中文字幕电影在线看| 亚洲激情av一区二区| 91 亚洲视频在线观看| 偷拍自拍视频图片免费| 国产麻豆乱子伦午夜视频观看| 亚洲一区二区三区av网站| 人妻熟女在线一区二区| 欧美一区二区三区激情啪啪啪|