Funcular.Data.Orm 2.3.2

There is a newer version of this package available.
See the version list below for details.
dotnet add package Funcular.Data.Orm --version 2.3.2
                    
NuGet\Install-Package Funcular.Data.Orm -Version 2.3.2
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Funcular.Data.Orm" Version="2.3.2" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Funcular.Data.Orm" Version="2.3.2" />
                    
Directory.Packages.props
<PackageReference Include="Funcular.Data.Orm" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Funcular.Data.Orm --version 2.3.2
                    
#r "nuget: Funcular.Data.Orm, 2.3.2"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package Funcular.Data.Orm@2.3.2
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Funcular.Data.Orm&version=2.3.2
                    
Install as a Cake Addin
#tool nuget:?package=Funcular.Data.Orm&version=2.3.2
                    
Install as a Cake Tool

Recent Changes

  • v2.3.2: Published package icon update.
  • v2.3.1: Fixed parameter naming in chained Where clauses to prevent SQL errors.
  • v2.1.0: Added support for MSSQL reserved words in table/column names (e.g., [User], [Order]).
  • v2.0.0: Major release. Breaking change to Query<T>(predicate), safety enhancements for Deletes, chained Where clauses.
  • v1.6.0: Fix for closure predicates, added CI/CD.

Funcular / Funky ORM: a speedy, lambda-powered .NET ORM designed for MSSQL

Funcular logo

NuGet Downloads CI status Tests License: MIT

Overview

Welcome to Funcular ORM (aka FunkyORM), the micro-ORM designed for developers who want the speed of a micro-ORM with the simplicity and type safety of LINQ.

If you're tired of wrestling with raw SQL strings (Dapper) or debugging generated queries from a heavy framework (Entity Framework), FunkyORM is your sweet spot.

Why FunkyORM?

  • Instant Lambda Queries: Write C# lambda expressions, get optimized SQL.
  • Performance: Outperforms EF Core in single-row writes and matches it in reads. (See our Usage Guide for benchmarks).
  • Zero Configuration: No DbContext, no mapping files. Just POCOs and a connection string.
  • Safe: All queries are parameterized to prevent SQL injection.
  • Mass Delete Prevention: Includes safeguards against accidental "delete all" operations (e.g., blocking 1=1), though this does not guarantee prevention of all crafty circumventions.
  • Convention over Configuration: Sensible defaults for primary key naming conventions (like id, tablename_id, or TableNameId) mean less boilerplate and more productivity.
  • Cached Reflection: Funcular ORM caches reflection results to minimize overhead and maximize performance.

Getting Started

1. Installation

Add the package to your project via the .NET CLI:

dotnet add package Funcular.Data.Orm

2. Initialization

Create an instance of SqlServerOrmDataProvider. You can do this once and register it as a singleton in your DI container, or create it as needed.

using Funcular.Data.Orm.SqlServer;

// Initialize with your connection string
var connectionString = "Server=.;Database=MyDb;Integrated Security=True;TrustServerCertificate=True;";
var provider = new SqlServerOrmDataProvider(connectionString);

3. Define Your Data Models

FunkyORM is designed to keep your code clean. You usually don't need attributes.

By default, we map the intersection of your class properties and the database table columns.

  • If your class has a FullName property but the table doesn't, we ignore it. No [NotMapped] needed.
  • If the table has a CreatedDate column but your class doesn't, we ignore it. No errors.

We also infer table names and primary keys automatically.

// No attributes needed!
// Maps to table 'Person', 'Persons', 'PERSON', etc.
public class Person
{
    // Automatically detected as Primary Key
    public int Id { get; set; }
    
    // Maps to column 'FirstName', 'first_name', etc.
    public string FirstName { get; set; }
    public string LastName { get; set; }
    public int Age { get; set; }
    
    // Ignored automatically if no matching column exists
    public string FullName => $"{FirstName} {LastName}";
}

If you need to deviate from conventions (e.g., mapping Person class to tbl_Users), you can still use standard System.ComponentModel.DataAnnotations:

using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;

[Table("tbl_Users")]
public class Person
{
    [Key]
    [Column("user_id")]
    public int Id { get; set; }
    // ...
}

4. Start Querying

// Insert a new record
var newPerson = new Person { FirstName = "Jane", LastName = "Doe", Age = 25 };
provider.Insert(newPerson);

// Get by ID
var person = provider.Get<Person>(1);

// Complex Querying with LINQ
var adults = provider.Query<Person>()
    .Where(p => p.Age >= 18)
    .Where(p => p.LastName.StartsWith("D"))
    .OrderByDescending(p => p.Age)
    .Take(10)
    .ToList();

Documentation

For detailed usage examples, performance benchmarks, and a comparison with other ORMs, please see our Usage Guide.

Comparison: FunkyORM vs. The World

Feature Entity Framework Dapper FunkyORM
Setup Heavy (DbContext, Config) Light Lightest
Query Style LINQ SQL Strings LINQ
Performance Good (if tuned) Excellent Excellent
Mapping Strict (needs config) Manual/Strict Forgiving/Auto
SQL Injection Protected Manual Parameterization Protected
Vibe Enterprise Java Hardcore Metal Cool Jazz
Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 is compatible.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
3.0.1 86 2/6/2026
3.0.1-beta1 272 12/16/2025
2.3.2 435 12/11/2025
2.0.0 680 12/3/2025
1.6.0 680 12/2/2025
1.5.2 174 10/17/2025
1.5.0 187 10/16/2025
1.1.1 184 10/14/2025
1.1.0 201 9/4/2025
1.0.0 224 8/30/2025
0.9.2 239 8/27/2025
Loading failed