国产午夜成人免费看片无遮挡_日本免费xxxx色视频_免费人成网上在线观看_黄网址在线永久免费观看

當前位置:雨林木風下載站 > 技術開發教程 > 詳細頁面

一個用技巧強大的ODBC API 函數訪問數據庫類

一個用技巧強大的ODBC API 函數訪問數據庫類

更新時間:2021-09-25 文章作者:未知 信息來源:網絡 閱讀次數:

/*-- 專項技術學習 -數據庫訪問技術之ODBC API                 
     這個類 通過ODBC API 函數訪問ODBC 數據源的數據表            
     功能簡介:能夠幫定一個臨時指定表,調用類的函數即可對該表    
     插入、增加、修改、簡單統計等等操作(注:通過動態改變表的信息:表名字、
  表字段總數、字段名字、字段類型、字段是否為數值、字段是否為主鍵。這樣
  就可以訪問ODBC 數據源的所有表了)                          
     另外提供一個函數 可以對該數據源的其他表(包括幫定的表)進行 
     刪除、修改功能                                               
     LSZ 2001.08.25                                                  */

/*頭文件*/

#ifndef _WDC_DATABASE_H
#define _WDC_DATABASE_H

#include <sql.h>
#include <sqlext.h>

#define  MAX_FIELDS     500
#define  MAX_ERROR_MSG  1024
#define  MAX_DATA     500

class CWdcDatabase  
{
public:
CWdcDatabase();
virtual ~CWdcDatabase();
    BOOL Open(const CString& sDSN,
     const CString& sTable,
     const CString& sUserId,
     const CString& sPassword)  ; /*打開一個ODBC數據源數據庫*/

public:
BOOL m_bOpen;  /*標志數據庫是否打開*/
BOOL m_bBrackets; /*標識表名、字段名是否用方擴號擴起來*/
int m_nError;  /*ODBC錯誤返回代碼*/
CString m_sQuery; /*操作ODBC 數據源公用的語句,用于方便構造*/
CString m_sErrMsg; /*ODBC錯誤返回信息*/
CString m_sDSN;  /*ODBC 數據源的 DSN*/
CString m_sTable;   /*臨時綁定的表名*/

public:
void DropHstmtSelect(); /*確保公共查詢的語句句柄釋放*/
long GetRecordCount(CString &sSel); /*取得符合條件的記錄數*/
BOOL NextMatchingRecord(); /*查詢符合條件的下一條記錄*/
int SelectMatchingRecords(CString& sWhereContext); /*查詢符合條件的記錄*/
BOOL UpdateRecord(); /*更新臨時綁定的表的一條記錄*/
BOOL AddRecord();    /*增加臨時綁定表一條新記錄*/
BOOL DeleteRecord(CString &sWhereDelete); /*刪除臨時綁定表符合條件記錄*/
BOOL Execute(const CString  &sText); /*執行一個SQL語句,注:可以執行存儲過程*/
void Close();        /*關閉數據庫*/
public:
int m_nFields;       /*臨時綁定表字段的總數*/
CString m_sFieldName[MAX_FIELDS]; /*臨時綁定表字段名字*/
CString m_sFieldValue[MAX_FIELDS];/*臨時綁定表字段值*/
BOOL m_bKeyField[MAX_FIELDS];/*臨時綁定表字段是否為主鍵*/
BOOL m_bNumeric[MAX_FIELDS];/*臨時綁定表字段是否為數值類型*/

private:
CString Quote(CString &sQuote); /*字符串替換*/
RETCODE rc;                     /*ODBC API 涵數執行返回碼*/
HSTMT hstmt, hstmt_select; /*公共語句句柄*/
unsigned char szDSN[200]; /*連接數據源的 DSN */
unsigned char szID[200]; /*連接數據源的 UID */
unsigned char szPassword[200]; /*連接數據源的 PWD*/
unsigned char szQuery[3000]; /*公共執行的語句句柄*/
unsigned char szTemp[1000]; /*公共使用的字符串*/
CString sTemp ; /*公共使用的字符串*/
HENV henv;      /*環境句柄*/
HDBC hdbc;      /*ODBC 連接句柄*/
};

#endif


/*實現文件*/

#include "stdafx.h"
#include "WdcDatabase.h"
#include <sql.h>
#include <sqlext.h>

#ifdef _DEBUG
#undef THIS_FILE
static char THIS_FILE[]=__FILE__;
#define new DEBUG_NEW
#endif

CWdcDatabase::CWdcDatabase()
{
  m_nError = 0;
m_bOpen = false;
m_nFields = 0;
m_bBrackets = false;
}

CWdcDatabase::~CWdcDatabase()
{
    if(m_bOpen)
{
  Close() ;
}
}

BOOL CWdcDatabase::Open(const CString& sDSN,
      const CString& sTable,
      const CString& sUserId,
      const CString& sPassword)
{
    if(m_bOpen)
{
  Close() ;
}

hstmt_select = NULL ;
RETCODE rc ;
CString stemp ;

memset(szDSN,0x00,200) ;
    memset(szID,0x00,200) ;
memset(szPassword,0x00,200) ;
/*Open Database */
SQLAllocEnv(&henv) ;
SQLAllocConnect(henv,&hdbc) ;

strcpy((char*)szDSN,sDSN) ;

stemp = sUserId ;
strcpy((char*)szID,stemp) ;

    stemp = sPassword ;
strcpy((char*)szPassword,stemp) ;

m_sDSN   = sDSN ;
m_sTable = sTable ;

rc = SQLConnect(hdbc,
     szDSN,
     SQL_NTS,
     szID,
     SQL_NTS,
     szPassword,
     SQL_NTS);

m_nError = (int) rc ;

if((rc == SQL_SUCCESS ) ||(rc == SQL_SUCCESS_WITH_INFO))
{
      m_bOpen = TRUE ;
   TRACE0("Open database Succeed !\n") ;
   return TRUE  ;
}
    else
{
      m_bOpen = FALSE ;
   TRACE0("Open Database Failed !\n") ;
   return FALSE ;
}

}

void CWdcDatabase::Close()
{
    if(m_bOpen)
{
  if(hstmt_select)
  {
   SQLFreeStmt(hstmt_select,SQL_DROP) ;
   hstmt_select = NULL ;
  }

  SQLDisconnect(hdbc) ;    /*Dis   hdbc*/
  SQLFreeConnect(hdbc) ;   /*Free  Odbc*/
  SQLFreeEnv(henv) ;       /*Free  henv*/  
  m_bOpen = false;
  TRACE0("Close database Succeed !\n") ;
}
}

BOOL CWdcDatabase::Execute(const CString &sSQL)
{
RETCODE rc ;
    unsigned char szSQLSTATE[6] ;
SDWORD nErr ;
unsigned char msg[MAX_ERROR_MSG + 1] ;
SWORD cbmsg ;

m_sErrMsg = "" ;
m_sQuery = sSQL ;

if(!m_bOpen)
  return FALSE ;

SQLAllocStmt(hdbc,&hstmt) ;
memset((char*)szQuery,0x00,sizeof(szQuery)) ;
strcpy((char*)szQuery,m_sQuery) ;

rc = SQLExecDirect(hstmt,
                 szQuery,
        SQL_NTS) ;

   m_nError = (int) rc ;
   if(rc == SQL_SUCCESS || rc == SQL_SUCCESS_WITH_INFO)
   {
       SQLTransact(henv,hdbc,SQL_COMMIT);
    SQLFreeStmt(hstmt,SQL_DROP) ;
    return TRUE ;
   }
   else
   {
     m_sErrMsg = "" ;
      while(SQLError(0,
               0,
      hstmt,
      szSQLSTATE,
      &nErr,
      msg,
      sizeof(msg),
      &cbmsg) == SQL_SUCCESS)
           m_sErrMsg = "\t\t" + (CString)msg + "\n" ;
      SQLFreeStmt(hstmt,SQL_DROP) ;
   return FALSE ;
   }

}

/*帶入條件為 Where 以后的條件*/
BOOL CWdcDatabase::DeleteRecord(CString &sWhereDelete)
{
   RETCODE rc  ;
   unsigned char szSQLSTATE[6] ;
   SDWORD nErr ;
   unsigned char msg[MAX_ERROR_MSG+1] ;
   SWORD cbmsg ;

   CString sTemp ;

   if(!m_bOpen)
    return FALSE ;

   m_sQuery = "" ;
   m_sErrMsg = "" ;
   
   /*開始構造刪除語句*/
   m_sQuery.Format("Delete From %s ",m_sTable) ;

/* int ff =0 ;
   for(int f= 0 ;f<m_nFields;f++)
   {
    if(m_bKeyField[f]) /*如果是表的主鍵
       {
         if(ff>0) /*如果主鍵超過2個,要把條件連接起來
    m_sQuery += " AND " ;
   ff++ ;

        if (m_bNumeric[f])
   sTemp.Format("%s=%s",m_sFieldName[f],m_sFieldValue[f]) ;
    else
   sTemp.Format("%s=%s",m_sFieldName[f],Quote(m_sFieldValue[f])) ;
         
    m_sQuery += sTemp ;
    }
   }
*/
    if(sWhereDelete !="")
       m_sQuery +=" Where " + sWhereDelete ;

    TRACE0(m_sQuery) ;
memset((char*)szQuery,0x00,sizeof(szQuery)) ;
    strcpy((char*)szQuery,m_sQuery) ;
    SQLAllocStmt(hdbc,&hstmt) ;
    rc = SQLExecDirect(hstmt,
                 szQuery,
        SQL_NTS)  ;

m_nError = (int) rc ;
    if(rc ==SQL_SUCCESS || rc == SQL_SUCCESS_WITH_INFO)
{ /*如果執行成功*/
     SQLTransact(henv,hdbc,SQL_COMMIT);
  SQLFreeStmt(hstmt,SQL_DROP) ;
  return TRUE ;
}
else
{
  m_sErrMsg = "" ;
        while(SQLError(0,
              0,
        hstmt,
        szSQLSTATE,
        &nErr,
        msg,
        sizeof(msg),
        &cbmsg) == SQL_SUCCESS)
       m_sErrMsg = "\t\t" + (CString) msg + "\n" ;
       SQLFreeStmt(hstmt,SQL_DROP) ;
    return FALSE ;
}

}

CString CWdcDatabase::Quote(CString &sText)
{
  CString sResult="" ;
  CString sChar   ;
  int iTextLen = sText.GetLength() ;

  for(int pos = 0 ;pos<iTextLen;pos++)
  {
     sChar = sText.Mid(pos,1) ;
  if (sChar == "'")
   sChar = "''" ;
  sResult += sChar ;
  }

  return  CString("'" + sResult + "'") ;

}

BOOL CWdcDatabase::AddRecord()
{
    unsigned char szSQLSTATE[6] ;
SDWORD nErr ;
unsigned char msg[MAX_ERROR_MSG+1] ;
SWORD cbmsg ;

CString sTemp ;

if(!m_bOpen)
  return FALSE ;

    m_sQuery.Format("Insert Into %s(",m_sTable) ;
    
int ff=0 ;
for(int f=0 ;f<m_nFields;f++)
{
       if(ff>0)
     m_sQuery += "," ;
    ff ++ ;
    m_sQuery += m_sFieldName[f] ;
}

m_sQuery += ") values(" ;
ff = 0 ;
    for(f=0 ;f<m_nFields ;f++)
{
  if(ff>0)
   m_sQuery += "," ;

  ff ++ ;
  /*---如果數據不為空*/
      if(m_sFieldValue[f]!="")
    {
          if(m_bNumeric[f])
           sTemp.Format("%s",m_sFieldValue[f]) ;
   else
     sTemp.Format("%s",Quote(m_sFieldValue[f])) ;
    }
    else
    { /*如果數據為空*/
          sTemp.Format("%s","NULL") ;
    }

  m_sQuery += sTemp ;
}

m_sQuery += ")" ;

memset((char*)szQuery,0x00,sizeof(szQuery)) ;
strcpy((char*)szQuery,m_sQuery) ;
SQLAllocStmt(hdbc,&hstmt) ;
rc = SQLExecDirect(hstmt,
                 szQuery,
        SQL_NTS) ;

m_nError = (int) rc ;
if(rc == SQL_SUCCESS || rc == SQL_SUCCESS_WITH_INFO)
{
     SQLTransact(henv,hdbc,SQL_COMMIT);
        SQLFreeStmt(hstmt,SQL_DROP) ;
  hstmt=NULL ;
  return TRUE ;
}
else
{
  m_sErrMsg = "" ;
        while(SQLError(0,
              0,
        hstmt,
        szSQLSTATE,
        &nErr,
        msg,
        sizeof(msg),
        &cbmsg) == SQL_SUCCESS )

    m_sErrMsg += "\t\t" + (CString) msg +"\n" ;
          SQLFreeStmt(hstmt,SQL_DROP) ;
    return FALSE ;
}
}
/*更新表的指定紀錄*/
BOOL CWdcDatabase::UpdateRecord()
{
  unsigned char szSQLSTATE[6] ;
  SDWORD nErr ;
  unsigned char msg[MAX_ERROR_MSG + 1] ;
  SWORD cbmsg ;

  RETCODE rc ;
  CString sTemp ;

  if(!m_bOpen)
   return FALSE ;

  m_sQuery.Format("Update %s Set ",m_sTable) ;

  int ff = 0 ;
  for(int f= 0 ;f<m_nFields ;f++)
  {
     if (ff>0)
   m_sQuery += "," ;
     
  ff ++ ;

   if(m_sFieldValue[f]!="")  /*數據為空*/
   {
     if(m_bNumeric[f])
       sTemp.Format("%s=%s",m_sFieldName[f],m_sFieldValue[f]) ;
     else
       sTemp.Format("%s=%s",m_sFieldName[f],Quote(m_sFieldValue[f])) ;
   }
   else
       sTemp.Format("%s=%s",m_sFieldName[f],NULL) ;

  m_sQuery += sTemp ;
  }
  m_sQuery += " Where " ;

  ff = 0 ;
  for(f=0 ;f<m_nFields ;f++)
  {
   if(m_bKeyField[f]) /*如果為主鍵*/
   {
         if(ff>0)
    m_sQuery += "," ;
   ff ++ ;
         if(m_bNumeric[f])
    sTemp.Format("%s=%s",m_sFieldName[f],m_sFieldValue[f]) ;
   else
    sTemp.Format("%s=%s",m_sFieldName[f],Quote(m_sFieldValue[f])) ;

   m_sQuery += sTemp ;
   }
  }

  memset((char*)szQuery,0x00,sizeof(szQuery)) ;
  strcpy((char*)szQuery,m_sQuery) ;
  SQLAllocStmt(hdbc,
            &hstmt) ;
  rc = SQLExecDirect(hstmt,
                  szQuery,
      SQL_NTS) ;
  m_nError = (int) rc ;

  if(rc == SQL_SUCCESS || rc == SQL_SUCCESS_WITH_INFO)
  {  
      SQLTransact(henv,hdbc,SQL_COMMIT);
   SQLFreeStmt(hstmt,SQL_DROP) ;
   return TRUE ;
  }
  else
  {  
  m_sErrMsg = "" ;
      while(SQLError(0,
               0,
      hstmt,
      szSQLSTATE,
      &nErr,
      msg,
      sizeof(msg) ,
      &cbmsg ) == SQL_SUCCESS )
      m_sErrMsg += "\t\t" +(CString) msg + "\n" ;
    
   SQLFreeStmt(hstmt,SQL_DROP) ;
   return FALSE ;
  }

}

/* 查找紀錄---
返回值
    1: 即沒有錯誤發生的找到紀錄
    -1: 在查找過程中出現錯誤
    0: 查找過程當中沒有錯誤出現,但是沒有找到適合條件的紀錄,即沒有返回紀錄  */
int CWdcDatabase::SelectMatchingRecords(CString &sWhereContext)
{
   unsigned char szSQLSTATE[6];
   SDWORD nErr ;
   unsigned char msg[MAX_ERROR_MSG+1] ;
   SWORD cbmsg ;
   CString sTemp ;

   char szData[MAX_DATA] ;
   SDWORD cbData ;
   RETCODE rc ;

   if(!m_bOpen)
    return -1 ;

   sTemp="" ;
   int ff=0 ;
   for(int j=0;j<m_nFields;j++)
   {
       if(ff>0)
     sTemp += "," ;
    ff ++ ;
    sTemp += m_sFieldName[j] ;
   }

   if(sWhereContext == "")
      m_sQuery.Format("Select %s from %s",sTemp,m_sTable) ;
   else
   m_sQuery.Format("Select %s From %s Where %s",sTemp,m_sTable,sWhereContext) ;

   SQLAllocStmt(hdbc,&hstmt_select) ;
   memset((char*)szQuery,0x00,sizeof(szQuery)) ;
   strcpy((char*)szQuery,m_sQuery) ;

   rc = SQLExecDirect(hstmt_select,
                   szQuery,
       SQL_NTS) ;
   m_nError = (int) rc ;

   if(rc == SQL_SUCCESS || rc == SQL_SUCCESS_WITH_INFO)
   {
       rc = SQLFetch(hstmt_select );
       if(rc == SQL_SUCCESS || rc == SQL_SUCCESS_WITH_INFO)
    {  /*執行成功,并且有數據*/
      for(int f = 0 ; f<m_nFields ; f++)
   {
               rc = SQLGetData(hstmt_select,
                   f+1 ,
          SQL_C_CHAR,
          szData,
          sizeof(szData) ,
          &cbData ) ;
              
       if(cbData != SQL_NULL_DATA)
    {  /*如果數據不為空*/
                 if(rc == SQL_SUCCESS || rc == SQL_SUCCESS_WITH_INFO)
         m_sFieldValue[f] = CString(szData) ;
        else
       m_sFieldValue[f] = "" ;
    }
    else
     m_sFieldValue[f] = "" ;

   }   

     return 1 ;   /*執行成功,并且有數據*/
    }
    else if(rc == 100)
    {  /*查找成功,但是沒有數據*/
          return 0 ;
    }
   }
       m_sErrMsg = "" ;
    while(SQLError(0,
                0,
       hstmt_select,
       szSQLSTATE,
       &nErr,
       msg,
       sizeof(msg),
       &cbmsg) == SQL_SUCCESS )
       m_sErrMsg += "\t\t" +CString(msg) + "\n" ;
     
    SQLFreeStmt(hstmt_select,SQL_DROP) ;
    hstmt_select = NULL ;
    return -1 ;
}

BOOL CWdcDatabase::NextMatchingRecord()
{
   unsigned char szSQLSTATE[6] ;
   SDWORD nErr ;
   unsigned char msg[MAX_ERROR_MSG+1] ;
   SWORD cbmsg ;

   char szData[MAX_DATA] ;
   SDWORD cbData ;
   RETCODE rc ;

   if(!m_bOpen)
    return FALSE ;

   rc = SQLFetch(hstmt_select) ;
   if(rc == SQL_SUCCESS || rc == SQL_SUCCESS_WITH_INFO)
   {
       for(int f =0 ;f<m_nFields ; f++)
    {
          rc = SQLGetData(hstmt_select,
                 f+1 ,
           SQL_C_CHAR,
           szData,
           sizeof(szData),
           &cbData) ;
            if(cbData !=SQL_NULL_DATA)
   { /*如果數據不為空*/
              if(rc == SQL_SUCCESS || rc == SQL_SUCCESS_WITH_INFO)
            m_sFieldValue[f] = (CString) szData ;
        else
       m_sFieldValue[f] = "" ;
   }
   else
    m_sFieldValue[f] = "" ;

    }   
    return TRUE ;
    }

m_sErrMsg = "" ;
    while(SQLError(0,
             0,
       hstmt_select,
       szSQLSTATE,
       &nErr,
       msg,
       sizeof(msg),
       &cbmsg )==SQL_SUCCESS )
            
           m_sErrMsg += "\t\t" +CString (msg) + "\n" ;
        SQLFreeStmt(hstmt_select,SQL_DROP) ;
     hstmt_select = NULL ;

   return FALSE ;
}
/*統計符合條件的紀錄總數
  返回值
  -1: 執行出錯
  >0: 執行成功,并且返回統計結果 */
long CWdcDatabase::GetRecordCount(CString &sSel)
{
   unsigned char szSQLSTATE[6] ;
   SDWORD nErr ;
   unsigned char ErrMsg[500] ;
   SWORD cbmsg;
   long lRet ;  /*返回值*/

   unsigned char lpSelect[1000];
   memset((char*)lpSelect,0x00,sizeof(lpSelect)) ;
   if(sSel=="")
       sTemp.Format("Select count(*) from %s ",m_sTable) ;
   else
    sTemp.Format("Select Count(*) From %s Where %s",m_sTable,sSel) ;

   if(!m_bOpen)
    return -1  ;
   strcpy((char*)lpSelect,sTemp) ;
   SQLAllocStmt(hdbc,&hstmt_select) ;
   rc=SQLExecDirect(hstmt_select,
              lpSelect,
     SQL_NTS) ;
   if(rc==SQL_SUCCESS || rc == SQL_SUCCESS_WITH_INFO)
   { /* SQLExecDirect True*/
       SQLBindCol(hstmt_select,1,SQL_INTEGER,&lRet,sizeof(int),NULL) ;
    rc = SQLFetch(hstmt_select) ;
    if(rc == SQL_SUCCESS || rc == SQL_SUCCESS_WITH_INFO)
    { /*有數據*/
    SQLFreeStmt(hstmt_select,SQL_DROP) ;
    hstmt_select = NULL ;
          return lRet ;
    }
    else if (rc == 100)
    { /*沒有數據*/
    SQLFreeStmt(hstmt_select,SQL_DROP) ;
    hstmt_select = NULL ;
          return 0 ;
    }
       else if (rc < 0)
    { /*出錯*/
         goto end ;
    }
   }
   else
   { /* SQLExecDirect FALSE */
    goto end ;
  }

end:
  {
      m_sErrMsg = "" ;
         while(SQLError(0,
              0,
        hstmt_select,
                       szSQLSTATE,
        &nErr,
        ErrMsg,
        sizeof(ErrMsg),
        &cbmsg)==SQL_SUCCESS)
         m_sErrMsg += "\t\t" + CString(ErrMsg) +"\n" ;  

   SQLFreeStmt(hstmt_select,SQL_DROP) ;
   hstmt_select = NULL ;
    return -1 ;
  }
}
/*非常有用函數,用在確保語句句柄釋放*/
void CWdcDatabase::DropHstmtSelect()
{
if(hstmt_select !=NULL)
{
  SQLFreeStmt(hstmt_select,SQL_DROP) ;
  hstmt_select = NULL ;
}
}

溫馨提示:喜歡本站的話,請收藏一下本站!

本類教程下載

系統下載排行

国产午夜成人免费看片无遮挡_日本免费xxxx色视频_免费人成网上在线观看_黄网址在线永久免费观看

  • <label id="pxtpz"><meter id="pxtpz"></meter></label>
      1. <span id="pxtpz"><optgroup id="pxtpz"></optgroup></span>

        中文字幕精品综合| 99国产精品久| www.亚洲在线| 国产视频不卡一区| 国产精品123| 国产女人aaa级久久久级| 国产成人av一区二区三区在线观看| 国产日韩欧美高清在线| 色综合天天做天天爱| 午夜精品福利久久久| 日韩精品一区二区三区视频 | 国产在线播精品第三| 久久免费视频一区| 99久久国产综合色|国产精品| 一区二区三区精品在线观看| 欧美肥妇bbw| 岛国精品在线播放| 亚洲成人免费看| 久久奇米777| 日本高清成人免费播放| 久久精品99久久久| 综合在线观看色| 欧美一二三区在线| 色综合久久中文综合久久97| 美国av一区二区| 亚洲天堂av一区| 日韩欧美视频在线| 91精品福利视频| 国产剧情一区在线| 五月激情丁香一区二区三区| 国产精品国产三级国产专播品爱网| 91国偷自产一区二区三区成为亚洲经典| 日韩在线一二三区| 亚洲欧美日韩系列| 亚洲国产精品v| 91精品国产乱码| 色婷婷综合久久久中文一区二区| 久久av资源站| 天天色综合天天| 亚洲激情男女视频| 国产精品国产馆在线真实露脸| 91精品国产福利在线观看| 91免费看片在线观看| 国产毛片一区二区| 青青草精品视频| 午夜精品福利视频网站| 亚洲色图视频免费播放| 国产三级三级三级精品8ⅰ区| 91精品国产手机| 欧美日本在线看| 在线视频一区二区三| bt欧美亚洲午夜电影天堂| 国产在线播精品第三| 久久99国产精品久久99| 日本不卡不码高清免费观看| 亚洲午夜激情网站| 亚洲一区二区免费视频| 亚洲自拍欧美精品| 亚洲影院在线观看| 亚洲午夜电影网| 亚洲超碰精品一区二区| 亚洲高清不卡在线| 亚洲国产成人tv| 午夜精品福利在线| 麻豆国产91在线播放| 青青青爽久久午夜综合久久午夜 | 精品久久久网站| 日韩一区二区高清| 日韩欧美国产三级电影视频| 日韩精品在线一区| 久久亚洲欧美国产精品乐播 | 99在线热播精品免费| 成人精品视频一区二区三区| 99久久99久久综合| 色哟哟一区二区| 精品视频一区三区九区| 欧美日本高清视频在线观看| 日韩久久免费av| 国产精品色在线观看| 亚洲欧美日韩国产中文在线| 亚洲大型综合色站| 紧缚捆绑精品一区二区| 91一区二区在线观看| 欧美人牲a欧美精品| 337p粉嫩大胆色噜噜噜噜亚洲| 亚洲国产电影在线观看| 亚洲成人久久影院| 国产成人啪午夜精品网站男同| 99麻豆久久久国产精品免费| 日本国产一区二区| 欧美videossexotv100| 一色屋精品亚洲香蕉网站| 亚洲午夜电影网| 国产一区二区三区免费| 91国内精品野花午夜精品| 精品国产91洋老外米糕| 亚洲精品精品亚洲| 国产呦萝稀缺另类资源| 欧美偷拍一区二区| 国产亚洲综合av| 偷拍自拍另类欧美| 国产成人综合亚洲91猫咪| 欧美日韩精品一区二区三区四区 | 天天影视涩香欲综合网| 久久er精品视频| 一本在线高清不卡dvd| 精品区一区二区| 亚洲一卡二卡三卡四卡| 成人动漫一区二区三区| 91精品国产免费| 亚洲精品久久久蜜桃| 国产很黄免费观看久久| 日韩欧美久久一区| 亚洲午夜私人影院| 91麻豆免费在线观看| 欧美激情一区二区三区四区| 久久精品国产**网站演员| 欧美系列一区二区| 日韩理论在线观看| 国产不卡视频在线观看| 日韩精品专区在线| 五月激情丁香一区二区三区| 色老汉一区二区三区| 欧美国产日韩a欧美在线观看| 蜜乳av一区二区| 91精品国产综合久久香蕉的特点| 亚洲乱码精品一二三四区日韩在线 | 99久久综合色| 国产精品国产a级| 成人av网站在线观看免费| 国产欧美综合在线| 成人性生交大片免费看中文| 中文字幕精品一区| 成人免费高清视频| 中文字幕一区二区三区精华液| 国产成人99久久亚洲综合精品| 久久久午夜精品| 丁香婷婷综合色啪| 自拍偷拍欧美激情| 在线观看免费视频综合| 午夜亚洲福利老司机| 日韩午夜精品电影| 韩国成人精品a∨在线观看| 精品国产精品网麻豆系列| 国产一区二区调教| 中文字幕av资源一区| 色婷婷综合在线| 日韩精品一级中文字幕精品视频免费观看 | 国产乱国产乱300精品| 久久久精品日韩欧美| 成人综合在线观看| 亚洲色图.com| 91麻豆精品国产91久久久久久久久 | 日韩久久精品一区| 国产jizzjizz一区二区| 国产精品久久久久久亚洲毛片| 99精品视频一区二区| 午夜精品久久久久久久久久| 精品国产sm最大网站免费看| gogogo免费视频观看亚洲一| 美日韩一区二区三区| 国产精品久久久久久久裸模| 欧美在线免费观看视频| 久久99国产精品尤物| 亚洲免费观看高清完整版在线观看| 欧美日韩视频第一区| 国内精品久久久久影院薰衣草| 国产精品区一区二区三区| 欧美伦理电影网| 99re成人在线| 久久成人综合网| 亚洲精品一二三区| 久久蜜桃一区二区| 欧美性大战久久久久久久蜜臀| 激情五月婷婷综合网| 亚洲一二三区不卡| 国产片一区二区三区| 欧美高清www午色夜在线视频| 成人黄色小视频| 国产最新精品免费| 视频在线在亚洲| 亚洲欧美日韩人成在线播放| 久久久精品免费观看| 精品污污网站免费看| 成人免费精品视频| 国模少妇一区二区三区| 日韩成人伦理电影在线观看| 亚洲人精品午夜| 国产精品久久影院| 久久久久久久久久久99999| 9191久久久久久久久久久| 91麻豆精品一区二区三区| 国产suv精品一区二区883| 精品一区二区国语对白| 日本午夜精品一区二区三区电影| 亚洲午夜精品久久久久久久久| 亚洲精品中文在线| 亚洲女爱视频在线| 亚洲欧美成人一区二区三区| 中文字幕亚洲一区二区va在线|