C#操作SQLite

1、SQLite介绍

 

 


SQLite,是一款轻型的数据库,是遵守的ACID关系型数据库管理系统,它包含在一个相对小的C库中。它的设计目标嵌入式是的,而且已经在很多中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。它能够支持Windows/Linux/Unix等等主流的操作系统,同时能够跟很多程序语言相结合,比如 Tcl、C#、PHP、Java等。

2、C#下调用SQLite数据库

在NuGet程序包内,搜索System.Data.Sqlite,安装Sqlite类库

 

 

创建SQLiteHelper类 如下:

  1 using System;
  2 using System.Collections.Generic;
  3 using System.Data;
  4 using System.Data.SQLite;
  5 using System.IO;
  6 using System.Linq;
  7 using System.Text;
  8 using System.Threading.Tasks;
  9 
 10 namespace DemoSQLite.com.DemoSQLite.Control
 11 {
 12     public class SQLiteHelper
 13     {
 14         ///创建数据库文件
 15         public static void CreateDBFile(string fileName)
 16         {
 17             string path = System.Environment.CurrentDirectory + @"/Data/";
 18             if (!Directory.Exists(path))
 19             {
 20                 Directory.CreateDirectory(path);
 21             }
 22             string databaseFileName = path + fileName;
 23             if (!File.Exists(databaseFileName))
 24             {
 25                 SQLiteConnection.CreateFile(databaseFileName);
 26             }
 27         }
 28 
 29         //生成连接字符串
 30         private static string CreateConnectionString()
 31         {
 32             SQLiteConnectionStringBuilder connectionString = new SQLiteConnectionStringBuilder();
 33             connectionString.DataSource = @"data/StudentDB.db";
 34 
 35             string conStr = connectionString.ToString();
 36             return conStr;
 37         }
 38 
 39         /// <summary>
 40         /// 对插入到数据库中的空值进行处理
 41         /// </summary>
 42         /// <param name="value"></param>
 43         /// <returns></returns>
 44         public static object ToDbValue(object value)
 45         {
 46             if (value == null)
 47             {
 48                 return DBNull.Value;
 49             }
 50             else
 51             {
 52                 return value;
 53             }
 54         }
 55 
 56         /// <summary>
 57         /// 对从数据库中读取的空值进行处理
 58         /// </summary>
 59         /// <param name="value"></param>
 60         /// <returns></returns>
 61         public static object FromDbValue(object value)
 62         {
 63             if (value == DBNull.Value)
 64             {
 65                 return null;
 66             }
 67             else
 68             {
 69                 return value;
 70             }
 71         }
 72 
 73         /// <summary>
 74         /// 执行非查询的数据库操作
 75         /// </summary>
 76         /// <param name="sqlString">要执行的sql语句</param>
 77         /// <param name="parameters">参数列表</param>
 78         /// <returns>返回受影响的条数</returns>
 79         public static int ExecuteNonQuery(string sqlString, params SQLiteParameter[] parameters)
 80         {
 81             string connectionString = CreateConnectionString();
 82             using (SQLiteConnection conn = new SQLiteConnection(connectionString))
 83             {
 84                 conn.Open();
 85                 using (SQLiteCommand cmd = conn.CreateCommand())
 86                 {
 87                     cmd.CommandText = sqlString;
 88                     foreach (SQLiteParameter parameter in parameters)
 89                     {
 90                         cmd.Parameters.Add(parameter);
 91                     }
 92                     return cmd.ExecuteNonQuery();
 93                 }
 94             }
 95         }
 96 
 97         /// <summary>
 98         /// 执行查询并返回查询结果第一行第一列
 99         /// </summary>
100         /// <param name="sqlString">SQL语句</param>
101         /// <param name="sqlparams">参数列表</param>
102         /// <returns></returns>
103         public static object ExecuteScalar(string sqlString, params SQLiteParameter[] parameters)
104         {
105             string connectionString = CreateConnectionString();
106             using (SQLiteConnection conn = new SQLiteConnection(connectionString))
107             {
108                 conn.Open();
109                 using (SQLiteCommand cmd = conn.CreateCommand())
110                 {
111                     cmd.CommandText = sqlString;
112                     foreach (SQLiteParameter parameter in parameters)
113                     {
114                         cmd.Parameters.Add(parameter);
115                     }
116                     return cmd.ExecuteScalar();
117                 }
118             }
119         }
120 
121         /// <summary>
122         /// 查询多条数据
123         /// </summary>
124         /// <param name="sqlString">SQL语句</param>
125         /// <param name="parameters">参数列表</param>
126         /// <returns>返回查询的数据表</returns>
127         public static DataTable GetDataTable(string sqlString, params SQLiteParameter[] parameters)
128         {
129             string connectionString = CreateConnectionString();
130             using (SQLiteConnection conn = new SQLiteConnection(connectionString))
131             {
132                 conn.Open();
133                 using (SQLiteCommand cmd = conn.CreateCommand())
134                 {
135                     cmd.CommandText = sqlString;
136                     foreach (SQLiteParameter parameter in parameters)
137                     {
138                         cmd.Parameters.Add(parameter);
139                     }
140                     DataSet ds = new DataSet();
141                     SQLiteDataAdapter adapter = new SQLiteDataAdapter(cmd);
142                     adapter.Fill(ds);
143                     conn.Close();
144                     return ds.Tables[0];
145                 }
146             }
147         }
148     }
149 }

 

调用方式:

/// <summary>
        /// 查询所有年级
        /// </summary>
        /// <returns></returns>
        public List<GradeEty> GetAllGrade()
        {
            List<GradeEty> gradeEties = new List<GradeEty>();

            SQLiteHelper sQLiteHelper = new SQLiteHelper();
            string sqlQuery = "SELECT * FROM 'Grade';";
            SQLiteParameter[] parameters = new SQLiteParameter[]
             {
                    //new SQLiteParameter("@IMG_ID", DbType.Int32,4),
                    //new SQLiteParameter("@USER_ID", DbType.String),
             };
            //parameters[0].Value = model.IMG_ID;
            //parameters[1].Value = model.USER_ID;

            DataTable dt = SQLiteHelper.GetDataTable(sqlQuery, parameters);
            for (int i = 0; i < dt.Rows.Count; i++)
            {
                string Id = dt.Rows[i]["ID"].ToString();
                string GradeName = dt.Rows[i]["GradeName"].ToString();
            

                GradeEty clientEty = new GradeEty(Id, GradeName);
                gradeEties.Add(clientEty);
            }
            return gradeEties;
        }

 

posted @ 2022-12-10 10:02  宇宙无敌狗蛋  阅读(6921)  评论(0编辑  收藏  举报