当前位置: 首页 > news >正文

【C#-sqlSugar-sqlite】在Windows从源码编译构建System.Data.SQLite.dll的方法

sqlSugar从git上拉下来就能编译、跑测试,非常方便。但是,如果你想了解原理,从源码编译System.Data.SQLite是必不可少的,否则的话open()这种地方调试都进不去。

那么如何编译System.Data.SQLite呢?

它使用Fossil,你要先创建两个文件夹D:\SQLiteRepositories和D:\SQLiteSource

然后类似这样

fossil clone https://system.data.sqlite.org/ D:\SQLiteRepositories\sds.fossil

输出类似这样就成功了

Round-trips: 76 Artifacts sent: 0 received: 31804
Clone done, wire bytes sent: 20466 received: 512407584 remote: 194.195.208.62
Rebuilding repository meta-data…
100.0% complete…
Extra delta compression… 8 deltas save 22,850 bytes
Vacuuming the database…
project-id: xxx
server-id: xxx

这样拉下来是单个文件,你还需要这样

cd D:\SQLiteSource
fossil open D:\SQLiteRepositories\sds.fossil

这样才相当于git clone了。
切到跟自己的sqlSugar兼容的版本,比如

fossil update release-1.0.102.0

然后编译。编译时会有一些坑,比如vs版本问题,强制签名什么的,我也不是很懂,总之把我能跑的贴在这里。

cd d:\SQLiteSource; C:\Windows\Microsoft.NET\Framework64\v4.0.30319\MSBuild.exe System.Data.SQLite\System.Data.SQLite.2015.csproj /p:Configuration=Debug /p:Platform=Win32 /p:SignAssembly=false /p:DelaySign=false Start-Process -FilePath 'C:\Program Files\Microsoft Visual Studio\2022\Community\MSBuild\Current\Bin\MSBuild.exe' -ArgumentList 'SQLite.Interop\SQLite.Interop.2015.vcxproj', '/p:Configuration=Debug', '/p:Platform=Win32' -Wait -NoNewWindow Start-Process -FilePath 'C:\Program Files\Microsoft Visual Studio\2022\Community\MSBuild\Current\Bin\MSBuild.exe' -ArgumentList 'SQLite.Interop\SQLite.Interop.2015.vcxproj', '/p:Configuration=DebugNativeOnly', '/p:Platform=Win32' -Wait -NoNewWindow 

最后,把输出的System.Data.SQLite.dll等文件粘贴到Src\Asp.Net\SqlSugar\References\下面,把旧的命名为System.Data.SQLite.dll.bak就可以了。

再次在open()按F11,就可以直接跳转到D:\SQLiteSource下的那些源文件里。

实际上,微软的C#/.NET提供了一个虚函数套,叫做System.Data(里面包含抽象类DbConnection等等),希望各个数据库都可以适配它,这样大家用C#的时候就会比较统一,那么果不其然sqlite官方真的就适配了它。再然后,sqlSugar.sqlite就是直接面向已经适配了System.Data的sqlite-C#进行编程。

http://www.dtcms.com/a/596445.html

相关文章:

  • 【WPF】WrapPanel的用法
  • wpf 控件中Margin属性如何设置绑定?
  • 【管综】考研199管理类联考真题试卷及答案解析PDF电子版(2009-2025年)
  • UDP/TCP接收/转发/广播服务端
  • WPF 获取鼠标相对于控件的坐标信息,控制控件锚点放缩
  • 面试题—linux
  • 福田皇岗社区做网站网页制作怎么收费
  • 236. Java 集合 - 使用索引访问 List 元素
  • 天河网站建设哪家强华为企业邮箱
  • 基于Java的电影管理系统的设计与实现
  • C#初级面试题5、拆箱和装箱
  • 如何判断企业是否需要 IAM ?数字化转型中的权限治理自测
  • CSP-J教程——第一阶段——第六课:程序流程控制 - 循环结构(一)for循环
  • 【C++基础与提高】第二章:C++数据类型系统——构建程序的基础砖石
  • 【每天一个知识点】CAG:Context-Augmented Generation
  • 《Linux系统编程之系统导论》【冯诺依曼体系结构 + 操作系统基本概述】
  • 第23天python内容
  • 5.2、Python-字符串的编码和解码
  • 美容院网站源码网站流量下降的原因
  • FreeRTOS 学习:(十七)“外部中断”和“内核中断”的差异,引入 FreeRTOS 中断管理
  • CodeBuddy AI IDE :Skills 模式
  • 大模型学习计划(按周规划)
  • 绥中网站建设分类信息网网站500
  • k8s 部署MySQL 数据持久化
  • Quantinuum 发布新型量子计算机“Helios“
  • ubuntu/kali安装k8s
  • 开源 Objective-C IOS 应用开发(二)Xcode安装
  • 【论文阅读】Gradient Guidance for Diffusion Models:An Optimization Perspective
  • WebSocket调试工具(html),用于调试WebSocket链接是否畅通
  • Springboot3.X+security6.5+jdk21