在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日

相关文章

  • ASP.NET Core使用JWT认证授权的方法

    当使用ASP.NET Core构建Web应用程序时,使用JWT(JSON Web Token)进行身份验证和授权是一种常见的方法。JWT是一种轻量级的身份验证和授权机制,它使用JSON格式的令牌来传递用户信息和权限。 以下是使用ASP.NET Core进行JWT身份验证和授权的完整攻略: 步骤一:安装必要的NuGet包 在使用JWT进行身份验证和授权之前,需…

    C# 2023年5月17日
    00
  • asp.net(c#)获取内容第一张图片地址的函数

    获取内容中第一张图片地址是 web 开发中常见的需求,可以通过正则表达式或者 HTML 解析器(如 HtmlAgilityPack)来实现。下面我将分别介绍这两种方法的具体实现步骤。 使用正则表达式获取第一张图片 1. 构建正则表达式 构建正则表达式以匹配 HTML 中的 img 标签,并获取其中的 src 属性值。 string regx = "…

    C# 2023年5月15日
    00
  • Unity中Instantiate实例化物体卡顿问题的解决

    关于Unity中Instantiate实例化物体卡顿问题的解决,我整理了以下攻略: Unity中Instantiate实例化物体卡顿问题的解决 问题描述 在Unity开发过程中,使用Instantiate()函数实例化物体时,会出现卡顿现象,特别是当要大量实例化物体时,卡顿现象会更加明显。 解决方法 方法一:使用对象池 使用对象池是一种常见的解决Instan…

    C# 2023年6月3日
    00
  • C#向无窗口的进程发送消息

    下面是详细的讲解。 C#向无窗口的进程发送消息的完整攻略 在C#中,我们可以使用Windows API来向无窗口的进程发送消息。下面是完整的攻略。 1. 准备工作 要向无窗口的进程发送消息,我们需要知道目标进程的进程ID(PID)。可以使用Windows API中的Process.GetProcessesByName()方法获取指定名称的进程列表,然后根据需…

    C# 2023年6月6日
    00
  • C#实现矩阵加法、取负、数乘、乘法的方法

    要实现矩阵加法、取负、数乘、乘法,可以使用 C# 中的多维数组来表示矩阵,然后编写相应的函数实现这些操作。 定义矩阵 可以使用以下语句定义一个 2×3 的矩阵: int[,] matrix = new int[2,3]{{1,2,3},{4,5,6}}; 矩阵加法 矩阵加法的规则是将两个矩阵对应位置的元素相加,得到一个新的矩阵。 可以编写以下函数实现矩阵加法…

    C# 2023年6月7日
    00
  • 关于WPF WriteableBitmap类直接操作像素点的问题

    关于WPF WriteableBitmap类直接操作像素点的问题,可以参考以下攻略: 1. 什么是WriteableBitmap类 WriteableBitmap是WPF中一个重要的类,它可以被用来创建一个用于呈现可写的图像的BitmapSource对象,而且可以以像素为单位进行访问和修改。WriteableBitmap对象的像素数组可以由开发者直接修改,使…

    C# 2023年6月3日
    00
  • C#实现对象的序列化和反序列化

    C#实现对象的序列化和反序列化 在C#中,我们可以使用对象的序列化和反序列化将对象转换为字节流,并将其保存到文件中或发送到网络。在本文中,我们将介绍如何使用C#实现对象的序列化和反序列化。 什么是对象序列化? 序列化是指将一个对象转换为字节流的过程。序列化后的对象可以保存在文件中或通过网络发送。当我们需要在不同的应用程序或服务器之间传输数据时,序列化是一种非…

    C# 2023年5月31日
    00
  • C#中IntPtr类型的具体使用

    当需要动态操作内存时,C# 提供了一个 IntPtr 类型,该类型可以包含一个指针或句柄的值。 在C#中,IntPtr类型被广泛使用,它定义为和平台相关大小的整数,通常是32位或64位整数数据类型。一般来说,IntPtr类型在本机环境下使用。下面是IntPtr类的语法。 public struct System.IntPtr : System.Runtime…

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