ASP.NET|日常开发中连接Sqlite数据库详解

news2024/12/13 18:40:51

在这里插入图片描述
在这里插入图片描述

ASP.NET|日常开发中连接Sqlite数据库详解

  • 前言
  • 一、安装和引用相关库
    • 1.1 安装 SQLite 驱动
    • 1.2 引用命名空间
  • 二、配置连接字符串
    • 2.1 连接字符串的基本格式
  • 三、建立数据库连接
    • 3.1 创建连接对象并打开连接
  • 四、执行数据库操作
    • 4.1 创建表(以简单的用户表为例)
    • 4.2 插入数据
    • 4.3 查询数据
    • 4.4 更新数据
    • 4.5 删除数据
  • 结束语
  • 优质源码分享

ASP.NET|日常开发中连接Sqlite数据库详解,在ASP.NET日常开发中,连接SQLite数据库是一个常见的需求,特别是对于那些需要轻量级、嵌入式数据库解决方案的应用程序。SQLite是一个自给自足的、无服务器的、零配置的SQL数据库引擎,它非常适合于嵌入式设备和移动应用程序。以下是一个详细的步骤指南,介绍如何在ASP.NET应用程序中连接SQLite数据库。

前言

        在数字浪潮汹涌澎湃的时代,程序开发宛如一座神秘而宏伟的魔法城堡,矗立在科技的浩瀚星空中。代码的字符,似那闪烁的星辰,按照特定的轨迹与节奏,组合、交织、碰撞,即将开启一场奇妙且充满无限可能的创造之旅。当空白的文档界面如同深邃的宇宙等待探索,程序员们则化身无畏的星辰开拓者,指尖在键盘上轻舞,准备用智慧与逻辑编织出足以改变世界运行规则的程序画卷,在 0 和 1 的二进制世界里,镌刻下属于人类创新与突破的不朽印记。

一、安装和引用相关库

1.1 安装 SQLite 驱动

    在ASP.NET项目中连接 SQLite 数据库,首先需要安装 SQLite 的.NET 数据访问库。可以通过 NuGet 包管理器安装System.Data.SQLite包。这个包提供了在.NET 环境下操作 SQLite 数据库所需的类和方法。

1.2 引用命名空间

    在代码文件中添加using System.Data.SQLite;引用,这样才能使用 SQLite 相关的类,如SQLiteConnection、SQLiteCommand等。

二、配置连接字符串

2.1 连接字符串的基本格式

    SQLIte 的连接字符串格式相对简单。例如,连接一个本地的 SQLite 数据库文件的连接字符串可以是:

string connectionString = "Data Source=your_database_file.db;Version=3;";

    其中,Data Source指定了 SQLite 数据库文件的路径。如果数据库文件在项目的相对路径下,需要确保路径的正确性。Version=3表示使用 SQLite 的版本 3,这是比较常用的版本。

三、建立数据库连接

3.1 创建连接对象并打开连接

    使用SQLiteConnection类来创建连接对象,例如:

SQLiteConnection connection = new SQLiteConnection(connectionString);
try
{
    connection.Open();
    // 在这里执行数据库操作
}
catch (SQLiteException ex)
{
    Console.WriteLine($"数据库连接错误: {ex.Message}");
}
finally
{
    connection.Close();
}

    在try - catch - finally块中,try部分用于打开连接并执行数据库操作;catch部分用于捕获数据库连接过程中可能出现的异常,如文件不存在、权限问题等;finally部分确保无论操作是否成功,连接都会被关闭,以释放资源。

四、执行数据库操作

4.1 创建表(以简单的用户表为例)

  • 构建创建表语句

    在 SQLite 中,使用CREATE TABLE语句来创建表。例如,创建一个名为users的表,包含id(主键,自动增长)、name和age字段的 SQL 语句如下:

    CREATE TABLE users (
        id INTEGER PRIMARY KEY AUTOINCREMENT,
        name TEXT,
        age INTEGER
    );
  • 在 C# 中执行创建表操作

    使用SQLiteCommand类来执行 SQL 语句,如下所示:

    string createTableQuery = "CREATE TABLE users (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER)";
    SQLiteCommand command = new SQLiteCommand(createTableQuery, connection);
    try
    {
        command.ExecuteNonQuery();
        Console.WriteLine("表创建成功。");
    }
    catch (SQLiteException ex)
    {
        Console.WriteLine($"表创建错误: {ex.Message}");
    }

    ExecuteNonQuery方法用于执行不返回结果集的 SQL 语句,如CREATE、INSERT、UPDATE和DELETE语句,它返回受影响的行数。对于创建表操作,如果成功创建,返回值为 0。

4.2 插入数据

  • 构建插入语句

    插入数据使用INSERT INTO语句。例如,插入一条用户记录的 SQL 语句如下:

    INSERT INTO users (name, age) VALUES ('John', 20);
  • 在 C# 中执行插入操作

    同样使用SQLiteCommand类,并且推荐使用参数化查询,如下所示:

    string insertQuery = "INSERT INTO users (name, age) VALUES (@name, @age)";
    SQLiteCommand command = new SQLiteCommand(insertQuery, connection);
    command.Parameters.AddWithValue("@name", "John");
    command.Parameters.AddWithValue("@age", 20);
    try
    {
        int rowsAffected = command.ExecuteNonQuery();
        if (rowsAffected > 0)
        {
            Console.WriteLine("数据插入成功。");
        }
    }
    catch (SQLiteException ex)
    {
        Console.WriteLine($"数据插入错误: {ex.Message}");
    }

    参数化查询不仅可以防止 SQL 注入攻击,还可以方便地动态设置参数值。ExecuteNonQuery方法返回受影响的行数,对于插入操作,如果成功插入一行,返回值为 1。

4.3 查询数据

  • 构建查询语句

    查询数据使用SELECT语句。例如,查询users表中所有用户的姓名和年龄的 SQL 语句如下:

    SELECT name, age FROM users;
  • 在 C# 中执行查询操作

    创建SQLiteCommand对象并执行查询,通过SQLiteDataReader读取结果,如下所示:

    string selectQuery = "SELECT name, age FROM users";
    SQLiteCommand command = new SQLiteCommand(selectQuery, connection);
    SQLiteDataReader reader;
    try
    {
        reader = command.ExecuteReader();
        while (reader.Read())
        {
            string name = reader.GetString("name");
            int age = reader.GetInt32("age");
            Console.WriteLine($"姓名: {name}, 年龄: {age}");
        }
        reader.Close();
    }
    catch (SQLiteException ex)
    {
        Console.WriteLine($"数据查询错误: {ex.Message}");
    }

    使用ExecuteReader方法执行查询语句,返回一个SQLiteDataReader对象。通过reader.Read方法遍历结果集,然后使用GetString、GetInt32等方法获取相应列的值。注意,获取列值时,列名或列索引要与数据库表中的定义一致。最后要记得关闭SQLiteDataReader对象,以释放资源。

4.4 更新数据

  • 构建更新语句

    更新数据使用UPDATE语句。例如,将users表中姓名为John的用户年龄更新为 21 的 SQL 语句如下:

    UPDATE users SET age = 21 WHERE name = 'John';
  • 在 C# 中执行更新操作

    构建和执行更新语句如下:

    string updateQuery = "UPDATE users SET age = @newAge WHERE name = @name";
    SQLiteCommand command = new SQLiteCommand(updateQuery, connection);
    command.Parameters.AddWithValue("@newAge", 21);
    command.Parameters.AddWithValue("@name", "John");
    try
    {
        int rowsAffected = command.ExecuteNonQuery();
        if (rowsAffected > 0)
        {
            Console.WriteLine("数据更新成功。");
        }
    }
    catch (SQLiteException ex)
    {
        Console.WriteLine($"数据更新错误: {ex.Message}");
    }

    同样使用参数化查询来构建更新语句,通过ExecuteNonQuery方法执行更新操作,并根据返回的受影响行数判断更新是否成功。

4.5 删除数据

  • 构建删除语句

    删除数据使用DELETE FROM语句。例如,删除users表中姓名为John的用户记录的 SQL 语句如下:

    DELETE FROM users WHERE name = 'John';
  • 在 C# 中执行删除操作

    构建和执行删除语句如下:

    string deleteQuery = "DELETE FROM users WHERE name = @name";
    SQLiteCommand command = new SQLiteCommand(deleteQuery, connection);
    command.Parameters.AddWithValue("@name", "John");
    try
    {
        int rowsAffected = command.ExecuteNonQuery();
        if (rowsAffected > 0)
        {
            Console.WriteLine("数据删除成功。");
        }
    }
    catch (SQLiteException ex)
    {
        Console.WriteLine($"数据删除错误: {ex.Message}");
    }

    还是使用参数化查询构建删除语句,执行ExecuteNonQuery方法后,根据返回的受影响行数判断删除是否成功。

结束语

        亲爱的朋友,无论前路如何漫长与崎岖,都请怀揣梦想的火种,因为在生活的广袤星空中,总有一颗属于你的璀璨星辰在熠熠生辉,静候你抵达。

         愿你在这纷繁世间,能时常收获微小而确定的幸福,如春日微风轻拂面庞,所有的疲惫与烦恼都能被温柔以待,内心永远充盈着安宁与慰藉。

        至此,文章已至尾声,而您的故事仍在续写,不知您对文中所叙有何独特见解?期待您在心中与我对话,开启思想的新交流。


--------------- 业精于勤,荒于嬉 ---------------
 

请添加图片描述

--------------- 行成于思,毁于随 ---------------

优质源码分享

  • 【百篇源码模板】html5各行各业官网模板源码下载

  • 【模板源码】html实现酷炫美观的可视化大屏(十种风格示例,附源码)

  • 【VUE系列】VUE3实现个人网站模板源码

  • 【HTML源码】HTML5小游戏源码

  • 【C#实战案例】C# Winform贪吃蛇小游戏源码


在这里插入图片描述


     💞 关注博主 带你实现畅游前后端

     🏰 大屏可视化 带你体验酷炫大屏

     💯 神秘个人简介 带你体验不一样得介绍

     🎀 酷炫邀请函 带你体验高大上得邀请


     ① 🉑提供云服务部署(有自己的阿里云);
     ② 🉑提供前端、后端、应用程序、H5、小程序、公众号等相关业务;
     如🈶合作请联系我,期待您的联系。
    :本文撰写于CSDN平台,作者:xcLeigh所有权归作者所有) ,https://blog.csdn.net/weixin_43151418,如果相关下载没有跳转,请查看这个地址,相关链接没有跳转,皆是抄袭本文,转载请备注本文原地址。


     亲,码字不易,动动小手,欢迎 点赞 ➕ 收藏,如 🈶 问题请留言(评论),博主看见后一定及时给您答复,💌💌💌


原文地址:https://blog.csdn.net/weixin_43151418/article/details/144309263(防止抄袭,原文地址不可删除)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2258921.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

DS记录中

DataX/hdfswriter/doc/hdfswriter.md at master alibaba/DataX GitHub DataX 写入文档 https://dolphinscheduler.apache.org/zh-cn/docs/3.2.2/architecture/task-structure DS文档 DS 项目举例 流程 数据库(Datax) -> ODS (shell)->ADS(…

Node.js express

1. express 介绍 express 是一个基于 Node.js 平台的极简、灵活的 WEB 应用开发框架,官方网址:https://www.expressjs.com.cn/简单来说,express 是一个封装好的工具包,封装了很多功能,便于我们开发 WEB 应用&#xff…

网络应用技术 实验八:防火墙实现访问控制(华为ensp)

目录 一、实验简介 二、实验目的 三、实验需求 四、实验拓扑 五、实验步骤 1、设计全网 IP 地址 2、设计防火墙安全策略 3、在 eNSP 中部署园区网 4、配置用户主机地址 5、配置网络设备 配置交换机SW-1~SW-5 配置路由交换机RS-1~RS-5 配置路由器R-1~R-3 6、配置仿…

分布式日志系统设计

一、分布式日志系统定义 分布式日志系统是一种用于收集、存储和分析大规模分布式系统日志的系统。它可以帮助开发人员和系统管理员实时监控和调试系统,提高系统可靠性和可用性,同时也可以用于日志分析和故障排查。 二、简单设计思路 日志收集&#xff…

详解RabbitMQ在Ubuntu上的安装

​​​​​​​ 目录 Ubuntu 环境安装 安装Erlang 查看Erlang版本 退出命令 ​编辑安装RabbitMQ 确认安装结果 安装RabbitMQ管理界面 启动服务 查看服务状态 通过IP:port访问 添加管理员用户 给用户添加权限 再次访问 Ubuntu 环境安装 安装Erlang RabbitMq需要…

java+springboot+mysql私人会所管理系统

项目介绍: 使用javaspringbootmysql开发的私人会所管理系统,系统包含管理员、技师、用户角色,功能如下: 管理员:用户管理;服务项目;技师管理;房间管理;预约管理&#x…

Java面试之Happens-Before原则

此篇接上一篇的Java面试之volatile关键字。 首先,这是Java语言中的一个“先行发生”(Happens-Before)的原则。是判断数据是否存在竞争,线程是否安全的非常有用的手段,也是Java内存模型中定义的两项操作之间的偏序关系。 其次,Happ…

TensorFlow深度学习实战(1)——神经网络与模型训练过程详解

TensorFlow深度学习实战(1)——神经网络与模型训练过程详解 0. 前言1. 神经网络基础1.1 神经网络简介1.2 神经网络的训练1.3 神经网络的应用 2. 从零开始构建前向传播2.1 计算隐藏层节点值2.2 应用激活函数2.3 计算输出层值2.4 计算损失值2.4.1 在连续变…

C++鼠标轨迹算法(鼠标轨迹模拟真人移动)

一.简介 鼠标轨迹算法是一种模拟人类鼠标操作的程序,它能够模拟出自然而真实的鼠标移动路径。 鼠标轨迹算法的底层实现采用C/C语言,原因在于C/C提供了高性能的执行能力和直接访问操作系统底层资源的能力。 鼠标轨迹算法具有以下优势: 模拟…

Java从入门到工作2 - IDEA

2.1、项目启动 从git获取到项目代码后,用idea打开。 安装依赖完成Marven/JDK等配置检查数据库配置启动相关服务 安装依赖 如果个别依赖从私服下载不了,可以去maven官网下载补充。 如果run时提示程序包xx不存在,在项目目录右键Marven->Re…

【AI知识】过拟合、欠拟合和正则化

一句话总结: 过拟合和欠拟合是机器学习中的两个相对的概念,正则化是用于解决过拟合的方法。 1. 欠拟合: 指模型在训练数据上表现不佳,不能充分捕捉数据的潜在规律,导致在训练集和测试集上的误差都很高。欠拟合意味着模…

汽车升级到底应不应该设置“可取消“功能

最近,汽车OTA(Over-the-Air)升级频频成为车主讨论的热点。有些车主反映,一些升级增加了实用功能,而另一些却让体验变得复杂甚至带来不便。于是,大家不禁发问:汽车升级功能究竟应不应该允许“可取…

优选算法——分治(快排)

1. 颜色分类 题目链接:75. 颜色分类 - 力扣(LeetCode) 题目展示: 题目分析:本题其实就要将数组最终分成3块儿,这也是后面快排的优化思路,具体大家来看下图。 这里我们上来先定义了3个指针&…

[Maven]下载安装、配置与简介

很多框架的下载使用的流程和思路是差不多的,这里以maven做详细介绍。 下载安装与配置变量 下载 首先,我们要使用maven,必须先下载它的相关文件。想要下载,我们可以直接搜索maven。找到它的官网。这里不绕弯子,直接给出…

Maven 安装配置(详细教程)

文章目录 一、Maven 简介二、下载 Maven三、配置 Maven3.1 配置环境变量3.2 Maven 配置3.3 IDEA 配置 四、结语 一、Maven 简介 Maven 是一个基于项目对象模型(POM)的项目管理和自动化构建工具。它主要服务于 Java 平台,但也支持其他编程语言…

【AI知识】人工智能、机器学习、深度学习的概念与联系

下图来自博客 机器学习和深度学习概念入门 ,图中可明显看到人工智能、机器学习、深度学习三个概念的包含关系,下面简单介绍一下这三个概念已经它们之间的联系。 1. 人工智能(Artificial Intelligence,AI) 概念&#x…

BUUCTF Pwn bjdctf_2020_babystack2 题解

1.下载 checksec 64位 拖入IDA64 定位到main函数 以及后门函数 发现read需要读取输入——nbytes的数字来决定长度 同时nbytes是size_t类型 也就是无符号整型的 所以想到整数溢出漏洞 将nbytes设置为-1就会回绕,变成超大整数 从而实现栈溢出漏洞 exp&#xff1a…

微服务-01【续】

1.OpenFeign 上篇文章我们利用Nacos实现了服务的治理,利用利用RestTemplate实现了服务的远程调用。但是远程调用的代码太复杂了: 而且这种调用方式,与原本的本地方法调用差异太大,编程时的体验也不统一,一会儿远程调用…

中电金信携手中远海科,共启贸易金融数智新篇章

在数智化转型成为驱动经济社会高质量发展的新引擎背景下,“数智方案”栏目聚焦金融等国计民生重点行业场景,依托中电金信“源启筑基咨询引领应用重构”的产品及服务体系,输出市场洞察和行业解决方案、应用案例,旨在全面推动行业IT…

【前端】React快速构建登陆注册前后端全栈

近期更新完毕,建议关注、收藏! 目录 快速入门 快速入门 前提:安装npm #npm install react react-dom conda install nodejs npm install create-react-app cd my-app#切换到项目文件夹 npm install npm i web-vitals --save-dev #如果上述…