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

相关文章

  • .NET 6开发TodoList应用之使用AutoMapper实现GET请求

    一、前言 本文将会详细讲解如何使用AutoMapper实现GET请求。在本文中,我们将会使用.NET 6和AutoMapper来搭建一个TodoList应用程序,以便我们更好的理解AutoMapper的作用。 二、什么是AutoMapper AutoMapper是一个.NET的对象映射库。它的作用是将一个对象类型的数据转换为另一个对象类型的数据。因为在实际项…

    C# 2023年6月3日
    00
  • C#求n个数中最大值和最小值的方法

    C#求n个数中最大值和最小值的方法 在 C# 中求解 n 个数中最大值和最小值有多种方法,下面将给出两种常用的方法: 方法一:使用 Arrays 类的 Sort 和第一个元素和最后一个元素的方法 这种方法先使用 Arrays 类的 Sort 方法将所有数从小到大排序,然后取出排序后的第一个元素作为最小值,最后一个元素作为最大值。 示例代码如下: int[] …

    C# 2023年6月1日
    00
  • C#影院售票系统毕业设计(1)

    下面逐步讲解“C#影院售票系统毕业设计(1)”的完整攻略。 1. 确定项目需求 要开发一个影院售票系统,需要满足以下需求: 用户端 用户可以通过图形化操作,实现选座、支付等功能; 可以查看影片排片信息、影院信息、个人信息等; 可以对已完成订单进行评价和投诉; 实现基本的安全性,如密码保护等。 管理员端 管理员可以通过图形化界面添加、修改、删除影片和影院信息;…

    C# 2023年6月1日
    00
  • ASP.Net Core对USB摄像头进行截图

    以下是“ASP.NetCore对USB摄像头进行截图”的完整攻略: 什么是ASP.NetCore ASP.NetCore是一个跨平台的Web应用程序框架,它可以在Windows、Linux和macOS等操作系统上运行。ASP.NetCore是.NET Core的一部分,它提供了一现代化的Web开发模型,可以轻松地构建高性能、可展和安全的Web应用程序。 如何…

    C# 2023年5月12日
    00
  • C#使用log4net记录日志

    下面是关于” C#使用log4net记录日志 “的完整攻略。 一、什么是log4net log4net是一个用于.Net环境下高度可配置的日志组件,它能够记录任何.Net应用程序或库中发生的任何事件,从简单的控制台输出到复杂的邮件消息和数据库日志记录都可以轻松地实现。 二、如何使用log4net 以下是使用log4net的基本步骤: 1. 添加log4net…

    C# 2023年5月14日
    00
  • C# 程序集和反射详解

    C#程序集和反射是C#语言中的重要概念,下面我将详细讲解它们。 C#程序集 程序集是 C# 语言的一个基本概念,它是一组可重用的代码和相关信息的集合。程序集是一种可以被其他程序重用的单元。在 Visual Studio 中,可以创建两种类型的程序集:可执行程序集和动态链接库。 在创建程序集的过程中,需要考虑程序集名称、程序集版本、程序集描述等信息。下面是创建…

    C# 2023年5月14日
    00
  • 游戏开发之随机概率的选择算法

    游戏开发中,随机数算法是一个非常重要的部分,它常常被用来在游戏当中生成随机的事件、物品、角色属性等等。而其中选择算法则是如何从一个固定的集合中,按照一定的概率来随机选择一个目标的算法。 以下是游戏开发中常用的三种选择算法: 1. 等概率随机算法 这种算法是最简单的一种,它的实现原理是先生成一个 0-1 之间的随机数,然后将这个随机数乘以集合元素的个数,将结果…

    C# 2023年6月7日
    00
  • asp.net core实体类生产CRUD后台管理界面

    ASP.NET Core 实体类生成 CRUD 后台管理界面 ASP.NET Core 实体类生成 CRUD 后台管理界面是一种常见的操作。本攻略将介绍如何使用 ASP.NET Core 实体类生成 CRUD 后台管理界面。 步骤 以下是使用 ASP.NET Core 实体类生成 CRUD 后台管理界面的步骤: 安装 Scaffold-DbContext 工…

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