亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

C#基于SQLiteHelper類似SqlHelper類實現存取Sqlite數據庫的方法

2020-01-24 01:40:42
字體:
來源:轉載
供稿:網友

本文實例講述了C#基于SQLiteHelper類似SqlHelper類實現存取Sqlite數據庫的方法。分享給大家供大家參考。具體如下:

這個類不是我實現的,英文原文地址為http://www.eggheadcafe.com/articles/20050315.asp,這里修改了原文中分析sql語句參數的方法,將方法名修改為AttachParameters,將其修飾符修改為private,并直接傳遞command到這個方法,直接綁定參數到comand。修改后的代碼如下

using System;using System.Data;using System.Text.RegularExpressions;using System.Xml;using System.IO;using System.Collections;using System.Data.SQLite;namespace DBUtility.SQLite{ /// <summary> /// SQLiteHelper is a utility class similar to "SQLHelper" in MS /// Data Access Application Block and follows similar pattern. /// </summary> public class SQLiteHelper {  /// <summary>  /// Creates a new <see cref="SQLiteHelper"/> instance. The ctor is marked private since all members are static.  /// </summary>  private SQLiteHelper()  {  }  /// <summary>  /// Creates the command.  /// </summary>  /// <param name="connection">Connection.</param>  /// <param name="commandText">Command text.</param>  /// <param name="commandParameters">Command parameters.</param>  /// <returns>SQLite Command</returns>  public static SQLiteCommand CreateCommand(SQLiteConnection connection, string commandText, params SQLiteParameter[] commandParameters)  {   SQLiteCommand cmd = new SQLiteCommand(commandText, connection);   if (commandParameters.Length > 0)   {    foreach (SQLiteParameter parm in commandParameters)     cmd.Parameters.Add(parm);   }   return cmd;  }  /// <summary>  /// Creates the command.  /// </summary>  /// <param name="connectionString">Connection string.</param>  /// <param name="commandText">Command text.</param>  /// <param name="commandParameters">Command parameters.</param>  /// <returns>SQLite Command</returns>  public static SQLiteCommand CreateCommand(string connectionString, string commandText, params SQLiteParameter[] commandParameters)  {   SQLiteConnection cn = new SQLiteConnection(connectionString);   SQLiteCommand cmd = new SQLiteCommand(commandText, cn);   if (commandParameters.Length > 0)   {    foreach (SQLiteParameter parm in commandParameters)     cmd.Parameters.Add(parm);   }   return cmd;  }  /// <summary>  /// Creates the parameter.  /// </summary>  /// <param name="parameterName">Name of the parameter.</param>  /// <param name="parameterType">Parameter type.</param>  /// <param name="parameterValue">Parameter value.</param>  /// <returns>SQLiteParameter</returns>  public static SQLiteParameter CreateParameter(string parameterName, System.Data.DbType parameterType, object parameterValue)  {   SQLiteParameter parameter = new SQLiteParameter();   parameter.DbType = parameterType;   parameter.ParameterName = parameterName;   parameter.Value = parameterValue;   return parameter;  }  /// <summary>  /// Shortcut method to execute dataset from SQL Statement and object[] arrray of parameter values  /// </summary>  /// <param name="connectionString">SQLite Connection string</param>  /// <param name="commandText">SQL Statement with embedded "@param" style parameter names</param>  /// <param name="paramList">object[] array of parameter values</param>  /// <returns></returns>  public static DataSet ExecuteDataSet(string connectionString, string commandText, object[] paramList)  {   SQLiteConnection cn = new SQLiteConnection(connectionString);   SQLiteCommand cmd = cn.CreateCommand();   cmd.CommandText = commandText;   if (paramList != null)   {    AttachParameters(cmd,commandText, paramList);   }   DataSet ds = new DataSet();   if (cn.State == ConnectionState.Closed)    cn.Open();   SQLiteDataAdapter da = new SQLiteDataAdapter(cmd);   da.Fill(ds);   da.Dispose();   cmd.Dispose();   cn.Close();   return ds;  }  /// <summary>  /// Shortcut method to execute dataset from SQL Statement and object[] arrray of parameter values  /// </summary>  /// <param name="cn">Connection.</param>  /// <param name="commandText">Command text.</param>  /// <param name="paramList">Param list.</param>  /// <returns></returns>  public static DataSet ExecuteDataSet(SQLiteConnection cn, string commandText, object[] paramList)  {   SQLiteCommand cmd = cn.CreateCommand();   cmd.CommandText = commandText;   if (paramList != null)   {    AttachParameters(cmd,commandText, paramList);   }   DataSet ds = new DataSet();   if (cn.State == ConnectionState.Closed)    cn.Open();   SQLiteDataAdapter da = new SQLiteDataAdapter(cmd);   da.Fill(ds);   da.Dispose();   cmd.Dispose();   cn.Close();   return ds;  }  /// <summary>  /// Executes the dataset from a populated Command object.  /// </summary>  /// <param name="cmd">Fully populated SQLiteCommand</param>  /// <returns>DataSet</returns>  public static DataSet ExecuteDataset(SQLiteCommand cmd)  {   if (cmd.Connection.State == ConnectionState.Closed)    cmd.Connection.Open();   DataSet ds = new DataSet();   SQLiteDataAdapter da = new SQLiteDataAdapter(cmd);   da.Fill(ds);   da.Dispose();   cmd.Connection.Close();   cmd.Dispose();   return ds;  }  /// <summary>  /// Executes the dataset in a SQLite Transaction  /// </summary>  /// <param name="transaction">SQLiteTransaction. Transaction consists of Connection, Transaction, /// and Command, all of which must be created prior to making this method call. </param>  /// <param name="commandText">Command text.</param>  /// <param name="commandParameters">Sqlite Command parameters.</param>  /// <returns>DataSet</returns>  /// <remarks>user must examine Transaction Object and handle transaction.connection .Close, etc.</remarks>  public static DataSet ExecuteDataset(SQLiteTransaction transaction, string commandText, params SQLiteParameter[] commandParameters)  {   if (transaction == null) throw new ArgumentNullException("transaction");   if (transaction != null && transaction.Connection == null) throw new ArgumentException("The transaction was rolled back or committed, please provide an open transaction.", "transaction");   IDbCommand cmd = transaction.Connection.CreateCommand();   cmd.CommandText = commandText;   foreach (SQLiteParameter parm in commandParameters)   {    cmd.Parameters.Add(parm);   }   if (transaction.Connection.State == ConnectionState.Closed)    transaction.Connection.Open();   DataSet ds = ExecuteDataset((SQLiteCommand)cmd);   return ds;  }  /// <summary>  /// Executes the dataset with Transaction and object array of parameter values.  /// </summary>  /// <param name="transaction">SQLiteTransaction. Transaction consists of Connection, Transaction, /// and Command, all of which must be created prior to making this method call. </param>  /// <param name="commandText">Command text.</param>  /// <param name="commandParameters">object[] array of parameter values.</param>  /// <returns>DataSet</returns>  /// <remarks>user must examine Transaction Object and handle transaction.connection .Close, etc.</remarks>  public static DataSet ExecuteDataset(SQLiteTransaction transaction, string commandText, object[] commandParameters)  {   if (transaction == null) throw new ArgumentNullException("transaction");   if (transaction != null && transaction.Connection == null) throw new ArgumentException("The transaction was rolled back or committed,               please provide an open transaction.", "transaction");   IDbCommand cmd = transaction.Connection.CreateCommand();   cmd.CommandText = commandText;   AttachParameters((SQLiteCommand)cmd,cmd.CommandText, commandParameters);   if (transaction.Connection.State == ConnectionState.Closed)    transaction.Connection.Open();   DataSet ds = ExecuteDataset((SQLiteCommand)cmd);   return ds;  }  #region UpdateDataset  /// <summary>  /// Executes the respective command for each inserted, updated, or deleted row in the DataSet.  /// </summary>  /// <remarks>  /// e.g.:   /// UpdateDataset(conn, insertCommand, deleteCommand, updateCommand, dataSet, "Order");  /// </remarks>  /// <param name="insertCommand">A valid SQL statement to insert new records into the data source</param>  /// <param name="deleteCommand">A valid SQL statement to delete records from the data source</param>  /// <param name="updateCommand">A valid SQL statement used to update records in the data source</param>  /// <param name="dataSet">The DataSet used to update the data source</param>  /// <param name="tableName">The DataTable used to update the data source.</param>  public static void UpdateDataset(SQLiteCommand insertCommand, SQLiteCommand deleteCommand, SQLiteCommand updateCommand, DataSet dataSet, string tableName)  {   if (insertCommand == null) throw new ArgumentNullException("insertCommand");   if (deleteCommand == null) throw new ArgumentNullException("deleteCommand");   if (updateCommand == null) throw new ArgumentNullException("updateCommand");   if (tableName == null || tableName.Length == 0) throw new ArgumentNullException("tableName");   // Create a SQLiteDataAdapter, and dispose of it after we are done   using (SQLiteDataAdapter dataAdapter = new SQLiteDataAdapter())   {    // Set the data adapter commands    dataAdapter.UpdateCommand = updateCommand;    dataAdapter.InsertCommand = insertCommand;    dataAdapter.DeleteCommand = deleteCommand;    // Update the dataset changes in the data source    dataAdapter.Update(dataSet, tableName);    // Commit all the changes made to the DataSet    dataSet.AcceptChanges();   }  }  #endregion  /// <summary>  /// ShortCut method to return IDataReader  /// NOTE: You should explicitly close the Command.connection you passed in as  /// well as call Dispose on the Command after reader is closed.  /// We do this because IDataReader has no underlying Connection Property.  /// </summary>  /// <param name="cmd">SQLiteCommand Object</param>  /// <param name="commandText">SQL Statement with optional embedded "@param" style parameters</param>  /// <param name="paramList">object[] array of parameter values</param>  /// <returns>IDataReader</returns>  public static IDataReader ExecuteReader(SQLiteCommand cmd, string commandText, object[] paramList)  {   if (cmd.Connection == null)    throw new ArgumentException("Command must have live connection attached.", "cmd");   cmd.CommandText = commandText;   AttachParameters(cmd,commandText, paramList);   if (cmd.Connection.State == ConnectionState.Closed)    cmd.Connection.Open();   IDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnection);   return rdr;  }  /// <summary>  /// Shortcut to ExecuteNonQuery with SqlStatement and object[] param values  /// </summary>  /// <param name="connectionString">SQLite Connection String</param>  /// <param name="commandText">Sql Statement with embedded "@param" style parameters</param>  /// <param name="paramList">object[] array of parameter values</param>  /// <returns></returns>  public static int ExecuteNonQuery(string connectionString, string commandText, params object[] paramList)  {   SQLiteConnection cn = new SQLiteConnection(connectionString);   SQLiteCommand cmd = cn.CreateCommand();   cmd.CommandText = commandText;   AttachParameters(cmd,commandText, paramList);   if (cn.State == ConnectionState.Closed)    cn.Open();   int result = cmd.ExecuteNonQuery();   cmd.Dispose();   cn.Close();   return result;  }  public static int ExecuteNonQuery(SQLiteConnection cn, string commandText, params object[] paramList)  {   SQLiteCommand cmd = cn.CreateCommand();   cmd.CommandText = commandText;   AttachParameters(cmd,commandText, paramList);   if (cn.State == ConnectionState.Closed)    cn.Open();   int result = cmd.ExecuteNonQuery();   cmd.Dispose();   cn.Close();   return result;  }  /// <summary>  /// Executes non-query sql Statment with Transaction  /// </summary>  /// <param name="transaction">SQLiteTransaction. Transaction consists of Connection, Transaction, /// and Command, all of which must be created prior to making this method call. </param>  /// <param name="commandText">Command text.</param>  /// <param name="paramList">Param list.</param>  /// <returns>Integer</returns>  /// <remarks>user must examine Transaction Object and handle transaction.connection .Close, etc.</remarks>  public static int ExecuteNonQuery(SQLiteTransaction transaction, string commandText, params object[] paramList)  {   if (transaction == null) throw new ArgumentNullException("transaction");   if (transaction != null && transaction.Connection == null) throw new ArgumentException("The transaction was rolled back or committed,              please provide an open transaction.", "transaction");   IDbCommand cmd = transaction.Connection.CreateCommand();   cmd.CommandText = commandText;   AttachParameters((SQLiteCommand)cmd,cmd.CommandText, paramList);   if (transaction.Connection.State == ConnectionState.Closed)    transaction.Connection.Open();   int result = cmd.ExecuteNonQuery();   cmd.Dispose();   return result;  }  /// <summary>  /// Executes the non query.  /// </summary>  /// <param name="cmd">CMD.</param>  /// <returns></returns>  public static int ExecuteNonQuery(IDbCommand cmd)  {   if (cmd.Connection.State == ConnectionState.Closed)    cmd.Connection.Open();   int result = cmd.ExecuteNonQuery();   cmd.Connection.Close();   cmd.Dispose();   return result;  }  /// <summary>  /// Shortcut to ExecuteScalar with Sql Statement embedded params and object[] param values  /// </summary>  /// <param name="connectionString">SQLite Connection String</param>  /// <param name="commandText">SQL statment with embedded "@param" style parameters</param>  /// <param name="paramList">object[] array of param values</param>  /// <returns></returns>  public static object ExecuteScalar(string connectionString, string commandText, params object[] paramList)  {   SQLiteConnection cn = new SQLiteConnection(connectionString);   SQLiteCommand cmd = cn.CreateCommand();   cmd.CommandText = commandText;   AttachParameters(cmd,commandText, paramList);   if (cn.State == ConnectionState.Closed)    cn.Open();   object result = cmd.ExecuteScalar();   cmd.Dispose();   cn.Close();   return result;  }  /// <summary>  /// Execute XmlReader with complete Command  /// </summary>  /// <param name="command">SQLite Command</param>  /// <returns>XmlReader</returns>  public static XmlReader ExecuteXmlReader(IDbCommand command)  { // open the connection if necessary, but make sure we    // know to close it when we�re done.   if (command.Connection.State != ConnectionState.Open)   {    command.Connection.Open();   }   // get a data adapter    SQLiteDataAdapter da = new SQLiteDataAdapter((SQLiteCommand)command);   DataSet ds = new DataSet();   // fill the data set, and return the schema information   da.MissingSchemaAction = MissingSchemaAction.AddWithKey;   da.Fill(ds);   // convert our dataset to XML   StringReader stream = new StringReader(ds.GetXml());   command.Connection.Close();   // convert our stream of text to an XmlReader   return new XmlTextReader(stream);  }  /// <summary>  /// Parses parameter names from SQL Statement, assigns values from object array , /// and returns fully populated ParameterCollection.  /// </summary>  /// <param name="commandText">Sql Statement with "@param" style embedded parameters</param>  /// <param name="paramList">object[] array of parameter values</param>  /// <returns>SQLiteParameterCollection</returns>  /// <remarks>Status experimental. Regex appears to be handling most issues. Note that parameter object array must be in same ///order as parameter names appear in SQL statement.</remarks>  private static SQLiteParameterCollection AttachParameters(SQLiteCommand cmd, string commandText, params object[] paramList)  {   if (paramList == null || paramList.Length == 0) return null;   SQLiteParameterCollection coll = cmd.Parameters;   string parmString = commandText.Substring(commandText.IndexOf("@"));   // pre-process the string so always at least 1 space after a comma.   parmString = parmString.Replace(",", " ,");   // get the named parameters into a match collection   string pattern = @"(@)/S*(.*?)/b";   Regex ex = new Regex(pattern, RegexOptions.IgnoreCase);   MatchCollection mc = ex.Matches(parmString);   string[] paramNames = new string[mc.Count];   int i = 0;   foreach (Match m in mc)   {    paramNames[i] = m.Value;    i++;   }   // now let's type the parameters   int j = 0;   Type t = null;   foreach (object o in paramList)   {    t = o.GetType();    SQLiteParameter parm = new SQLiteParameter();    switch (t.ToString())    {     case ("DBNull"):     case ("Char"):     case ("SByte"):     case ("UInt16"):     case ("UInt32"):     case ("UInt64"):      throw new SystemException("Invalid data type");     case ("System.String"):      parm.DbType = DbType.String;      parm.ParameterName = paramNames[j];      parm.Value = (string)paramList[j];      coll.Add(parm);      break;     case ("System.Byte[]"):      parm.DbType = DbType.Binary;      parm.ParameterName = paramNames[j];      parm.Value = (byte[])paramList[j];      coll.Add(parm);      break;     case ("System.Int32"):      parm.DbType = DbType.Int32;      parm.ParameterName = paramNames[j];      parm.Value = (int)paramList[j];      coll.Add(parm);      break;     case ("System.Boolean"):      parm.DbType = DbType.Boolean;      parm.ParameterName = paramNames[j];      parm.Value = (bool)paramList[j];      coll.Add(parm);      break;     case ("System.DateTime"):      parm.DbType = DbType.DateTime;      parm.ParameterName = paramNames[j];      parm.Value = Convert.ToDateTime(paramList[j]);      coll.Add(parm);      break;     case ("System.Double"):      parm.DbType = DbType.Double;      parm.ParameterName = paramNames[j];      parm.Value = Convert.ToDouble(paramList[j]);      coll.Add(parm);      break;     case ("System.Decimal"):      parm.DbType = DbType.Decimal;      parm.ParameterName = paramNames[j];      parm.Value = Convert.ToDecimal(paramList[j]);      break;     case ("System.Guid"):      parm.DbType = DbType.Guid;      parm.ParameterName = paramNames[j];      parm.Value = (System.Guid)(paramList[j]);      break;     case ("System.Object"):      parm.DbType = DbType.Object;      parm.ParameterName = paramNames[j];      parm.Value = paramList[j];      coll.Add(parm);      break;     default:      throw new SystemException("Value is of unknown data type");    } // end switch    j++;   }   return coll;  }  /// <summary>  /// Executes non query typed params from a DataRow  /// </summary>  /// <param name="command">Command.</param>  /// <param name="dataRow">Data row.</param>  /// <returns>Integer result code</returns>  public static int ExecuteNonQueryTypedParams(IDbCommand command, DataRow dataRow)  {   int retVal = 0;   // If the row has values, the store procedure parameters must be initialized   if (dataRow != null && dataRow.ItemArray.Length > 0)   {    // Set the parameters values    AssignParameterValues(command.Parameters, dataRow);    retVal = ExecuteNonQuery(command);   }   else   {    retVal = ExecuteNonQuery(command);   }   return retVal;  }  /// <summary>  /// This method assigns dataRow column values to an IDataParameterCollection  /// </summary>  /// <param name="commandParameters">The IDataParameterCollection to be assigned values</param>  /// <param name="dataRow">The dataRow used to hold the command's parameter values</param>  /// <exception cref="System.InvalidOperationException">Thrown if any of the parameter names are invalid.</exception>  protected internal static void AssignParameterValues(IDataParameterCollection commandParameters, DataRow dataRow)  {   if (commandParameters == null || dataRow == null)   {    // Do nothing if we get no data    return;   }   DataColumnCollection columns = dataRow.Table.Columns;   int i = 0;   // Set the parameters values   foreach (IDataParameter commandParameter in commandParameters)   {    // Check the parameter name    if (commandParameter.ParameterName == null ||     commandParameter.ParameterName.Length <= 1)     throw new InvalidOperationException(string.Format(       "Please provide a valid parameter name on the parameter #{0},       the ParameterName property has the following value: '{1}'.",      i, commandParameter.ParameterName));    if (columns.Contains(commandParameter.ParameterName))     commandParameter.Value = dataRow[commandParameter.ParameterName];    else if (columns.Contains(commandParameter.ParameterName.Substring(1)))     commandParameter.Value = dataRow[commandParameter.ParameterName.Substring(1)];    i++;   }  }  /// <summary>  /// This method assigns dataRow column values to an array of IDataParameters  /// </summary>  /// <param name="commandParameters">Array of IDataParameters to be assigned values</param>  /// <param name="dataRow">The dataRow used to hold the stored procedure's parameter values</param>  /// <exception cref="System.InvalidOperationException">Thrown if any of the parameter names are invalid.</exception>  protected void AssignParameterValues(IDataParameter[] commandParameters, DataRow dataRow)  {   if ((commandParameters == null) || (dataRow == null))   {    // Do nothing if we get no data    return;   }   DataColumnCollection columns = dataRow.Table.Columns;   int i = 0;   // Set the parameters values   foreach (IDataParameter commandParameter in commandParameters)   {    // Check the parameter name    if (commandParameter.ParameterName == null ||     commandParameter.ParameterName.Length <= 1)     throw new InvalidOperationException(string.Format(      "Please provide a valid parameter name on the parameter #{0}, the ParameterName property has the following value: '{1}'.",      i, commandParameter.ParameterName));    if (columns.Contains(commandParameter.ParameterName))     commandParameter.Value = dataRow[commandParameter.ParameterName];    else if (columns.Contains(commandParameter.ParameterName.Substring(1)))     commandParameter.Value = dataRow[commandParameter.ParameterName.Substring(1)];    i++;   }  }  /// <summary>  /// This method assigns an array of values to an array of IDataParameters  /// </summary>  /// <param name="commandParameters">Array of IDataParameters to be assigned values</param>  /// <param name="parameterValues">Array of objects holding the values to be assigned</param>  /// <exception cref="System.ArgumentException">Thrown if an incorrect number of parameters are passed.</exception>  protected void AssignParameterValues(IDataParameter[] commandParameters, params object[] parameterValues)  {   if ((commandParameters == null) || (parameterValues == null))   {    // Do nothing if we get no data    return;   }   // We must have the same number of values as we pave parameters to put them in   if (commandParameters.Length != parameterValues.Length)   {    throw new ArgumentException("Parameter count does not match Parameter Value count.");   }   // Iterate through the IDataParameters, assigning the values from the corresponding position in the    // value array   for (int i = 0, j = commandParameters.Length, k = 0; i < j; i++)   {    if (commandParameters[i].Direction != ParameterDirection.ReturnValue)    {     // If the current array value derives from IDataParameter, then assign its Value property     if (parameterValues[k] is IDataParameter)     {      IDataParameter paramInstance;      paramInstance = (IDataParameter)parameterValues[k];      if (paramInstance.Direction == ParameterDirection.ReturnValue)      {       paramInstance = (IDataParameter)parameterValues[++k];      }      if (paramInstance.Value == null)      {       commandParameters[i].Value = DBNull.Value;      }      else      {       commandParameters[i].Value = paramInstance.Value;      }     }     else if (parameterValues[k] == null)     {      commandParameters[i].Value = DBNull.Value;     }     else     {      commandParameters[i].Value = parameterValues[k];     }     k++;    }   }  } }}

希望本文所述對大家的C#程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
68精品国产免费久久久久久婷婷| 国产精品丝袜久久久久久高清| 欧美—级a级欧美特级ar全黄| 亚洲精品影视在线观看| 亚洲人成免费电影| 欧美日韩一区二区三区在线免费观看| 国产精品极品美女粉嫩高清在线| 欧美日韩国产丝袜另类| 欧美高清一级大片| 91精品视频专区| 色中色综合影院手机版在线观看| 久久亚洲成人精品| 久久精品国亚洲| 777午夜精品福利在线观看| 国内揄拍国内精品少妇国语| 国产精品无av码在线观看| 91久久精品国产91久久性色| 亚洲精品久久久久久久久| 久久6精品影院| 6080yy精品一区二区三区| 欧美性生活大片免费观看网址| 青青久久av北条麻妃黑人| 欧美综合第一页| 成人免费视频97| 日韩中文字幕视频| 狠狠综合久久av一区二区小说| 中文字幕在线观看日韩| 精品国产成人av| 91精品久久久久久久久久久| 日韩成人在线视频| 伦伦影院午夜日韩欧美限制| 91亚洲永久免费精品| 国产午夜精品一区理论片飘花| 久久天堂av综合合色| 久久影视三级福利片| 中文字幕av一区中文字幕天堂| yellow中文字幕久久| 亚洲欧美变态国产另类| 日韩成人在线网站| 亚洲最大福利视频网站| 国产精品老女人视频| 欧美日本在线视频中文字字幕| 一区二区中文字幕| 欧美福利视频网站| 国产精品观看在线亚洲人成网| 久久亚洲国产精品| 国产精品7m视频| 亚洲日本欧美中文幕| 国产91在线播放精品91| 欧美高清在线观看| 欧美中文字幕视频| 亚洲精品国产精品乱码不99按摩| 国产欧美日韩综合精品| 69久久夜色精品国产69| 亚洲成年人在线播放| 日韩欧美国产网站| 国产丝袜一区视频在线观看| y97精品国产97久久久久久| 最近中文字幕日韩精品| 一个人www欧美| 中文字幕av一区二区三区谷原希美| 中文字幕日韩欧美| 中文字幕亚洲欧美在线| 日韩视频在线一区| 成人a视频在线观看| 国产视频精品免费播放| 中文字幕在线视频日韩| 亚洲欧美精品伊人久久| 欧美另类69精品久久久久9999| 自拍偷拍亚洲在线| 高清欧美性猛交xxxx| 欧美一级在线播放| 日韩国产激情在线| 国产精品偷伦免费视频观看的| 欧美日韩性生活视频| 国产精品久久久久免费a∨大胸| 国产精品美女在线观看| 国产成人精品久久二区二区91| 国产精品黄页免费高清在线观看| 91久久精品久久国产性色也91| 亚洲高清久久网| 欧美日韩xxx| 69国产精品成人在线播放| 亚洲激情在线观看| 中文字幕视频在线免费欧美日韩综合在线看| 亚洲精品成人久久电影| 青青精品视频播放| 国产91精品最新在线播放| 少妇高潮久久77777| 亚洲欧美国产精品专区久久| 欧美日韩成人黄色| 国产91免费看片| 国产精品黄色影片导航在线观看| 欧美影院在线播放| 91精品国产成人| 中文字幕一区二区精品| 亚洲视频在线播放| 久久久国产视频91| 欧美日韩国产精品一区| 欧美精品在线观看| 日韩免费在线电影| 日韩**中文字幕毛片| 国产精品精品久久久久久| 亚洲精品一区二三区不卡| 国产欧美久久一区二区| 久久精品99国产精品酒店日本| 久久久久久久久久久久av| 超在线视频97| 最好看的2019年中文视频| 狠狠做深爱婷婷久久综合一区| 中文字幕9999| 国产精品欧美日韩一区二区| 国产91精品久| 国产成人免费av电影| 欧美激情在线有限公司| 超薄丝袜一区二区| 欧美在线一区二区三区四| 国产精品久久久久久久av电影| 中文欧美在线视频| 欧美午夜宅男影院在线观看| 亚洲乱码国产乱码精品精| 欧美精品一本久久男人的天堂| 日本精品在线视频| 国产视频999| 国产精品一区二区三区在线播放| 精品无人区乱码1区2区3区在线| 欧美在线国产精品| 中文在线资源观看视频网站免费不卡| 日韩欧美一区二区三区久久| 成人做爽爽免费视频| 亚洲精品国精品久久99热一| 欧美精品在线视频观看| 尤物九九久久国产精品的分类| 日本久久久久亚洲中字幕| 欧美日韩激情小视频| 黄色精品一区二区| 91在线观看免费| 精品国偷自产在线| 成人中文字幕在线观看| 夜色77av精品影院| 国产成人欧美在线观看| 国产精品99久久久久久白浆小说| 国产伊人精品在线| 韩国美女主播一区| 成人做爽爽免费视频| 日韩中文视频免费在线观看| 亚洲午夜精品久久久久久性色| 欧美在线观看网站| 青草青草久热精品视频在线网站| 欧美久久精品午夜青青大伊人| 一个人看的www欧美| 久久久久久高潮国产精品视| 久久伊人免费视频| 久久免费成人精品视频| 久久久国产一区| 国产免费亚洲高清| 欧美野外wwwxxx| 91色精品视频在线| 久久99热精品这里久久精品| 久久人人爽人人爽人人片av高清| 国产在线拍揄自揄视频不卡99| 欧美另类极品videosbest最新版本| 国产精品成人一区二区三区吃奶| 欧美亚洲日本网站|