ado.net 操作sqlite

新建控制台项目

在这里插入图片描述
安装nuget包Microsoft.Data.Sqlite
在这里插入图片描述

数据库名字和链接

string dbName = "test.db";
SqliteConnection? connection = null;
try
{
    //创建链接
    connection = new SqliteConnection($"Data Source={dbName}");
    //打开链接
    connection.Open();
}
catch (Exception ex)
{
    Console.WriteLine(ex.Message);
}
finally
{
    //使用完关闭
    connection?.Close();
}
Console.WriteLine("执行执行完毕");
Console.ReadKey();

创建表

/// <summary>
/// 创建表
/// </summary>
static void CreateTable(SqliteConnection connection)
{
    var studentTable = @"CREATE TABLE IF NOT EXISTS Student(Id INTEGER PRIMARY KEY AUTOINCREMENT,Name TEXT NOT NULL,Age INTEGER)";
    using (var command = new SqliteCommand(studentTable, connection))
    {
        var status = command.ExecuteNonQuery();
        Console.WriteLine($"创建学生表结果:{status}");
    }
}

/// <summary>
/// 查询数据库中的表
/// </summary>
/// <param name="connection"></param>
static void QueryTables(SqliteConnection connection)
{
    var querySql = "SELECT name FROM sqlite_master WHERE type='table' AND name NOT LIKE 'sqlite_%';";
    using (var command = new SqliteCommand(querySql, connection))
    using (var reader = command.ExecuteReader())
    {
        while (reader.Read())
        {
            Console.WriteLine($"表名:{reader.GetString(0)}");
        }
    }
}

在这里插入图片描述

增加数据

/// <summary>
/// 插入数据
/// </summary>
/// <param name="connection"></param>
static void InsertData(SqliteConnection connection)
{
    string insertSql = @"INSERT INTO Student (Name, Age) VALUES (@Name, @Age)";

    using (var command = new SqliteCommand(insertSql, connection))
    {
        command.Parameters.AddWithValue("@Name", "小明");
        command.Parameters.AddWithValue("@Age", 25);
        command.ExecuteNonQuery();
        command.Parameters["@Name"].Value = "小红";
        command.Parameters["@Age"].Value = 22;
        command.ExecuteNonQuery();
        Console.WriteLine("插入成功");
    }
}

在这里插入图片描述

查询数据

/// <summary>
/// 查询数据
/// </summary>
/// <param name="connection"></param>
static void QueryData(SqliteConnection connection)
{
    var querySql = "Select Id,Name,Age FROM Student;";
    using (var command = new SqliteCommand(querySql, connection))
    using (var reader = command.ExecuteReader())
    {
        while (reader.Read())
        {
            Console.WriteLine($"Id:{reader.GetInt32(0)},姓名:{reader.GetString(1)},年龄:{reader.GetInt32(2)}");
        }
    }
}

在这里插入图片描述

修改数据

/// <summary>
/// 更新数据
/// </summary>
/// <param name="connection"></param>
static void UpdateData(SqliteConnection connection)
{
    string updateSql = @"UPDATE Student SET Age=@Age WHERE Id=@Id";

    using (var command = new SqliteCommand(updateSql, connection))
    {
        command.Parameters.AddWithValue("@Id", 1);
        command.Parameters.AddWithValue("@Age", 31);
        command.ExecuteNonQuery();
        //查询结果
        QueryData(connection);
    }
}

在这里插入图片描述

删除数据

/// <summary>
/// 删除数据
/// </summary>
/// <param name="connection"></param>
static void DeleteData(SqliteConnection connection)
{
    string deleteSql = @"DELETE FROM Student WHERE Id=@Id";

    using (var command = new SqliteCommand(deleteSql, connection))
    {
        command.Parameters.AddWithValue("@Id", 1);
        command.ExecuteNonQuery();
        //查询结果
        QueryData(connection);
    }
}

在这里插入图片描述
完整代码如下

using Microsoft.Data.Sqlite;

namespace AdoNetSqliteStu
{
    internal class Program
    {
        static void Main(string[] args)
        {
            string dbName = "test.db";
            SqliteConnection? connection = null;
            try
            {
                //创建链接
                connection = new SqliteConnection($"Data Source={dbName}");
                //打开链接
                connection.Open();
                //创建表
                CreateTable(connection);
                QueryTables(connection);
                //插入数据
                InsertData(connection);
                //查询数据
                QueryData(connection);
                //更新数据
                UpdateData(connection);
                //删除数据
                DeleteData(connection);
            }
            catch (Exception ex)
            {
                Console.WriteLine(ex.Message);
            }
            finally
            {
                //使用完关闭
                connection?.Close();
            }
            Console.WriteLine("执行执行完毕");
            Console.ReadKey();
        }

        /// <summary>
        /// 创建表
        /// </summary>
        static void CreateTable(SqliteConnection connection)
        {
            var studentTable = @"CREATE TABLE IF NOT EXISTS Student(Id INTEGER PRIMARY KEY AUTOINCREMENT,Name TEXT NOT NULL,Age INTEGER)";
            using (var command = new SqliteCommand(studentTable, connection))
            {
                var status = command.ExecuteNonQuery();
                Console.WriteLine($"创建学生表结果:{status}");
            }
        }

        /// <summary>
        /// 查询数据库中的表
        /// </summary>
        /// <param name="connection"></param>
        static void QueryTables(SqliteConnection connection)
        {
            var querySql = "SELECT name FROM sqlite_master WHERE type='table' AND name NOT LIKE 'sqlite_%';";
            using (var command = new SqliteCommand(querySql, connection))
            using (var reader = command.ExecuteReader())
            {
                while (reader.Read())
                {
                    Console.WriteLine($"表名:{reader.GetString(0)}");
                }
            }
        }

        /// <summary>
        /// 插入数据
        /// </summary>
        /// <param name="connection"></param>
        static void InsertData(SqliteConnection connection)
        {
            string insertSql = @"INSERT INTO Student (Name, Age) VALUES (@Name, @Age)";

            using (var command = new SqliteCommand(insertSql, connection))
            {
                command.Parameters.AddWithValue("@Name", "小明");
                command.Parameters.AddWithValue("@Age", 25);
                command.ExecuteNonQuery();
                command.Parameters["@Name"].Value = "小红";
                command.Parameters["@Age"].Value = 22;
                command.ExecuteNonQuery();
                Console.WriteLine("插入成功");
            }
        }
    
        /// <summary>
        /// 查询数据
        /// </summary>
        /// <param name="connection"></param>
        static void QueryData(SqliteConnection connection)
        {
            var querySql = "Select Id,Name,Age FROM Student;";
            using (var command = new SqliteCommand(querySql, connection))
            using (var reader = command.ExecuteReader())
            {
                while (reader.Read())
                {
                    Console.WriteLine($"Id:{reader.GetInt32(0)},姓名:{reader.GetString(1)},年龄:{reader.GetInt32(2)}");
                }
            }
        }
        
        /// <summary>
        /// 更新数据
        /// </summary>
        /// <param name="connection"></param>
        static void UpdateData(SqliteConnection connection)
        {
            string updateSql = @"UPDATE Student SET Age=@Age WHERE Id=@Id";

            using (var command = new SqliteCommand(updateSql, connection))
            {
                command.Parameters.AddWithValue("@Id", 1);
                command.Parameters.AddWithValue("@Age", 31);
                command.ExecuteNonQuery();
                //查询结果
                QueryData(connection);
            }
        }

        /// <summary>
        /// 删除数据
        /// </summary>
        /// <param name="connection"></param>
        static void DeleteData(SqliteConnection connection)
        {
            string deleteSql = @"DELETE FROM Student WHERE Id=@Id";

            using (var command = new SqliteCommand(deleteSql, connection))
            {
                command.Parameters.AddWithValue("@Id", 1);
                command.ExecuteNonQuery();
                //查询结果
                QueryData(connection);
            }
        }
    }
}

  • 5
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

假装我不帅

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值