【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#进行编程。

相关推荐
加号35 小时前
【C#】 串口通信技术深度解析及实现
开发语言·c#
无风听海7 小时前
C# 隐式转换深度解析
java·开发语言·c#
LateFrames7 小时前
520 - 如何说晚安 (WPF)
c#·wpf·浪漫·ui体验
魔法阵维护师8 小时前
从零开发游戏需要学习的c#模块,第十四章(保存和加载)
学习·游戏·c#
木心术111 小时前
Windows系统下MySQL与AI工具集成方案:数据存储与调用实践
人工智能·windows·mysql
Xin_ye1008612 小时前
C# 零基础到精通教程 - 第十一章:LINQ——语言集成查询
开发语言·c#
Xin_ye1008612 小时前
C# 零基础到精通教程 - 第十章:集合与泛型——高效管理数据
开发语言·c#
beyond阿亮12 小时前
Hermes Agent快速接入 QQ 完整教程|QQ聊天使用AI智能体
人工智能·windows·ai·openclaw·hermes agent
DONSEE广东东信智能读卡器13 小时前
用PowerShell实现Windows 本地 WSS/HTTPS 自签名证书配置方法
windows·网络协议·https·powershell·身份证阅读器
魔法阵维护师14 小时前
从零开发游戏需要学习的c#模块,第十一章(rpg小游戏入门,上篇,地图与移动)
学习·游戏·c#