Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/jchristn/watsonorm

WatsonORM is a lightweight and easy to use object-relational mapper (ORM) in C# for .NET Core.
https://github.com/jchristn/watsonorm

dotnet mysql mysql-database orm postgres postgresql postgresql-database repository-pattern sqlite sqlserver

Last synced: 4 days ago
JSON representation

WatsonORM is a lightweight and easy to use object-relational mapper (ORM) in C# for .NET Core.

Awesome Lists containing this project

README

        

![alt tag](https://github.com/jchristn/watsonorm/blob/master/assets/watson.ico)

# WatsonORM

| Library | Version | Downloads |
|---|---|---|
| WatsonORM (all supported database types) | [![NuGet Version](https://img.shields.io/nuget/v/WatsonORM.svg?style=flat)](https://www.nuget.org/packages/WatsonORM/) | [![NuGet](https://img.shields.io/nuget/dt/WatsonORM.svg)](https://www.nuget.org/packages/WatsonORM) |
| WatsonORM.Mysql | [![NuGet Version](https://img.shields.io/nuget/v/WatsonORM.Mysql.svg?style=flat)](https://www.nuget.org/packages/WatsonORM.Mysql/) | [![NuGet](https://img.shields.io/nuget/dt/WatsonORM.Mysql.svg)](https://www.nuget.org/packages/WatsonORM.Mysql) |
| WatsonORM.Postgresql | [![NuGet Version](https://img.shields.io/nuget/v/WatsonORM.Postgresql.svg?style=flat)](https://www.nuget.org/packages/WatsonORM.Postgresql/) | [![NuGet](https://img.shields.io/nuget/dt/WatsonORM.Postgresql.svg)](https://www.nuget.org/packages/WatsonORM.Postgresql) |
| WatsonORM.Sqlite | [![NuGet Version](https://img.shields.io/nuget/v/WatsonORM.Sqlite.svg?style=flat)](https://www.nuget.org/packages/WatsonORM.Sqlite/) | [![NuGet](https://img.shields.io/nuget/dt/WatsonORM.Sqlite.svg)](https://www.nuget.org/packages/WatsonORM.Sqlite) |
| WatsonORM.SqlServer | [![NuGet Version](https://img.shields.io/nuget/v/WatsonORM.SqlServer.svg?style=flat)](https://www.nuget.org/packages/WatsonORM.SqlServer/) | [![NuGet](https://img.shields.io/nuget/dt/WatsonORM.SqlServer.svg)](https://www.nuget.org/packages/WatsonORM.SqlServer) |
| WatsonORM.Core | [![NuGet Version](https://img.shields.io/nuget/v/WatsonORM.Core.svg?style=flat)](https://www.nuget.org/packages/WatsonORM.Core/) | [![NuGet](https://img.shields.io/nuget/dt/WatsonORM.Core.svg)](https://www.nuget.org/packages/WatsonORM.Core) |

## Description

WatsonORM is a lightweight and easy to use object-relational mapper (ORM) in C# for .NET Core built on top of DatabaseWrapper. WatsonORM supports Microsoft SQL Server, Mysql, MariaDB, PostgreSQL, and Sqlite databases, both on-premises and in the cloud.

Core features:

- Annotate classes and automatically create database tables
- Quickly create, read, update, or delete database records using your own objects
- Reduce time-to-production and time spent building scaffolding code
- Programmatic table creation and removal

For a sample app exercising this library, refer to the ```Test``` project contained within the solution.

## New in v3.0.x

- Dependency update
- Minor breaking changes
- Async API support
- Better support for updating multiple records

## Special Thanks

We'd like to give special thanks to those who have contributed or helped make the library better!

@Maclay74 @flo2000ace @MacKey-255

## Simple Example

This example uses ```Sqlite```. For ```SqlServer```, ```Mysql```, or ```Postgresql```, you must make sure the database exists. Tables will be automatically created in this example. Refer to the ```Test``` project for a complete example.
```csharp
using ExpressionTree;
using DatabaseWrapper.Core;
using Watson.ORM;
using Watson.ORM.Core;

// Apply attributes to your class
[Table("person")]
public class Person
{
[Column("id", true, DataTypes.Int, false)]
public int Id { get; set; }

[Column("firstname", false, DataTypes.Nvarchar, 64, false)]
public string FirstName { get; set; }

// Parameter-less constructor is required
public Person()
{
}
}

// Initialize
DatabaseSettings settings = new DatabaseSettings("./WatsonORM.db");
WatsonORM orm = new WatsonORM(settings);
orm.InitializeDatabase();
orm.InitializeTable(typeof(Person)); // initialize one table
orm.InitializeTables(new List { typeof(Person) }); // initialize multiple tables

// Insert
Person person = new Person { FirstName = "Joel" };
Person inserted = orm.Insert(person);

// Select
Person selected = orm.SelectByPrimaryKey(1);

// Select all records
List people = orm.SelectMany();

// Select many by column name
Expr e1 = new Expr("id", OperatorEnum.GreaterThan, 0);
people = orm.SelectMany(e1);

// Select many by property
Expr e2 = new Expr(
orm.GetColumnName(nameof(Person.Id)),
DbOperators.GreaterThan,
0);
people = orm.SelectMany(e2);

// Select many by property with pagination
// Retrieve 50 records starting at record number 10
people = orm.SelectMany(10, 50, e2);

// Select many with descending order
ResultOrder[] resultOrder = new ResultOrder[1];
resultOrder[0] = new ResultOrder("id", OrderDirectionEnum.Descending);
people = orm.SelectMany(null, null, e2, resultOrder);

// Update
inserted.FirstName = "Jason";
Person updated = orm.Update(inserted);

// Delete
orm.Delete(updated);
```

## Column Naming

Columns can be named *explicitly* by specifying the colum name in the ```Column``` attribute constructor. Alternatively, constructors that don't include a name can be used, in which case the name of the property will be used as the column name.

Example with explicit naming:
```csharp
[Column("id", true, DataTypes.Int, false)] // column name "id"
public int Id { get; set; }

[Column("firstname", false, DataTypes.Nvarchar, 64, false)] // column name "firstname"
public string FirstName { get; set; }
```

Example without explicit naming:
```csharp
[Column(true, DataTypes.Int, false)] // column name "Id"
public int Id { get; set; }

[Column(DataTypes.Nvarchar, 64, false)] // column name "FirstName"
public string FirstName { get; set; }
```

## Pagination with SelectMany

```SelectMany``` can be paginated by using the method with either signature ```(int? indexStart, int? maxResults, Expr expr)``` or ```(int? indexStart, int? maxResults, Expr expr, ResultOrder[] resultOrder)```. ```indexStart``` is the number of records to skip, and ```maxResults``` is the number of records to retrieve.

Paginated results are always ordered by the primary key column value in ascending order, i.e. ```ORDER BY id ASC``` in the ```Person``` example above.

## Validating One or More Tables

If you wish to determine if there are any errors or warnings associated with a given ```Type```, use either the ```ValidateTable``` or ```ValidateTables``` API:
```csharp
List errors = new List();
List warnings = new List();

// validate a single table
bool success = orm.ValidateTable(typeof(Person), out errors, out warnings);

// validate multiple tables
bool success = orm.ValidateTables(new List
{
typeof(Person),
typeof(Order),
typeof(Inventory)
},
out errors,
out warnings);

if (errors.Count > 0)
foreach (string error in errors) Console.WriteLine(error);

if (warnings.Count > 0)
foreach (string warning in warnings) Console.WriteLine(warning);
```

## Using Sqlite

Sqlite may not work out of the box with .NET Framework. In order to use Sqlite with .NET Framework, you'll need to manually copy the ```runtimes``` folder into your project output directory. This directory is automatically created when building for .NET Core. To get this folder, build the Test.Sqlite project and navigate to the ```bin/[debug||release]/[netcoreapp*||net5.0||net6.0]``` directory. Then copy the runtimes folder into the project output directory of your .NET Framework application.

## Using SQL Server

In order to use pagination with SQL Server, the ```SelectMany``` method containing the ```ResultOrder[] resultOrder``` parameter must be used.

## Using MySQL

While the ```DateTimeOffset``` type can be used in objects, with MySQL the offset is not persisted. It is recommended that you store UTC timestamps using the ```DateTime``` type instead.

## Using MariaDB

Use the MySQL constructor. MySQL constraints apply.

## Version history

Refer to CHANGELOG.md.