在C#中使用SQLite数据库

轻量级桌面程序数据库不太适合用SQLServer、MySQL之类的重量级数据库,嵌入式数据库更好。在对比Access、SQLite、Firebird数据库后发现SQLite较另外两个有较多优点。

环境:.NET Framework 3.5、windows11 64位、Visual Studio 2010.

C#使用SQLite需要从SQLite官网下载DLL组件。

我是windows11,64位的开发环境,最开始下载的64位的,结果运行时报异常。通过查资料,情况比较复杂(参考:https://blog.51cto.com/xxjjing/5804868),遂重新下载了32位的包:sqlite-netFx35-binary-Win32-2008-1.0.117.0

下载地址:https://system.data.sqlite.org/index.html/doc/trunk/www/downloads.wiki

下载后将包解压放到一个固定目录,需要依赖System.Data.SQLite.dll和SQLite.Interop.dll这两个文件,

在项目里右键项目 > 添加引用 > 选“浏览”选项卡,找到解压后的目录,引入System.Data.SQLite.dll,另一个文件SQLite.Interop.dll不可以通过引用方式添加,必须只能复制文件到运行目录下,通过调试发现程序会自动把System.Data.SQLite.dll也复制到运行目录下,System.Data.SQLite.dll和SQLite.Interop.dll文件会在一起。(尝试过直接复制这两个文件到程序的运行目录下不可行,Visual Studio里不管怎么刷新项目的引用列表都不会出现这两个文件,运行会报错。)

C# 中使用SQLite示例:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Data;
using System.Data.SQLite;

namespace SQLiteTest
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void Form1_Load(object sender, EventArgs e)
        {
            Console.WriteLine("SQL Lite 数据库试验");
            // 连接数据库,FailIfMissing=false时若文件不存在会自动创建
            string connStr = "Data Source=test.db;Version=3;Pooling=true;FailIfMissing=false;";
            SQLiteConnection conn = new SQLiteConnection(connStr);
            conn.Open();

            //在指定数据库中创建一个table
            string sql = "create table highscores (name varchar(20), score int)";
            SQLiteCommand command = new SQLiteCommand(sql, conn);
            command.ExecuteNonQuery();

            // 插入一些数据
            sql = "insert into highscores (name, score) values ('Me', 3000)";
            command = new SQLiteCommand(sql, conn);
            command.ExecuteNonQuery();

            sql = "insert into highscores (name, score) values ('Myself', 6000)";
            command = new SQLiteCommand(sql, conn);
            command.ExecuteNonQuery();

            sql = "insert into highscores (name, score) values ('And I', 9001)";
            command = new SQLiteCommand(sql, conn);
            command.ExecuteNonQuery();

            // 查询数据
            sql = "select * from highscores order by score desc";
            command = new SQLiteCommand(sql, conn);
            SQLiteDataReader reader = command.ExecuteReader();
            while (reader.Read())
            {
                Console.WriteLine("Name: " + reader["name"] + "\tScore: " + reader["score"]);
            }
        }
    }
}

 更多参考资料:

原文链接:https://www.cnblogs.com/jsper/archive/2023/04/23/17346758.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:在C#中使用SQLite数据库 - Python技术站

(0)
上一篇 2023年4月24日
下一篇 2023年4月24日

相关文章

  • 深入了解c# 匿名类型

    深入了解 C# 匿名类型攻略 什么是匿名类型 C# 中的匿名类型是一种可以在运行时创建对象的特殊类型。与其他类不同,匿名类型没有名字,它的定义在编写代码时不需要指定名称。通常,匿名类型用于临时存储数据和查询结果等场景。 在 C# 中,创建匿名类型主要依靠对象初始化器和隐式类型表达式语法。以下是一个简单的示例: var person = new { Name …

    C# 2023年5月31日
    00
  • asp.net中一个linq分页实现代码

    针对“asp.net中一个linq分页实现代码”的完整攻略,我将分为以下几个步骤进行详细讲解。 步骤一:定义分页方法 首先,在asp.net中,我们可以通过自定义分页方法来实现分页功能。这里我们可以采用linq语句来获取指定页码的数据,以下是一个简单的分页方法示例: public IQueryable<T> GetPagedData<T&g…

    C# 2023年5月31日
    00
  • C#实现多文件压缩与解压功能

    我会根据题目要求,使用标准的markdown格式回答这个问题。 C#实现多文件压缩与解压功能攻略 压缩功能 压缩单个文件 我们可以使用C#自带的System.IO.Compression命名空间,在程序中直接实现单个文件的压缩。 下面是一个压缩单个文件的示例代码: using System.IO.Compression; public static void…

    C# 2023年6月1日
    00
  • CommunityToolkit.Mvvm8.1 消息通知(4)

    本系列文章导航 https://www.cnblogs.com/aierong/p/17300066.html https://github.com/aierong/WpfDemo (自我Demo地址)   希望提到的知识对您有所提示,同时欢迎交流和指正 作者:aierong出处:https://www.cnblogs.com/aierong   说明 为了…

    C# 2023年4月17日
    00
  • C#的winform控件命名规范

    C#的WinForm控件命名规范是指在WinForm应用程序中对各种控件进行命名的规范化约定,这能够使命名更加规范、易于理解和维护。接下来,我将介绍一些命名规范和示例说明: 命名规范 控件的名称应该以小写字母开头,其后可以跟着一个或多个单词,每个单词首字母大写,这些单词应当准确地描述该控件的用途。例如,如果你有一个按钮控件用于保存数据,那么这个按钮应当被命名…

    C# 2023年6月1日
    00
  • Web应用开发TypeScript使用详解

    Web应用开发TypeScript使用详解 简介 本攻略将介绍如何在Web应用开发中使用TypeScript,包括安装TypeScript、配置TypeScript环境、使用TypeScript编写前端代码等。 安装TypeScript 要使用TypeScript,需要先安装TypeScript编译器。可以通过以下命令来安装TypeScript: npm i…

    C# 2023年5月15日
    00
  • C# Stream.ReadByte – 从流中读取一个字节

    C# 中的 Stream 类提供了许多方法来读取和写入字节流,其中包括 ReadByte 方法。ReadByte 方法的作用是从当前流中读取下一个字节并提升流的位置一个字节,如果流已经结束,则返回 -1。 使用方法的完整攻略如下: 语法 public virtual int ReadByte(); 返回值 返回读取的字节的整数表示形式,如果已经读取到流的末尾…

    C# 2023年4月19日
    00
  • asp.net 备份和恢复数据库的方法示例

    当我们在开发ASP.NET项目的时候,经常需要用到对数据库的备份和恢复。本文将详细介绍如何使用SQL Server Management Studio(SSMS)和Transact-SQL(T-SQL)备份和恢复数据库,以及在ASP.NET中使用C#代码备份和恢复数据库。 使用SQL Server Management Studio(SSMS)备份和恢复数据…

    C# 2023年5月31日
    00
合作推广
合作推广
分享本页
返回顶部