日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

C#操作SQLite数据库增、删、改、查 实例

發布時間:2023/12/18 47 豆豆
生活随笔 收集整理的這篇文章主要介紹了 C#操作SQLite数据库增、删、改、查 实例 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

最近項目上要使用SQLite數據庫,不怕大伙笑話畢業四年多了,一直使用Oracle或者MySQL或者SQLServer,但是真的是沒有用過SQLite數據庫,據說非常輕量級,但是真沒有用過,于是網上大概搜索下,例子比較多,但是么有一個完整的,即使有,也五花八門。。看的人頭暈,可能對于他們大神來講這都太簡單了,算求了更新一篇,新來的小伙伴請看下文,大神你就直接飄過吧!

本例子運行效果

正式開始吧

1.SQLite的下載安裝

自然官網下載對應版本即可,我這里下載的是??Precompiled Binaries for 32-bit Windows (.NET Framework 4.0)? 不愿意下載的 可以直接使用我下載過的??點擊這里下載

2.減壓找出我們所需要的庫文件? ?這里我們只需要倆個文件下圖所示

3.下載一個數據庫管理系統來創建數據庫?

我是用的是SQLiteStudio3.1.1版本? 自己下載吧? 下載地址:https://sqlitestudio.pl/index.rvt?act=download

4.創建數據庫以及表

這里創建一個簡單的表?UserInfo? 完了代碼中會有這個數據庫 在Debug\bin目錄下

SQLite數據庫文件就一個后綴為.db的文件,就沒了。。

通過SQLiteStudio打開該數據庫

5.開始使用大伙所熟悉的VS了創建相關類

userinfo的Mode類

1 /// <summary>2 /// UserInfo:實體類(屬性說明自動提取數據庫字段的描述信息)3 /// </summary>4 [Serializable]5 public partial class UserInfo6 {7 public UserInfo()8 { }9 #region Model 10 private int _id; 11 private string _username; 12 private string _pwd; 13 private int? _age; 14 /// <summary> 15 /// 16 /// </summary> 17 public int ID 18 { 19 set { _id = value; } 20 get { return _id; } 21 } 22 /// <summary> 23 /// 24 /// </summary> 25 public string UserName 26 { 27 set { _username = value; } 28 get { return _username; } 29 } 30 /// <summary> 31 /// 32 /// </summary> 33 public string Pwd 34 { 35 set { _pwd = value; } 36 get { return _pwd; } 37 } 38 /// <summary> 39 /// 40 /// </summary> 41 public int? Age 42 { 43 set { _age = value; } 44 get { return _age; } 45 } 46 #endregion Model 47 48 }

UserInfo 的Dal類

1 /// <summary>2 /// 數據訪問類:UserInfo3 /// </summary>4 public partial class UserInfo5 {6 public UserInfo()7 { }8 #region BasicMethod9 10 /// <summary>11 /// 得到最大ID12 /// </summary>13 public int GetMaxId()14 {15 return DbHelperSQLite.GetMaxID("ID", "UserInfo");16 }17 18 /// <summary>19 /// 是否存在該記錄20 /// </summary>21 public bool Exists(int ID)22 {23 StringBuilder strSql = new StringBuilder();24 strSql.Append("select count(1) from UserInfo");25 strSql.Append(" where ID=@ID ");26 SQLiteParameter[] parameters = {27 new SQLiteParameter("@ID", DbType.Int32,8) };28 parameters[0].Value = ID;29 30 return DbHelperSQLite.Exists(strSql.ToString(), parameters);31 }32 33 34 /// <summary>35 /// 增加一條數據36 /// </summary>37 public bool Add(Model.UserInfo model)38 {39 StringBuilder strSql = new StringBuilder();40 strSql.Append("insert into UserInfo(");41 strSql.Append("UserName,Pwd,Age)");42 strSql.Append(" values (");43 strSql.Append("@UserName,@Pwd,@Age)");44 SQLiteParameter[] parameters = {45 new SQLiteParameter("@UserName", DbType.String,50),46 new SQLiteParameter("@Pwd", DbType.String,25),47 new SQLiteParameter("@Age", DbType.Int32,8)};48 parameters[0].Value = model.UserName;49 parameters[1].Value = model.Pwd;50 parameters[2].Value = model.Age;51 52 int rows = DbHelperSQLite.ExecuteSql(strSql.ToString(), parameters);53 if (rows > 0)54 {55 return true;56 }57 else58 {59 return false;60 }61 }62 /// <summary>63 /// 更新一條數據64 /// </summary>65 public bool Update(Model.UserInfo model)66 {67 StringBuilder strSql = new StringBuilder();68 strSql.Append("update UserInfo set ");69 strSql.Append("UserName=@UserName,");70 strSql.Append("Pwd=@Pwd,");71 strSql.Append("Age=@Age");72 strSql.Append(" where ID=@ID ");73 SQLiteParameter[] parameters = {74 new SQLiteParameter("@UserName", DbType.String,50),75 new SQLiteParameter("@Pwd", DbType.String,25),76 new SQLiteParameter("@Age", DbType.Int32,8),77 new SQLiteParameter("@ID", DbType.Int32,8)};78 parameters[0].Value = model.UserName;79 parameters[1].Value = model.Pwd;80 parameters[2].Value = model.Age;81 parameters[3].Value = model.ID;82 83 int rows = DbHelperSQLite.ExecuteSql(strSql.ToString(), parameters);84 if (rows > 0)85 {86 return true;87 }88 else89 {90 return false;91 }92 }93 94 /// <summary>95 /// 刪除一條數據96 /// </summary>97 public bool Delete(int ID)98 {99 100 StringBuilder strSql = new StringBuilder(); 101 strSql.Append("delete from UserInfo "); 102 strSql.Append(" where ID=@ID "); 103 SQLiteParameter[] parameters = { 104 new SQLiteParameter("@ID", DbType.Int32,8) }; 105 parameters[0].Value = ID; 106 107 int rows = DbHelperSQLite.ExecuteSql(strSql.ToString(), parameters); 108 if (rows > 0) 109 { 110 return true; 111 } 112 else 113 { 114 return false; 115 } 116 } 117 /// <summary> 118 /// 批量刪除數據 119 /// </summary> 120 public bool DeleteList(string IDlist) 121 { 122 StringBuilder strSql = new StringBuilder(); 123 strSql.Append("delete from UserInfo "); 124 strSql.Append(" where ID in (" + IDlist + ") "); 125 int rows = DbHelperSQLite.ExecuteSql(strSql.ToString()); 126 if (rows > 0) 127 { 128 return true; 129 } 130 else 131 { 132 return false; 133 } 134 } 135 136 137 /// <summary> 138 /// 得到一個對象實體 139 /// </summary> 140 public Model.UserInfo GetModel(int ID) 141 { 142 143 StringBuilder strSql = new StringBuilder(); 144 strSql.Append("select ID,UserName,Pwd,Age from UserInfo "); 145 strSql.Append(" where ID=@ID "); 146 SQLiteParameter[] parameters = { 147 new SQLiteParameter("@ID", DbType.Int32,8) }; 148 parameters[0].Value = ID; 149 150 Model.UserInfo model = new Model.UserInfo(); 151 DataSet ds = DbHelperSQLite.Query(strSql.ToString(), parameters); 152 if (ds.Tables[0].Rows.Count > 0) 153 { 154 return DataRowToModel(ds.Tables[0].Rows[0]); 155 } 156 else 157 { 158 return null; 159 } 160 } 161 162 163 /// <summary> 164 /// 得到一個對象實體 165 /// </summary> 166 public Model.UserInfo DataRowToModel(DataRow row) 167 { 168 Model.UserInfo model = new Model.UserInfo(); 169 if (row != null) 170 { 171 if (row["ID"] != null && row["ID"].ToString() != "") 172 { 173 model.ID = int.Parse(row["ID"].ToString()); 174 } 175 if (row["UserName"] != null) 176 { 177 model.UserName = row["UserName"].ToString(); 178 } 179 if (row["Pwd"] != null) 180 { 181 model.Pwd = row["Pwd"].ToString(); 182 } 183 if (row["Age"] != null && row["Age"].ToString() != "") 184 { 185 model.Age = int.Parse(row["Age"].ToString()); 186 } 187 } 188 return model; 189 } 190 191 /// <summary> 192 /// 獲得數據列表 193 /// </summary> 194 public DataSet GetList(string strWhere) 195 { 196 StringBuilder strSql = new StringBuilder(); 197 strSql.Append("select ID,UserName,Pwd,Age "); 198 strSql.Append(" FROM UserInfo "); 199 if (strWhere.Trim() != "") 200 { 201 strSql.Append(" where " + strWhere); 202 } 203 return DbHelperSQLite.Query(strSql.ToString()); 204 } 205 206 /// <summary> 207 /// 獲取記錄總數 208 /// </summary> 209 public int GetRecordCount(string strWhere) 210 { 211 StringBuilder strSql = new StringBuilder(); 212 strSql.Append("select count(1) FROM UserInfo "); 213 if (strWhere.Trim() != "") 214 { 215 strSql.Append(" where " + strWhere); 216 } 217 object obj = DbHelperSQLite.GetSingle(strSql.ToString()); 218 if (obj == null) 219 { 220 return 0; 221 } 222 else 223 { 224 return Convert.ToInt32(obj); 225 } 226 } 227 /// <summary> 228 /// 分頁獲取數據列表 229 /// </summary> 230 public DataSet GetListByPage(string strWhere, string orderby, int startIndex, int endIndex) 231 { 232 StringBuilder strSql = new StringBuilder(); 233 strSql.Append("SELECT * FROM ( "); 234 strSql.Append(" SELECT ROW_NUMBER() OVER ("); 235 if (!string.IsNullOrEmpty(orderby.Trim())) 236 { 237 strSql.Append("order by T." + orderby); 238 } 239 else 240 { 241 strSql.Append("order by T.ID desc"); 242 } 243 strSql.Append(")AS Row, T.* from UserInfo T "); 244 if (!string.IsNullOrEmpty(strWhere.Trim())) 245 { 246 strSql.Append(" WHERE " + strWhere); 247 } 248 strSql.Append(" ) TT"); 249 strSql.AppendFormat(" WHERE TT.Row between {0} and {1}", startIndex, endIndex); 250 return DbHelperSQLite.Query(strSql.ToString()); 251 } 252 253 #endregion BasicMethod 254 }

Userinfo的BLL類

1 public partial class UserInfo2 {3 private readonly DAL.UserInfo dal = new DAL.UserInfo();4 public UserInfo()5 { }6 #region BasicMethod7 8 /// <summary>9 /// 得到最大ID10 /// </summary>11 public int GetMaxId()12 {13 return dal.GetMaxId();14 }15 16 /// <summary>17 /// 是否存在該記錄18 /// </summary>19 public bool Exists(int ID)20 {21 return dal.Exists(ID);22 }23 24 /// <summary>25 /// 增加一條數據26 /// </summary>27 public bool Add(Model.UserInfo model)28 {29 return dal.Add(model);30 }31 32 /// <summary>33 /// 更新一條數據34 /// </summary>35 public bool Update(Model.UserInfo model)36 {37 return dal.Update(model);38 }39 40 /// <summary>41 /// 刪除一條數據42 /// </summary>43 public bool Delete(int ID)44 {45 46 return dal.Delete(ID);47 }48 /// <summary>49 /// 刪除一條數據50 /// </summary>51 public bool DeleteList(string IDlist)52 {53 return dal.DeleteList(IDlist);54 }55 56 /// <summary>57 /// 得到一個對象實體58 /// </summary>59 public Model.UserInfo GetModel(int ID)60 {61 62 return dal.GetModel(ID);63 }64 65 / <summary>66 / 得到一個對象實體,從緩存中67 / </summary>68 //public Model.UserInfo GetModelByCache(int ID)69 //{70 71 // string CacheKey = "UserInfoModel-" + ID;72 // object objModel = Common.DataCache.GetCache(CacheKey);73 // if (objModel == null)74 // {75 // try76 // {77 // objModel = dal.GetModel(ID);78 // if (objModel != null)79 // {80 // int ModelCache = Maticsoft.Common.ConfigHelper.GetConfigInt("ModelCache");81 // Maticsoft.Common.DataCache.SetCache(CacheKey, objModel, DateTime.Now.AddMinutes(ModelCache), TimeSpan.Zero);82 // }83 // }84 // catch { }85 // }86 // return (Maticsoft.Model.UserInfo)objModel;87 //}88 89 /// <summary>90 /// 獲得數據列表91 /// </summary>92 public DataSet GetList(string strWhere)93 {94 return dal.GetList(strWhere);95 }96 /// <summary>97 /// 獲得數據列表98 /// </summary>99 public List<Model.UserInfo> GetModelList(string strWhere) 100 { 101 DataSet ds = dal.GetList(strWhere); 102 return DataTableToList(ds.Tables[0]); 103 } 104 /// <summary> 105 /// 獲得數據列表 106 /// </summary> 107 public List<Model.UserInfo> DataTableToList(DataTable dt) 108 { 109 List<Model.UserInfo> modelList = new List<Model.UserInfo>(); 110 int rowsCount = dt.Rows.Count; 111 if (rowsCount > 0) 112 { 113 Model.UserInfo model; 114 for (int n = 0; n < rowsCount; n++) 115 { 116 model = dal.DataRowToModel(dt.Rows[n]); 117 if (model != null) 118 { 119 modelList.Add(model); 120 } 121 } 122 } 123 return modelList; 124 } 125 126 /// <summary> 127 /// 獲得數據列表 128 /// </summary> 129 public DataSet GetAllList() 130 { 131 return GetList(""); 132 } 133 134 /// <summary> 135 /// 分頁獲取數據列表 136 /// </summary> 137 public int GetRecordCount(string strWhere) 138 { 139 return dal.GetRecordCount(strWhere); 140 } 141 /// <summary> 142 /// 分頁獲取數據列表 143 /// </summary> 144 public DataSet GetListByPage(string strWhere, string orderby, int startIndex, int endIndex) 145 { 146 return dal.GetListByPage(strWhere, orderby, startIndex, endIndex); 147 } 148 /// <summary> 149 /// 分頁獲取數據列表 150 /// </summary> 151 //public DataSet GetList(int PageSize,int PageIndex,string strWhere) 152 //{ 153 //return dal.GetList(PageSize,PageIndex,strWhere); 154 //} 155 156 #endregion BasicMethod 157 #region ExtensionMethod 158 159 #endregion ExtensionMethod 160 }

創建SQLite幫助類

1 /// <summary>2 /// 數據訪問基礎類(基于SQLite)3 /// 可以用戶可以修改滿足自己項目的需要。4 /// </summary>5 public abstract class DbHelperSQLite6 {7 //數據庫連接字符串(web.config來配置),可以動態更改connectionString支持多數據庫. 8 public static string connectionString = CreateConnectionString();9 public DbHelperSQLite()10 {11 }12 private static string CreateConnectionString()13 {14 15 string dbName = ConfigurationManager.AppSettings["SQLiteDB"];16 string sqlLitePath = "data source=" + System.Environment.CurrentDirectory+"\\"+dbName + ";version=3;";17 return sqlLitePath;18 }19 20 #region 公用方法21 22 public static int GetMaxID(string FieldName, string TableName)23 {24 string strsql = "select max(" + FieldName + ")+1 from " + TableName;25 object obj = GetSingle(strsql);26 if (obj == null)27 {28 return 1;29 }30 else31 {32 return int.Parse(obj.ToString());33 }34 }35 public static bool Exists(string strSql)36 {37 object obj = GetSingle(strSql);38 int cmdresult;39 if ((Object.Equals(obj, null)) || (Object.Equals(obj, System.DBNull.Value)))40 {41 cmdresult = 0;42 }43 else44 {45 cmdresult = int.Parse(obj.ToString());46 }47 if (cmdresult == 0)48 {49 return false;50 }51 else52 {53 return true;54 }55 }56 public static bool Exists(string strSql, params SQLiteParameter[] cmdParms)57 {58 object obj = GetSingle(strSql, cmdParms);59 int cmdresult;60 if ((Object.Equals(obj, null)) || (Object.Equals(obj, System.DBNull.Value)))61 {62 cmdresult = 0;63 }64 else65 {66 cmdresult = int.Parse(obj.ToString());67 }68 if (cmdresult == 0)69 {70 return false;71 }72 else73 {74 return true;75 }76 }77 78 #endregion79 80 #region 執行簡單SQL語句81 82 /// <summary>83 /// 執行SQL語句,返回影響的記錄數84 /// </summary>85 /// <param name="SQLString">SQL語句</param>86 /// <returns>影響的記錄數</returns>87 public static int ExecuteSql(string SQLString)88 {89 using (SQLiteConnection connection = new SQLiteConnection(connectionString))90 {91 using (SQLiteCommand cmd = new SQLiteCommand(SQLString, connection))92 {93 try94 {95 connection.Open();96 int rows = cmd.ExecuteNonQuery();97 return rows;98 }99 catch (System.Data.SQLite.SQLiteException E) 100 { 101 connection.Close(); 102 throw new Exception(E.Message); 103 } 104 } 105 } 106 } 107 108 /// <summary> 109 /// 執行多條SQL語句,實現數據庫事務。 110 /// </summary> 111 /// <param name="SQLStringList">多條SQL語句</param> 112 public static void ExecuteSqlTran(ArrayList SQLStringList) 113 { 114 using (SQLiteConnection conn = new SQLiteConnection(connectionString)) 115 { 116 conn.Open(); 117 SQLiteCommand cmd = new SQLiteCommand(); 118 cmd.Connection = conn; 119 SQLiteTransaction tx = conn.BeginTransaction(); 120 cmd.Transaction = tx; 121 try 122 { 123 for (int n = 0; n < SQLStringList.Count; n++) 124 { 125 string strsql = SQLStringList[n].ToString(); 126 if (strsql.Trim().Length > 1) 127 { 128 cmd.CommandText = strsql; 129 cmd.ExecuteNonQuery(); 130 } 131 } 132 tx.Commit(); 133 } 134 catch (System.Data.SQLite.SQLiteException E) 135 { 136 tx.Rollback(); 137 throw new Exception(E.Message); 138 } 139 } 140 } 141 /// <summary> 142 /// 執行帶一個存儲過程參數的的SQL語句。 143 /// </summary> 144 /// <param name="SQLString">SQL語句</param> 145 /// <param name="content">參數內容,比如一個字段是格式復雜的文章,有特殊符號,可以通過這個方式添加</param> 146 /// <returns>影響的記錄數</returns> 147 public static int ExecuteSql(string SQLString, string content) 148 { 149 using (SQLiteConnection connection = new SQLiteConnection(connectionString)) 150 { 151 SQLiteCommand cmd = new SQLiteCommand(SQLString, connection); 152 SQLiteParameter myParameter = new SQLiteParameter("@content", DbType.String); 153 myParameter.Value = content; 154 cmd.Parameters.Add(myParameter); 155 try 156 { 157 connection.Open(); 158 int rows = cmd.ExecuteNonQuery(); 159 return rows; 160 } 161 catch (System.Data.SQLite.SQLiteException E) 162 { 163 throw new Exception(E.Message); 164 } 165 finally 166 { 167 cmd.Dispose(); 168 connection.Close(); 169 } 170 } 171 } 172 /// <summary> 173 /// 向數據庫里插入圖像格式的字段(和上面情況類似的另一種實例) 174 /// </summary> 175 /// <param name="strSQL">SQL語句</param> 176 /// <param name="fs">圖像字節,數據庫的字段類型為image的情況</param> 177 /// <returns>影響的記錄數</returns> 178 public static int ExecuteSqlInsertImg(string strSQL, byte[] fs) 179 { 180 using (SQLiteConnection connection = new SQLiteConnection(connectionString)) 181 { 182 SQLiteCommand cmd = new SQLiteCommand(strSQL, connection); 183 SQLiteParameter myParameter = new SQLiteParameter("@fs", DbType.Binary); 184 myParameter.Value = fs; 185 cmd.Parameters.Add(myParameter); 186 try 187 { 188 connection.Open(); 189 int rows = cmd.ExecuteNonQuery(); 190 return rows; 191 } 192 catch (System.Data.SQLite.SQLiteException E) 193 { 194 throw new Exception(E.Message); 195 } 196 finally 197 { 198 cmd.Dispose(); 199 connection.Close(); 200 } 201 } 202 } 203 204 /// <summary> 205 /// 執行一條計算查詢結果語句,返回查詢結果(object)。 206 /// </summary> 207 /// <param name="SQLString">計算查詢結果語句</param> 208 /// <returns>查詢結果(object)</returns> 209 public static object GetSingle(string SQLString) 210 { 211 using (SQLiteConnection connection = new SQLiteConnection(connectionString)) 212 { 213 using (SQLiteCommand cmd = new SQLiteCommand(SQLString, connection)) 214 { 215 try 216 { 217 connection.Open(); 218 object obj = cmd.ExecuteScalar(); 219 if ((Object.Equals(obj, null)) || (Object.Equals(obj, System.DBNull.Value))) 220 { 221 return null; 222 } 223 else 224 { 225 return obj; 226 } 227 } 228 catch (System.Data.SQLite.SQLiteException e) 229 { 230 connection.Close(); 231 throw new Exception(e.Message); 232 } 233 } 234 } 235 } 236 /// <summary> 237 /// 執行查詢語句,返回SQLiteDataReader 238 /// </summary> 239 /// <param name="strSQL">查詢語句</param> 240 /// <returns>SQLiteDataReader</returns> 241 public static SQLiteDataReader ExecuteReader(string strSQL) 242 { 243 SQLiteConnection connection = new SQLiteConnection(connectionString); 244 SQLiteCommand cmd = new SQLiteCommand(strSQL, connection); 245 try 246 { 247 connection.Open(); 248 SQLiteDataReader myReader = cmd.ExecuteReader(); 249 return myReader; 250 } 251 catch (System.Data.SQLite.SQLiteException e) 252 { 253 throw new Exception(e.Message); 254 } 255 256 } 257 /// <summary> 258 /// 執行查詢語句,返回DataSet 259 /// </summary> 260 /// <param name="SQLString">查詢語句</param> 261 /// <returns>DataSet</returns> 262 public static DataSet Query(string SQLString) 263 { 264 using (SQLiteConnection connection = new SQLiteConnection(connectionString)) 265 { 266 DataSet ds = new DataSet(); 267 try 268 { 269 connection.Open(); 270 SQLiteDataAdapter command = new SQLiteDataAdapter(SQLString, connection); 271 command.Fill(ds, "ds"); 272 } 273 catch (System.Data.SQLite.SQLiteException ex) 274 { 275 throw new Exception(ex.Message); 276 } 277 return ds; 278 } 279 } 280 281 282 #endregion 283 284 #region 執行帶參數的SQL語句 285 286 /// <summary> 287 /// 執行SQL語句,返回影響的記錄數 288 /// </summary> 289 /// <param name="SQLString">SQL語句</param> 290 /// <returns>影響的記錄數</returns> 291 public static int ExecuteSql(string SQLString, params SQLiteParameter[] cmdParms) 292 { 293 using (SQLiteConnection connection = new SQLiteConnection(connectionString)) 294 { 295 using (SQLiteCommand cmd = new SQLiteCommand()) 296 { 297 try 298 { 299 PrepareCommand(cmd, connection, null, SQLString, cmdParms); 300 int rows = cmd.ExecuteNonQuery(); 301 cmd.Parameters.Clear(); 302 return rows; 303 } 304 catch (System.Data.SQLite.SQLiteException E) 305 { 306 throw new Exception(E.Message); 307 } 308 } 309 } 310 } 311 312 313 /// <summary> 314 /// 執行多條SQL語句,實現數據庫事務。 315 /// </summary> 316 /// <param name="SQLStringList">SQL語句的哈希表(key為sql語句,value是該語句的SQLiteParameter[])</param> 317 public static void ExecuteSqlTran(Hashtable SQLStringList) 318 { 319 using (SQLiteConnection conn = new SQLiteConnection(connectionString)) 320 { 321 conn.Open(); 322 using (SQLiteTransaction trans = conn.BeginTransaction()) 323 { 324 SQLiteCommand cmd = new SQLiteCommand(); 325 try 326 { 327 //循環 328 foreach (DictionaryEntry myDE in SQLStringList) 329 { 330 string cmdText = myDE.Key.ToString(); 331 SQLiteParameter[] cmdParms = (SQLiteParameter[])myDE.Value; 332 PrepareCommand(cmd, conn, trans, cmdText, cmdParms); 333 int val = cmd.ExecuteNonQuery(); 334 cmd.Parameters.Clear(); 335 336 trans.Commit(); 337 } 338 } 339 catch 340 { 341 trans.Rollback(); 342 throw; 343 } 344 } 345 } 346 } 347 348 349 /// <summary> 350 /// 執行一條計算查詢結果語句,返回查詢結果(object)。 351 /// </summary> 352 /// <param name="SQLString">計算查詢結果語句</param> 353 /// <returns>查詢結果(object)</returns> 354 public static object GetSingle(string SQLString, params SQLiteParameter[] cmdParms) 355 { 356 using (SQLiteConnection connection = new SQLiteConnection(connectionString)) 357 { 358 using (SQLiteCommand cmd = new SQLiteCommand()) 359 { 360 try 361 { 362 PrepareCommand(cmd, connection, null, SQLString, cmdParms); 363 object obj = cmd.ExecuteScalar(); 364 cmd.Parameters.Clear(); 365 if ((Object.Equals(obj, null)) || (Object.Equals(obj, System.DBNull.Value))) 366 { 367 return null; 368 } 369 else 370 { 371 return obj; 372 } 373 } 374 catch (System.Data.SQLite.SQLiteException e) 375 { 376 throw new Exception(e.Message); 377 } 378 } 379 } 380 } 381 382 /// <summary> 383 /// 執行查詢語句,返回SQLiteDataReader 384 /// </summary> 385 /// <param name="strSQL">查詢語句</param> 386 /// <returns>SQLiteDataReader</returns> 387 public static SQLiteDataReader ExecuteReader(string SQLString, params SQLiteParameter[] cmdParms) 388 { 389 SQLiteConnection connection = new SQLiteConnection(connectionString); 390 SQLiteCommand cmd = new SQLiteCommand(); 391 try 392 { 393 PrepareCommand(cmd, connection, null, SQLString, cmdParms); 394 SQLiteDataReader myReader = cmd.ExecuteReader(); 395 cmd.Parameters.Clear(); 396 return myReader; 397 } 398 catch (System.Data.SQLite.SQLiteException e) 399 { 400 throw new Exception(e.Message); 401 } 402 403 } 404 405 /// <summary> 406 /// 執行查詢語句,返回DataSet 407 /// </summary> 408 /// <param name="SQLString">查詢語句</param> 409 /// <returns>DataSet</returns> 410 public static DataSet Query(string SQLString, params SQLiteParameter[] cmdParms) 411 { 412 using (SQLiteConnection connection = new SQLiteConnection(connectionString)) 413 { 414 SQLiteCommand cmd = new SQLiteCommand(); 415 PrepareCommand(cmd, connection, null, SQLString, cmdParms); 416 using (SQLiteDataAdapter da = new SQLiteDataAdapter(cmd)) 417 { 418 DataSet ds = new DataSet(); 419 try 420 { 421 da.Fill(ds, "ds"); 422 cmd.Parameters.Clear(); 423 } 424 catch (System.Data.SQLite.SQLiteException ex) 425 { 426 throw new Exception(ex.Message); 427 } 428 return ds; 429 } 430 } 431 } 432 433 434 private static void PrepareCommand(SQLiteCommand cmd, SQLiteConnection conn, SQLiteTransaction trans, string cmdText, SQLiteParameter[] cmdParms) 435 { 436 if (conn.State != ConnectionState.Open) 437 conn.Open(); 438 cmd.Connection = conn; 439 cmd.CommandText = cmdText; 440 if (trans != null) 441 cmd.Transaction = trans; 442 cmd.CommandType = CommandType.Text;//cmdType; 443 if (cmdParms != null) 444 { 445 foreach (SQLiteParameter parm in cmdParms) 446 cmd.Parameters.Add(parm); 447 } 448 } 449 450 #endregion 451 452 453 454 }

6.創建一個WinForm窗體用于測試

大概是這樣的,我用的是VS2017

數據庫配置文件新增App.config文件? 其余的沒有用,是Mysql的連接字符串,可以不用管。。。

窗體代碼大概是這樣的比較簡單,只是實現簡單的操作,具體細節那就交個大家了。。。

1 public partial class Form1 : Form2 {3 public Form1()4 {5 InitializeComponent();6 }7 8 9 BLL.UserInfo bll = new BLL.UserInfo(); 10 11 12 //數據庫連接 13 SQLiteConnection m_dbConnection; 14 private void button1_Click(object sender, EventArgs e) 15 { 16 17 DataSet ds = bll.GetAllList(); 18 19 this.dataGridView1.DataSource = ds.Tables[0]; 20 21 } 22 23 int count = 0; 24 private void button2_Click(object sender, EventArgs e) 25 { 26 count++; 27 Model.UserInfo userInfo = new Model.UserInfo(); 28 userInfo.UserName = "Count" + count; 29 userInfo.Pwd = "123456"; 30 userInfo.Age = count; 31 32 bll.Add(userInfo); 33 34 DataSet ds = bll.GetAllList(); 35 this.dataGridView1.DataSource = ds.Tables[0]; 36 37 } 38 39 private void button3_Click(object sender, EventArgs e) 40 { 41 42 Model.UserInfo userInfo = new Model.UserInfo(); 43 userInfo.ID = int.Parse(this.label1.Text); 44 userInfo.UserName = this.textBox1.Text; 45 userInfo.Pwd = this.textBox2.Text; 46 userInfo.Age = int.Parse(this.textBox3.Text); 47 bll.Update(userInfo); 48 49 50 DataSet ds = bll.GetAllList(); 51 this.dataGridView1.DataSource = ds.Tables[0]; 52 53 54 } 55 56 private void dataGridView1_MouseClick(object sender, MouseEventArgs e) 57 { 58 DataGridViewRow row = this.dataGridView1.CurrentRow; 59 this.label1.Text = row.Cells[0].Value.ToString(); 60 this.textBox1.Text = row.Cells[1].Value.ToString(); 61 this.textBox2.Text = row.Cells[2].Value.ToString(); 62 this.textBox3.Text = row.Cells[3].Value.ToString(); 63 64 65 } 66 67 private void button4_Click(object sender, EventArgs e) 68 { 69 bll.Delete(int.Parse(this.label1.Text)); 70 71 72 DataSet ds = bll.GetAllList(); 73 this.dataGridView1.DataSource = ds.Tables[0]; 74 } 75 76 private void linkLabel1_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e) 77 { 78 79 Process.Start("IExplore", "https://www.cnblogs.com/JiYF/"); 80 } 81 }

7.運行效果

8.項目結構文件

?

SQLite版本問題,如果你使用的32位,記得項目編譯采用X86? ?如果你是64位則采用X64? 否則會提示錯誤信息

總結

以上是生活随笔為你收集整理的C#操作SQLite数据库增、删、改、查 实例的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

久久夜色精品国产亚洲aⅴ 91chinesexxx | 五月花婷婷 | 国产黄色免费在线观看 | 色婷婷狠狠五月综合天色拍 | 在线日韩精品视频 | 久久久99精品免费观看乱色 | 高清免费av在线 | 黄色网址在线播放 | 国产日产欧美在线观看 | av亚洲产国偷v产偷v自拍小说 | 中文字幕免费 | 亚洲精品高清在线观看 | 在线日韩中文 | 在线v片免费观看视频 | 在线观看免费日韩 | 麻豆传媒视频在线 | 午夜精品久久久久久久99无限制 | 日韩在线不卡av | 99久久毛片 | 亚洲天天干 | 91视频在线免费看 | 天天干,天天插 | 亚洲视频1区2区 | 国产精品一区二区三区在线 | 五月天综合激情 | av久久在线 | 日韩视频专区 | 亚洲日日射 | 久久激情视频 久久 | 午夜精选视频 | 88av色 | 久久免费电影网 | 国产va饥渴难耐女保洁员在线观看 | 毛片网在线播放 | 亚洲精选在线 | 亚洲精品久久久蜜桃直播 | 伊人手机在线 | 国产精品视频一二三 | 久久夜色精品国产欧美乱 | 天天操天天操天天操天天操天天操天天操 | 成人一区不卡 | 狠色狠色综合久久 | 日韩在线观看av | 国产福利一区二区在线 | 久久精品亚洲国产 | 丁香狠狠| 国产精品久久久一区二区 | 欧美 亚洲 另类 激情 另类 | 亚洲一二区精品 | 国产亚洲精品久久久久动 | 伊人影院99 | 亚洲精品国产免费 | 国产精品中文在线 | 久久久久久久国产精品视频 | 国产一区二区久久久久 | 亚洲日本国产 | 欧美日韩高清在线 | 日本在线视频一区二区三区 | 在线观看完整版免费 | 亚洲精品乱码白浆高清久久久久久 | 美女在线国产 | 亚洲爱爱视频 | 91香蕉视频在线下载 | 91av电影在线 | 99热日本| 99久久影院 | 日韩欧美在线免费 | 欧美精品一区二区性色 | 久久综合欧美精品亚洲一区 | 欧美日韩视频网站 | 日本中文字幕高清 | 69久久99精品久久久久婷婷 | 综合久久网 | 久久一区国产 | 波多野结衣最新 | 免费高清在线视频一区· | 99日韩精品| 69精品视频在线观看 | 日韩免费电影在线观看 | 久久99久久99久久 | 久久国产区 | 天天爽天天爽夜夜爽 | 日本xxxx裸体xxxx17 | 一级黄色在线视频 | 91av电影网| 国产精品美女久久久 | 超碰成人免费电影 | 日韩免费电影网站 | 久久久久久久久久久网站 | 日本成人免费在线观看 | av播放在线| 最新中文字幕在线资源 | a天堂在线看| 蜜臀久久99精品久久久无需会员 | 最近更新好看的中文字幕 | 天天摸天天操天天舔 | 蜜臀av性久久久久蜜臀aⅴ流畅 | 涩涩网站在线播放 | 国产精品一区二区白浆 | 国产在线传媒 | 韩国在线一区二区 | 日韩精品在线视频免费观看 | 午夜婷婷在线播放 | 久久a级片 | 午夜黄色大片 | 超碰人人在线 | 久久男人中文字幕资源站 | 久久黄色影视 | av在线免费在线 | 激情欧美xxxx | 久久久久人人 | 亚洲欧洲一区二区在线观看 | 中文字幕第一 | 福利视频导航网址 | 国产精品毛片一区视频播 | 国产粉嫩在线 | 在线观看免费一级片 | 在线免费视频你懂的 | 免费a网站 | 狠狠狠狠狠狠狠狠 | 日韩午夜av | av高清在线| 国产色中涩 | 日本黄色大片儿 | 狠狠色噜噜狠狠 | 久一久久 | 成人免费看片网址 | 亚洲视频大全 | 亚州免费视频 | 国产精品久久久久久久av大片 | 欧美一级视频免费看 | 91精品欧美 | 香蕉久久久久久av成人 | 国产精品高清免费在线观看 | 黄色午夜 | 中文字幕激情 | 九九久久久久久久久激情 | 精品国精品自拍自在线 | 中文字幕在线观看免费 | 黄色影院在线免费观看 | 欧美激情精品 | 亚洲精品资源在线观看 | 日韩视频在线观看视频 | 久久视频99 | 国产视频97 | 97人人模人人爽人人少妇 | 久视频在线 | www.97色.com| 日韩在线三级 | 日本公妇色中文字幕 | 天操夜夜操 | 五月婷婷六月综合 | 五月天国产 | 国产精品入口麻豆www | 91桃色在线免费观看 | 国产资源网| 国产成人精品午夜在线播放 | 亚洲精品一区二区久 | 色999精品 | 欧美日韩一区二区视频在线观看 | 亚洲性少妇性猛交wwww乱大交 | 99精品视频在线观看 | 成人xxxx| 欧美a在线看 | 在线观看中文字幕视频 | 久久精品欧美一区 | 国产精品18久久久久久久久 | 久草久 | 中文字幕久久精品 | 337p日本欧洲亚洲大胆裸体艺术 | 天天干天天操天天做 | 日韩一级网站 | 亚洲,国产成人av | 亚洲人成在线观看 | 日韩免费观看视频 | 午夜精品久久久久久久久久久久 | 欧美韩国在线 | 久草爱视频 | 91香蕉视频好色先生 | 国产视频一区二区三区在线 | 精品久久久久久久久久久久久久久久久久 | 国产精品2018 | 欧美一级乱黄 | 综合精品久久 | 国产精品自在线 | 欧美精品一区二区在线播放 | 九九国产精品视频 | 色综合天天做天天爱 | 日韩天天操 | 碰碰影院 | 欧美成天堂网地址 | www.久久爱.cn | 夜夜骑天天操 | 99久久久国产精品免费99 | 久久久午夜影院 | 国产视频日韩视频欧美视频 | 超碰在线最新网址 | av女优中文字幕在线观看 | 国产成人精品久久二区二区 | 91av资源在线 | 国产精品国产三级在线专区 | 国产欧美日韩精品一区二区免费 | 国产手机视频精品 | 奇米四色影狠狠爱7777 | 欧美日韩高清一区二区 国产亚洲免费看 | 日韩v在线| 999久久久欧美日韩黑人 | 国产精品一区二区在线 | 久久久www成人免费毛片麻豆 | 就色干综合| 天天玩天天干天天操 | 中文日韩在线视频 | 国产在线视频一区二区三区 | 成人免费观看完整版电影 | 午夜免费在线观看 | 久久久久久高潮国产精品视 | 欧美精品亚州精品 | 国产一二区免费视频 | 久草91视频| 天天综合色 | 国产伦精品一区二区三区高清 | 欧美激情视频一区 | 久久国产三级 | 亚洲日本韩国一区二区 | 在线观看国产成人av片 | av免费成人 | 国产小视频福利在线 | 成年人在线免费看视频 | 亚洲欧美视频在线观看 | 亚洲免费精彩视频 | 天天天干夜夜夜操 | 久久有精品| 97**国产露脸精品国产 | 午夜精品视频免费在线观看 | 在线综合色 | 国产精品久久久久av | 国产精品久久久久久久久久新婚 | zzijzzij亚洲日本少妇熟睡 | 高清国产一区 | 免费高清在线视频一区· | 日日婷婷夜日日天干 | av在线一二三区 | 国产一二三区av | 国产精品刺激对白麻豆99 | 国产人成一区二区三区影院 | 中文字幕丝袜美腿 | 91色蜜桃 | 欧洲一区二区在线观看 | 日韩欧美一区二区三区在线观看 | 波多野结衣在线观看一区二区三区 | 午夜久久久久久久 | 国产精品一区二区在线看 | 久久y | 精品伦理一区二区三区 | 国产日产高清dvd碟片 | 2020天天干夜夜爽 | 男女免费av| 日日麻批40分钟视频免费观看 | 久草在线免费新视频 | 中文字幕免费高清av | 久久精品视频国产 | 久久国产女人 | 808电影免费观看三年 | 久久66热这里只有精品 | 精品一区 在线 | 中文资源在线官网 | 成人亚洲综合 | 人成午夜视频 | 探花视频在线版播放免费观看 | 国产精品成人免费一区久久羞羞 | 日韩在线观看精品 | 婷婷六月天综合 | 国产高清精| 国产精品美女久久久久久久 | 东方av免费在线观看 | 91视频午夜| 国产色资源 | 免费麻豆网站 | 狠狠做深爱婷婷综合一区 | 国产精品永久久久久久久久久 | 成人精品一区二区三区中文字幕 | 五月香视频在线观看 | 日韩在线电影观看 | 韩国精品福利一区二区三区 | 日韩高清免费在线 | 激情综合网婷婷 | 九九国产视频 | av黄色成人 | 国产精品久久在线 | 国产精品69久久久久 | 18+视频网站链接 | 免费久久视频 | 色噜噜色噜噜 | 欧美激情视频一区二区三区 | 国产不卡高清 | 99草视频| 91免费高清观看 | 在线v片免费观看视频 | 最近高清中文字幕 | 欧美日韩亚洲在线观看 | 国内精品久久久久久久久 | 婷婷色狠狠 | 97综合在线 | 久久夜色精品国产欧美一区麻豆 | 国产色区| 成人在线黄色 | 成人免费视频视频在线观看 免费 | 特级西西444www大精品视频免费看 | 在线亚洲观看 | 亚洲国产午夜视频 | 日韩精品久久久久 | 国产69久久| 免费高清在线观看成人 | 狠狠操操网 | 亚洲欧美成人网 | 99国产在线视频 | 91日本在线播放 | 波多野结衣一区二区 | 91免费高清观看 | 一区精品久久 | 免费不卡中文字幕视频 | 天天操天天弄 | 亚洲欧美日韩精品久久久 | 中文字幕国产一区二区 | 爱情影院aqdy鲁丝片二区 | 日日干美女 | 日韩videos高潮hd| 99国产一区二区三精品乱码 | 99精品视频免费观看视频 | 青青草国产成人99久久 | 免费又黄又爽视频 | 久久国产免费视频 | 国际精品久久久 | 香蕉视频最新网址 | 久久精品中文字幕免费mv | 日本久久久久久久久 | 国产一级二级视频 | 精品国产网址 | 亚洲欧美日韩在线一区二区 | 久久这里只有精品视频99 | 一区二区高清在线 | 国产成人三级三级三级97 | 欧美精品成人在线 | 九色精品免费永久在线 | 2023天天干 | 日韩av一区二区在线影视 | 国产精品久久综合 | 亚洲精品毛片一级91精品 | 亚洲电影毛片 | 天天鲁一鲁摸一摸爽一爽 | 狠狠躁日日躁 | 日韩欧美高清视频在线观看 | 亚洲国产成人精品电影在线观看 | 国产 日韩 欧美 中文 在线播放 | 亚洲国产成人精品电影在线观看 | www.99av | 婷婷丁香激情综合 | 在线免费视频 你懂得 | 在线观看中文字幕视频 | 色a资源在线 | 伊人精品在线 | 亚洲国产精品视频在线观看 | 国产精品久久一区二区三区, | 少妇bbb | 日本黄色免费电影网站 | av免费看av| 狠狠躁日日躁夜夜躁av | 久久久电影 | 国产精品免费久久久久久 | 在线中文字幕一区二区 | 日韩欧美高清视频在线观看 | 日本中文一区二区 | 狠狠五月天 | 超碰97人人干 | 免费在线观看视频一区 | 欧美日韩啪啪 | 婷婷精品进入 | 久久综合久久久 | 日韩精品免费在线 | 亚洲一区动漫 | 99re8这里有精品热视频免费 | 欧美激情精品久久久久久变态 | 中文字幕精品一区久久久久 | 91av视频在线播放 | 中文字幕4 | 91大神精品视频在线观看 | 视频在线观看亚洲 | 美女露久久 | 色全色在线资源网 | 国产精品麻豆果冻传媒在线播放 | 久久精品久久综合 | 久久日韩精品 | 久久精品国产免费看久久精品 | 99国产视频 | 91在线中字 | 欧美日一级片 | 色综合欧洲 | 免费视频黄色 | 狠狠网站 | 黄免费网站 | 亚洲日本va午夜在线电影 | 91成人免费视频 | 色婷av| h网站免费在线观看 | 韩国视频一区二区三区 | 女人魂免费观看 | 久青草视频 | 激情婷婷久久 | 中文字幕av影院 | 99久久婷婷国产一区二区三区 | 国产又粗又猛又色 | 在线观看激情av | 国产不卡在线观看视频 | 91在线麻豆 | 久久精选视频 | 三级在线国产 | 久久av在线 | 亚洲码国产日韩欧美高潮在线播放 | 日韩精品一区二区久久 | 日韩在线影视 | 久久综合狠狠综合久久激情 | 国产91在线免费视频 | 国产在线播放一区二区三区 | 午夜精品一二三区 | 日韩av黄 | 国产98色在线 | 日韩 | 99国产情侣在线播放 | 国精产品满18岁在线 | 激情久久综合 | 久久综合干| 午夜精品一区二区国产 | 91九色porny在线 | 色婷婷av在线 | 色综合久久久久久久 | 五月开心婷婷 | 国产精品久久久久久久久软件 | 三级av在线免费观看 | 免费亚洲片 | 草樱av | 97色婷婷 | 久久国产高清视频 | 九色porny真实丨国产18 | 在线日本看片免费人成视久网 | 九九久久成人 | 国产免费高清视频 | av网站在线观看免费 | 91亚洲精品久久久中文字幕 | 91久久精品日日躁夜夜躁国产 | 成人免费视频播放 | 青青草在久久免费久久免费 | 在线国产一区二区 | 免费视频91 | 中文字幕在线播放视频 | 91成人黄色 | 99在线视频播放 | 成人在线播放免费观看 | 青青河边草免费 | www.伊人网| 超碰在线国产 | 亚洲粉嫩av | 国产精品va在线播放 | 国产精品精品久久久久久 | 亚洲美女免费精品视频在线观看 | 亚洲免费资源 | 亚洲v欧美v国产v在线观看 | 免费精品视频在线观看 | 蜜桃视频在线观看一区 | 国产在线视频一区二区 | 国产亚洲精品精品精品 | 韩国av一区二区三区在线观看 | 成人免费网站在线观看 | 久久久免费国产 | 深爱激情五月婷婷 | 色婷婷国产精品 | 精品国产99国产精品 | 尤物97国产精品久久精品国产 | 国产日本亚洲 | 丰满少妇一级 | 日韩欧美在线不卡 | 最新日韩视频 | 久久免费观看视频 | 777奇米四色 | 国产精品99久久久久人中文网介绍 | 国产精品成人a免费观看 | 免费在线播放视频 | 免费视频一区 | 亚洲免费激情 | 97色在线观看免费视频 | 亚洲国产精品va在线 | 色婷婷综合久色 | 久久艹国产视频 | av在线官网 | 久久欧美综合 | 日韩午夜在线观看 | 欧美日韩精品网站 | 四虎8848免费高清在线观看 | 日韩精品短视频 | 久久久久国产免费免费 | 免费v片 | 国产成人久久77777精品 | 亚洲一级黄色大片 | 国产成人在线网站 | 最近高清中文字幕 | 久草视频国产 | 亚洲视频999 | 国产拍揄自揄精品视频麻豆 | 精品一区中文字幕 | 国产精品av久久久久久无 | 午夜精品麻豆 | 国产精品久久久久久久久久久久午夜 | 96超碰在线 | 成人午夜在线电影 | 成人av网页| 日韩色区 | 黄色小视频在线观看免费 | 天天干.com | 国产一区在线视频播放 | 亚洲国产网站 | 精品国产精品国产偷麻豆 | 国产麻豆电影 | 中文字幕在线观看1 | 精品一区精品二区高清 | 国内丰满少妇猛烈精品播 | 国产91免费在线 | 九九热在线精品视频 | 日韩一级电影在线观看 | 精品久久久久国产免费第一页 | 久久99热精品 | 久久美女电影 | 欧美日韩视频一区二区三区 | 欧美日韩不卡一区 | 精品久久久久久亚洲综合网 | 九九热精品视频在线播放 | 超碰在97| 国产精品三级视频 | 在线免费日韩 | 一区二区三区电影大全 | 免费观看黄 | 99视频国产在线 | 久久久久久久久综合 | 麻豆传媒一区二区 | 97在线超碰 | 日韩网站在线 | 天天射天天干天天操 | 日本在线观看一区二区三区 | 91日本在线播放 | 91亚洲影院 | 国产特黄色片 | 亚洲dvd | 欧美专区日韩专区 | 五月天婷亚洲天综合网鲁鲁鲁 | 日日夜夜婷婷 | 麻豆视频在线免费看 | 日韩一级电影在线 | 亚州av一区 | 97在线看 | 狠狠色狠狠色综合日日小说 | 免费观看黄色av | 亚洲精品国产麻豆 | 香蕉色综合 | 日本在线成人 | 国产区免费在线 | 日本公妇在线观看 | 夜夜狠狠 | 日本中文字幕在线视频 | 久久久网址 | 一区二区三区在线免费观看视频 | 在线久久| 久久久久国产精品午夜一区 | 一区国产精品 | 国产精品麻豆视频 | 久久另类小说 | 麻豆免费在线播放 | 日韩高清国产精品 | 91久久久久久久一区二区 | 国产99黄| 国产精品美女久久久久久久久久久 | 字幕网资源站中文字幕 | 久久久久久久看片 | 婷婷亚洲综合五月天小说 | 色干干| 蜜桃麻豆www久久囤产精品 | 91人人爽久久涩噜噜噜 | www.久久免费视频 | 国产在线综合视频 | 国产在线看 | 成人午夜电影网站 | 久草免费手机视频 | 国产无套一区二区三区久久 | 激情视频二区 | av在线网站观看 | 色婷婷激情| 久草在线免费资源站 | 国产精品成人av久久 | 国内精品久久久久久久影视简单 | 丝袜美腿亚洲综合 | 日韩精选在线观看 | 久久综合狠狠综合久久综合88 | 亚洲资源在线观看 | 久久精品成人 | 亚洲三级在线 | 日韩一区二区三免费高清在线观看 | 国产黄色精品在线观看 | 日韩精品视频一二三 | 国产手机精品视频 | 国产精品一区二区美女视频免费看 | 成人动漫一区二区三区 | 99国产视频在线 | 在线播放一区 | 日本性xxx| 九九色视频 | 激情婷婷欧美 | 国偷自产视频一区二区久 | 欧美大片在线观看一区 | 国内精品久久天天躁人人爽 | 国产精品一区免费在线观看 | 日韩在线观看一区二区三区 | 久久不见久久见免费影院 | 成人欧美一区二区三区黑人麻豆 | 国产一区二区在线免费视频 | 久久久久久久久久久久久9999 | 国产二区视频在线 | 亚洲激情一区二区三区 | 99视频精品全部免费 在线 | 天天色天天综合 | 日韩电影在线观看中文字幕 | 亚洲最新毛片 | 中文字幕资源在线 | 天天躁日日躁狠狠 | 麻豆小视频在线观看 | 国产精品一区二区三区免费看 | 天天做天天射 | 欧美成人h版电影 | 在线观看色网站 | 99国产精品免费网站 | 999在线精品| 中文字幕在线久一本久 | 亚洲视频高清 | 在线观看成人一级片 | 天天色天天艹 | 日韩欧美高清在线 | 久久综合五月婷婷 | 亚洲视频免费在线观看 | 在线视频18在线视频4k | 亚洲国内精品 | 欧美日韩一区二区在线观看 | 久久精品屋 | 欧美日韩精品二区第二页 | 久久婷婷色 | 天天草综合网 | 99亚洲天堂 | 精品一二三四在线 | 午夜美女福利直播 | 亚洲麻豆精品 | 国产在线成人 | 五月天综合激情网 | 麻豆一区二区三区视频 | 亚洲精品午夜国产va久久成人 | 欧美在线视频二区 | 国产美女搞久久 | 日韩三级.com | 日韩精品欧美视频 | 日日综合网 | 国产在线 一区二区三区 | 日韩av成人在线 | 九九久久成人 | 在线看免费 | 97操操操| 国产精品久久久电影 | 99热在线国产精品 | 久草在线看片 | 激情婷婷亚洲 | 日韩网站在线免费观看 | 97天天综合网 | 日韩在线第一区 | 4p变态网欧美系列 | 免费高清在线观看成人 | 日韩高清国产精品 | 久久久一本精品99久久精品 | 国产日本亚洲 | 国产日韩中文在线 | 欧美日韩视频一区二区三区 | 色婷婷av国产精品 | 精品久久亚洲 | 黄色a三级| 黄网站app在线观看免费视频 | 亚洲第一香蕉视频 | 欧美激情综合色综合啪啪五月 | 国产二区免费视频 | av一区二区三区在线播放 | 精品9999 | 色综合天天狠狠 | 久久伦理影院 | 丰满少妇高潮在线观看 | 色视频网页 | 亚洲午夜久久久久久久久久久 | 三上悠亚在线免费 | 波多野结衣在线播放一区 | 日本三级吹潮在线 | 免费人做人爱www的视 | 天天做日日做天天爽视频免费 | 玖玖爱在线观看 | 成人久久亚洲 | 亚洲三级视频 | 日韩国产欧美在线播放 | 人人视频网站 | 一区二区三区视频网站 | 国产中文字幕视频在线观看 | 中文字幕在线观看2018 | 久久久久女教师免费一区 | 日韩美女黄色片 | 91天天操| 韩国av免费在线 | 麻豆视频免费观看 | 免费在线观看av电影 | 亚洲综合五月 | 九九九热精品免费视频观看网站 | 欧美精品久久久久久久久久 | 欧美中文字幕第一页 | www.在线看片.com | 国产字幕在线观看 | 欧美激情视频在线观看免费 | 久草视频在 | 狠狠网亚洲精品 | 成人免费在线播放 | 久久特级毛片 | 香蕉影院在线播放 | 亚洲乱亚洲乱亚洲 | 99精品视频一区二区 | 国产高清无av久久 | 日韩高清成人 | 亚洲精品久久久久久久蜜桃 | 欧美a免费 | 在线免费中文字幕 | 久久夜色精品国产欧美乱极品 | 中文字幕一区二区三区在线观看 | 91在线看 | 国产午夜剧场 | 西西www4444大胆视频 | 岛国一区在线 | 色91av| 欧美日韩精 | 五月婷av | 天天色综合1 | 国产精品成人久久久久 | 二区中文字幕 | 国产伦精品一区二区三区在线 | 国产精品久久久久久久久久久久 | 国产视频高清 | a黄色片在线观看 | 中文字幕网站视频在线 | 亚洲精品自在在线观看 | 久久99久久99久久 | 国产精品区免费视频 | 欧美尹人| 国产在线超碰 | 国产无限资源在线观看 | 日本黄色免费网站 | 国产情侣一区 | 免费一级片观看 | 黄色不卡av | 亚洲成人在线免费 | 久久国产系列 | 欧美成人黄色 | 国产高清视频在线免费观看 | 美女视频永久黄网站免费观看国产 | 欧美精品视 | 免费h漫在线观看 | 在线观看国产一区 | 日本 在线 视频 中文 有码 | 亚洲黄色免费 | 91麻豆精品国产91 | 九九影视理伦片 | 最近中文字幕免费大全 | 中文字幕之中文字幕 | av成人免费| 欧美日韩精品在线免费观看 | 一级久久精品 | 天天摸天天操天天爽 | 久久精品中文视频 | 狠狠色狠狠色综合日日92 | 日韩一区视频在线 | 免费国产一区二区 | 国产高清免费av | 成 人 黄 色 片 在线播放 | 成人小视频在线 | 欧美日韩中| av成人在线播放 | 丁香电影小说免费视频观看 | 亚洲激情中文 | 在线视频99 | 日日噜噜噜噜夜夜爽亚洲精品 | 91麻豆网| av丁香花 | 久久久久久久久电影 | 九九热在线精品 | 国产麻豆剧传媒免费观看 | 免费不卡中文字幕视频 | 91麻豆精品国产午夜天堂 | 97精品国产97久久久久久春色 | 午夜精品福利一区二区 | 欧美久久久久久久久中文字幕 | 久久精品资源 | 91精品一区二区三区蜜臀 | 在线日韩 | 午夜在线日韩 | 国产原创中文在线 | 国产视频资源在线观看 | 免费视频久久久久久久 | 日本久久久久 | 亚洲精品美女免费 | 免费看黄色大全 | 久久精品国产免费观看 | 在线视频一二三 | 午夜电影 电影 | 久久99国产精品二区护士 | 怡红院久久 | 安徽妇搡bbbb搡bbbb | 9992tv成人免费看片 | 亚洲欧美日韩一区二区三区在线观看 | 超碰免费97| 一区二区三区免费在线观看 | 在线观看完整版 | 岛国一区在线 | 少妇性色午夜淫片aaaze | 久久香蕉电影 | 不卡视频一区二区三区 | 精品亚洲欧美一区 | 国产精品久久久久久久久久尿 | 中文字幕在线看 | 日韩免费在线 | 国产精品久久久999 国产91九色视频 | 三级毛片视频 | 久久久亚洲国产精品麻豆综合天堂 | 成人一级视频在线观看 | 欧美精品久久久久久久久久丰满 | 91尤物国产尤物福利在线播放 | 91伊人久久大香线蕉蜜芽人口 | 久草新在线 | 99视频国产精品免费观看 | 黄色大片免费网站 | a黄色大片| 国产又粗又猛又黄视频 | 人人射人人爽 | 日韩中字在线观看 | 中文字幕视频播放 | 亚洲精品国偷自产在线91正片 | 在线观看香蕉视频 | 在线观看国产www | 91av免费在线观看 | 国产日韩精品在线 | 日本丶国产丶欧美色综合 | 国产视频精品久久 | 日本在线视频一区二区三区 | 91人人射| 久久看免费视频 | 国产精品入口66mio女同 | 国产99区 | 99精品久久精品一区二区 | 国产成人福利片 | 日韩在线免费视频观看 | 欧美激情视频一区 | a级国产乱理论片在线观看 伊人宗合网 | 欧美性视频网站 | 99久久国产免费看 | 特及黄色片 | 亚洲精品高清在线 | 96久久精品 | 欧美精品久久久久久久久久白贞 | 日本三级久久 | 久久人人97超碰国产公开结果 | 日韩精品一区二区三区免费观看 | 国产精品丝袜 | 日本性动态图 | 亚洲精品午夜一区人人爽 | 中文字幕中文字幕在线中文字幕三区 | 国产在线成人 | av导航福利 | 国产麻豆精品一区 | 国产精品久久久久久久久久 | zzijzzij亚洲成熟少妇 | 成人免费看视频 | 四虎影视av| 国产手机视频在线观看 | 欧美性色黄大片在线观看 | 久久婷婷一区二区三区 | 天天干 夜夜操 | 亚洲精品国产欧美在线观看 | 亚洲一区二区麻豆 | 欧美网站黄色 | 成人国产精品入口 | 国内成人精品2018免费看 | 亚洲成年人免费网站 | 日韩精品在线观看av | 天堂入口网站 | 999一区二区三区 | 亚洲视频一区二区三区在线观看 | 国产视频久久久 | 成人动漫视频在线 | 亚洲一区不卡视频 | 日韩久久久久久久久久 | 久久免费中文视频 | 久久精品国产99 | 国产精品久久网站 | 黄色大片中国 | 97视频在线观看成人 | 日韩成人免费观看 | 欧洲色吧 | 91亚洲网站 | 色在线网站| 久久综合久久八八 | 欧美大片www | 精品一区二区视频 | 国产特级毛片aaaaaa高清 | 永久中文字幕 | 久久精品国产亚洲 | 超薄丝袜一二三区 | 最新av在线播放 | 亚洲精品乱码久久久久久蜜桃91 | 黄色网中文字幕 | 国产又粗又猛又色 | 精品一区精品二区 | 在线va视频| 黄色午夜 | 激情五月综合 | 视频一区二区在线观看 | 国产在线欧美在线 | 婷婷丁香狠狠爱 | 精品福利网站 | 亚洲国产免费网站 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 日日日操| 国产精品青草综合久久久久99 | 色干综合 | 国产精品美女在线观看 | 国产91在| 欧美日韩69 | 日本久久久久久久久久 | 男女啪啪视屏 | 久草久草视频 | 国产小视频在线免费观看视频 | 美女视频黄在线 | 日韩,中文字幕 | 免费在线观看日韩欧美 | 久草电影在线观看 | 91成人短视频在线观看 | 91麻豆高清视频 | 美女黄频| 中文字幕色播 | 久久亚洲国产精品 | 久久99精品久久久久久清纯直播 | 亚洲成免费 | 91久久国产露脸精品国产闺蜜 | av黄色一级片 | 一级做a视频 | 欧美日韩视频在线 | av视屏在线播放 | 成人一级| 国产成人亚洲在线观看 | 成人免费在线看片 | 亚洲男男gaygay无套同网址 | 婷久久 | 精品毛片一区二区免费看 | 一性一交视频 | 国产午夜精品一区二区三区在线观看 | 一区二区av | av免费播放 | 在线观看网站你懂的 | 人人澡人人草 | 国产日韩在线一区 | 啪啪凸凸| 天天综合网国产 | 久久成熟 | 中文字幕av一区二区三区四区 | av线上免费观看 | 五月婷婷六月丁香 | 国产精品9区 | 草久久久 | 日韩视频一区二区三区 | 国产成人精品一区二区在线观看 | 激情在线网址 | 国产精品日韩高清 | 91久久精品一区 | 黄色三级免费片 | 婷婷在线免费视频 | 这里只有精品视频在线 | 国产麻豆电影在线观看 | 超碰在97| 日韩亚洲在线观看 | 日韩精品免费 | 精品久久99| 国产一级精品绿帽视频 | 天天天色| 国产日本亚洲 | 久久久免费精品视频 | 日韩av不卡在线播放 | 日日夜夜噜噜噜 | 丝袜网站在线观看 |