.NET操作 Access (MSAccess)

注意:新项目推荐 Sqlite ,Access需要注意的东西太多了,比如OFFICE版本,是X86还是X64

连接字符串

cs 复制代码
Provider=Microsoft.ACE.OleDB.15.0;Data Source="+GetCurrentProjectPath+"\\test.accdb

//不同的office版本 连接字符串有差异

源码下载

下载: GitHub - DotNetNext/SqlSugar: .Net aot ORM Fastest ORM Simple Easy Sqlite orm Oracle ORM Mysql Orm postgresql ORm SqlServer oRm 达梦 ORM 人大金仓 ORM 神通ORM C# ORM , C# ORM .NET ORM NET5 ORM .NET6 ORM ClickHouse orm QuestDb ,TDengine ORM,OceanBase orm,GaussDB orm ,Tidb orm Object/Relational Mapping

注意:.NET CORE下要发布到X86文件夹下

NUGET安装

|--------------------------|-------------------------------------|
| .NET Framework | .NET CORE & .NET 5 & .NET 6 ....+ |
| SqlSugar SqlSugar.Access | SqlSugarCore SqlSugar.AccessCore |

代码

cs 复制代码
DbType=DbType.Access 

//不要使用Any Cpu Office安装的是X86就用X86 和office版本一样

注意:.NET CORE下要发布到X86文件夹下

cs 复制代码
//程序启动时加入
InstanceFactory.CustomAssemblies =
new System.Reflection.Assembly[] { typeof(AccessProvider).Assembly };

//创建db对象
var db=new SqlSugarClient(new ConnectionConfig()
            {
                DbType = SqlSugar.DbType.Access, 
                ConnectionString = Config.ConnectionString,
                IsAutoCloseConnection = true 
            });

//查询表的所有
var list = Db.Queryable<Student>().ToList();
 
//插入
Db.Insertable(new Student() { SchoolId = 1, Name = "jack" }).ExecuteCommand();
 
//更新
Db.Updateable(new Student() { Id = 1, SchoolId = 2, Name = "jack2" }).ExecuteCommand();
 
//删除
Db.Deleteable<Student>().Where(it => it.Id == 1).ExecuteCommand();

Access分页

Access在联表分页 如果存在OrderBy是不支持的

3种解决方案:

1、使用内存分页 .ToList().Skip(1).Take()

2、去掉OrderBy

3、使用子查询 (最新版版本才支持)

三表以上的JOIN操作

默认Access只支持2个表的联表查询,我们可以通过嵌套查询实现3表查询

cs 复制代码
 var getAll = db.Queryable<Order>()

                .LeftJoin<Order>((x, y) => x.Id == y.Id)

                //可以这儿加Select

                .MergeTable()//通过mergetable合并成一个表在进行JOIN

                .LeftJoin<Order>((x, y) => x.Id == y.Id)

                .ToList();
相关推荐
荔枝吻4 小时前
【AI总结】C#与.NET:一段跨越20年的命名纠葛与共生传奇
开发语言·c#·.net
波波0075 小时前
每日一题:请解释 .NET中的内存模型是什么
开发语言·c#·.net
荔枝吻6 小时前
【AI总结】【技术选型】 .NET Framework 打包指南:5种主流免费单EXE安装方案对比与推荐
.net·.net framework
light blue bird7 小时前
多Tab页签高索引组轴可视化图表
jvm·数据库·.net·桌面端·ai大数据
波波0077 小时前
2026 .NET 跨平台桌面开发选型指南:Avalonia vs Uno vs Eto
.net
武藤一雄16 小时前
从零构建C# OOP 知识体系
windows·microsoft·c#·.net·.netcore·oop
唐青枫17 小时前
C#.NET ConcurrentStack<T> 深入解析:无锁栈原理、LIFO 语义与使用边界
c#·.net
PascalMing1 天前
openEuler 25.09 安装 .NET 10(二进制 tar.gz 包)教程
.net·openeuler
我是唐青枫1 天前
C#.NET ReaderWriterLockSlim 深入解析:读写锁原理、升级锁与使用边界
开发语言·c#·.net
学以智用1 天前
.NET Core 日志与异常管理 完整实战指南
后端·.net