.Net|.Net ORM 访问 Firebird 数据库的方法
目录
- 前言
- 1、安装环境
- 2、创建项目
- 3、创建实体模型
- 4、初始化 ORM
- 5、插入数据
- 6、更新数据
- 7、查询数据
- 8、删除数据
- 结语
前言 Firebird 是一个跨平台的关系数据库系统,目前能够运行在 Windows、linux 和各种 Unix 操作系统上,提供了大部分 SQL-99 标准的功能。它既能作为多用户环境下的数据库服务器运行,也提供嵌入式数据库的实现。
Firebird 脱胎于 Borland 公司的开源版数据库 Interbase6.0,是一个完全非商业化的产品,用 C 和 C++ 开发。由于与 interbase 的血缘关系,大部分 interbase 的开发工具可以直接应用到 Firebird 开发中。Firebird 使用 Mozilla Public License v.1.1 许可证发行。
FreeSql 支持 Firebird 嵌入式数据库,与 Sqlite 一样属于本地数据库,并且可靠性强于 sqlite,数据库文件不过 10兆 大小。
1、安装环境 数据库环境:Firebird (嵌入式版本)
下载地址:https://firebirdsql.org/en/server-packages/
.NET版本:.net6.0
下载地址:https://dotnet.microsoft.com/learn/dotnet/hello-world-tutorial/install
开发机器 :windows 10
2、创建项目 我们以 console 类型项目试验 插入、删除、更新、查询 等功能,创建控制台项目,使用命令:
dotnet new console
文章图片
dotnet add package FreeSql.Provider.Firebird
dotnet add package FreeSql.Repository
文章图片
3、创建实体模型
using System; using FreeSql.DataAnnotations; [Table(Name = "USER_FIREBIRD")]public class User{[Column(IsIdentity = true)]public long Id { get; set; }public string UserName { get; set; }public string PassWord { get; set; }public DateTime CreateTime { get; set; }}
4、初始化 ORM
static IFreeSql fsql = new FreeSql.FreeSqlBuilder().UseConnectionString(FreeSql.DataType.Firebird, @"database=localhost:D:\fbdata\EXAMPLES.fdb; user=sysdba; password=123456; max pool size=3").UseMonitorCommand(cmd => Trace.WriteLine($"线程:{cmd.CommandText}\r\n")).UseAutoSyncStructure(true) //自动创建、迁移实体表结构.UseNameConvert(NameConvertType.ToUpper).Build();
5、插入数据
var repo = fsql.GetRepository(); var user = new User { UserName = "gaussdb1", PassWord = "123" }; repo.Insert(user);
文章图片
首次访问自动创建表
var users = new []{new User { UserName = "gaussdb2", PassWord = "1234" },new User { UserName = "gaussdb3", PassWord = "12345" },new User { UserName = "gaussdb4", PassWord = "123456" }}; repo.Insert(users); //批量插入
文章图片
由于主键 ID 是自增,此次批量插入会拆成多次执行,并将值回填 users[0..2].Id
6、更新数据
user.PassWord = "123123"; repo.Update(user);
文章图片
只更新有变化的属性(字段)
7、查询数据
var one = fsql.Select(1).First(); //查询一条数据var list = fsql.Select ().Where(a => a.UserName.StartsWith("gaussdb")).ToList();
文章图片
8、删除数据
fsql.Delete(1).ExecuteAffrows(); fsql.Delete ().Where(a => a.UserName.StartsWith("gaussdb")).ExecuteAffrows();
结语 这篇文章简单介绍了在 .net6.0 环境中使用 FreeSql 对 Firebird 数据库的访问,目前 FreeSql 还支持 .net framework 4.0 和 xamarin 平台上使用。
除了 增删查改,FreeSql 还支持很多功能,就不一一演示,一篇文章介绍不完。
FreeSql 是 .NETCore/.NetFramework/Xamarin 平台下的 ORM 开源项目,支持 SqlServer/MySql/PostgreSQL/Oracle/Sqlite/Firebird/Clickhouse/达梦/神通/金仓/翰高,还有华为GaussDB数据库,未来还会接入更多的国产数据库支持。
源码地址:https://github.com/2881099/FreeSql
【.Net|.Net ORM 访问 Firebird 数据库的方法】到此这篇关于.Net ORM 访问 Firebird 数据库的文章就介绍到这了,更多相关.NetFirebird 数据库内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- ASP.NET轻量级MVC框架Nancy的基本用法
- vue中formdata传值给后台时参数为空的问题
- webstorm配置vue.js开发(模板|webstorm配置vue.js开发(模板 代码风格 Macro定制)
- 【SIGIR 2022】面向长代码序列的Transformer模型优化方法,提升长代码场景性能
- html 玫瑰图 ,拿来直接用,无需下载js包以把js包改为远程访问
- OpenGL Transformation(openGL zh)
- Performance measurements for hypervisors on embedded ARM processors
- Identity|Identity Server 4客户端认证控制访问API
- security|spring security入门--从数据库读取数据实现用户登录访问简单示例四
- 从傅里叶级数(Fourier|从傅里叶级数(Fourier series)到离散傅里叶变换(Discrete Fourier transform)