Paradigm.ORM.Data
5.0.0
dotnet add package Paradigm.ORM.Data --version 5.0.0
NuGet\Install-Package Paradigm.ORM.Data -Version 5.0.0
<PackageReference Include="Paradigm.ORM.Data" Version="5.0.0" />
paket add Paradigm.ORM.Data --version 5.0.0
#r "nuget: Paradigm.ORM.Data, 5.0.0"
// Install Paradigm.ORM.Data as a Cake Addin #addin nuget:?package=Paradigm.ORM.Data&version=5.0.0 // Install Paradigm.ORM.Data as a Cake Tool #tool nuget:?package=Paradigm.ORM.Data&version=5.0.0
Paradigm.ORM
.NET Core ORM with dbfirst support, and code scaffolding features. This ORM supports different database sources. You can find more information here.
Nuget Packages
Self Contained Deploy (SCD)
Bellow you can find portable versions for all major OSs. If you are planning to use the tools in several projects, we recommend to add the SCD folder to your PATH.
Tool | OS | Zip File |
---|---|---|
DbFirst | Windows x86 | Download |
DbFirst | Windows x64 | Download |
DbFirst | Linux x64 | Download |
DbFirst | OSX x64 | Download |
DbPublisher | Windows x86 | Download |
DbPublisher | Windows x64 | Download |
DbPublisher | Linux x64 | Download |
DbPublisher | OSX x64 | Download |
DataExport | Windows x86 | Download |
DataExport | Windows x64 | Download |
DataExport | Linux x64 | Download |
DataExport | OSX x64 | Download |
Running the tests
We are working to automate the test suite, but currently, if you want to run the tests, you can create the test databases by
going to the directory ./build/docker/
and run docker compose:
$ cd ./build/docker
$ docker-compose up -d
You'll create 4 databases, one for each connection, that will be available in your localhost on the default ports:
- mysql
3306
- mssql
1433
- pgsql
5432
- scylla (cassandra)
9042
Once the docker compose provisioned the containers, you'll need to wait a couple of minutes depending on your machine, while each container starts the database and run the initial scripts. If you run the tests just after the docker-compose up, you'll get a lot of timeouts or errors.
After running the tests, you can shutdown the containers by:
$ docker-compose down
Important: Sometimes mysql can fail to setup the password and privileges. If that happens remove the container and do a docker-compose up -d
again.
Change log
Version 5.0.0
:
- Changed .NET Standard libraries to .NET 8.0.
- Updated dependencies to latest versions.
- Migrated SQL Server connector to use
Microsoft.Data.SqlClient
vsSystem.Data.SqlClient
. This will bring a lot of new security options to connect to Azure Entra ID, and a lot of security fixes and validations.IMPORTANT: This is a breaking change. If you were using the SqlServer connector, your connection strings will probably require some updates, to use either one of several options provided within Azure, or to use proper certificates and encryption.
Version 4.0.1
:
- Updated dependencies to latest versions.
- Updated the pgsql connector, and enabled a compatibility mode for function calls.
- NEW: The DbPublisher will accept reading the connection string from an environment variable to improve source code security. You can use the environment variable
Paradigm_ORM_ConnectionString
Paradigm_ORM_ConnectionString="Server=127.0.0.1;User=sa;Password=Paradigm_Test_1234;Connection Timeout=3600"
Version 4.0.0
:
- Updated projects to .net 7.0.
- Updated dependencies to latest versions.
- Updated how the scylla docker db is created, and tests executed.
- NEW: Added a new
#go
directive toDbPublisher
to allow multiple commands in one file. The application will separate the commands and execute individually. - NEW: DbPublisher will now exit with a non-zero value when errors are found during the process to allow for CI tests.
Version 3.0.0
:
- Updated projects to .net6.0.
- Updated dependencies to latest versions.
- Updated tests to utilize new features.
- Due to breaking changes on PostgreSQL, a temporal fix has been added to the connection to support old date formats, see more here and here.
Version 2.6.4
- Added a new feature to the
dbpublisher
tool to ignore script errors on execution. This only works while executing scripts, but the parameter will be dropped and ignored for file generation. To ignore the errors produced by a script, add the line#ignore-errors
to your script file, and theScriptBuilder
will configure the script to ignore errors, and will remove that line from the content. This can come in handy for cassandra and scylla, because there's no way of checking before altering a table, and subsequent executions will produce errors if you are usingdbpublisher
for incremental builds.
Version 2.6.3
- Updated cassandra connector to cache active connections by connection string instead of disposing them. When working with multiple threads, the ORM used to create multiple connections, and dispose them after finalization.
Disposing the active connection also disposed the internal cluster and session, producing unintended side effects inside the datastax driver: A lot of leaked references being captured and not collected by GC.
With this new change, we expect to provide a better performance and memory footprint overall.
If you need to clean all the static connections, you can still call to
CqlConnectionManager.ClearConnections()
but note that clearing the connections won't free everything, due to how the datastax driver caches internal pool objects. - Updated nuget dependencies.
Version 2.6.2
- Moved the open check to a more generic method.
Version 2.6.1
- Updated connector to open connection before creating a transaction, if the connection was closed.
- Added tests for transactions.
Version 2.6.0
- Updated connector specific commands to check if the connection has been opened before executing.
- Removed open check from extensions.
- Updated nuget dependencies.
Version 2.5.0
- Due to a constraint with Tuples, now the reader stored procedure must return a Tuple<List<TResult8>> for the last parameter.
- Updated code to use declarative using.
- Updated code to use async when possible in some cases that was calling the sync version.
Version 2.4.0
- Updated nuget dependencies.
- Updated project version to use .NET Standard 2.1.
- Updated console projects to use .NET 5.0.
- Fixed tests to use the latest fluent assertion extensions.
- Added docker files to create test databases.
- Merged pull request from @bgrainger to update MySql connector to the last version.
Version 2.3.2
- Updated nuget dependencies.
- Added logging provider and a default logger to log commands and command errors.
Version 2.3.1
- Added more tests for composite partition keys for cassandra/scylla connector.
- Disabled the batch delete for cassandra/scylla due to cql constrains.
- Fixed delete query for cassandra/scylla connector.
- Updated nuget dependencies.
Version 2.3.0
- Upgraded the cql schema provider, to use the newer scylla "system_schema" keyspace.
- Updated nuget dependencies.
- Updated test cases.
Version 2.2.4
- Added visual basic tests.
- Updated nuget dependencies.
- Fixed a couple of bugs found with the vb tests.
Version 2.2.3
- Added new DatabaseCommandException thrown when executing database commands. The DatabaseCommandException contains a reference to the executing command, allowing for a better debugging experience. Use Command.CommandText to observe the sql or cql query being executed. Use Command.Parameters to observe the parameters bound to the query.
- Fixed a bug in Cassandra connector not adding a parameter in one of the AddParameters methods.
- Fixed a bug in CustomQuery sync execution not updated the command text after parameter replacement.
- Improved and updated tests.
Version 2.2.2
- Removed mandatory data type in ColumnAttribute. The orm will choose the default column types for each database type.
- Changed how the CommandBatch replace parameter names, to prevent name collision.
- Added tests for the command batch name replacement.
- Changed how select parameters are replaced, from @Index to @pIndex or :pIndex, depending on the database parameter naming conventions.
- Updated NuGet dependencies.
Version 2.2.1
- Added a cache service for descriptors all over the orm, to prevent tons of small objects filling the heap.
- Removed constructors receiving descriptors. Now all the ORM classes should refer to the cache for descriptors.
- Descriptor constructors are now internal and can not be instantiated outside the ORM.
Version 2.2.0
- Refactor command handling to allow parallel execution of the ORM without conflicting with some of the connectors. The orm does not cache a command inside the command builder any more.
- Refactor command builders and moved shared functionality to the core classes, and removed the duplication from the client implementations. Now will be even easier to implement new clients.
- Moved base protected methods from the CommandBuilderBase to the ICommandFormatProvider and added a new base CommandFormatProviderBase with shared behavior for all the different format providers.
- Removed IDisposable interface from most of the ORM core classes. The most notable are:
- Database access
- Query
- Custom query
- All the stored procedure types
- Schema Provider
- Removed extension methods for the IDatabaseConnector not used any more.
Version 2.1.7
- Changed how the DatabaseAccess classes utilize the BatchManager to be thread safe.
Version 2.1.6
- Updated Paradigm.Core and other dependencies.
- Published new versions for the tools.
Version 2.1.5
- Removed a dependency over generic entities that needed a parameterless constructor in all the solution.
Version 2.1.4
- Removed a dependency over generic entities that needed a parameterless constructor.
Version 2.1.3
- Added new constructor to
DatabaseReaderMapper
to allow set both the service provider and the database connector. This will allow multi-tenancy support using the dbfirst generated code. - Added new constructors to all the stored procedure types for the same reason as the previous point.
- Added missing ValueConverter inside the database reader value provider.
Version 2.1.2
- Changed the database reader mappers to work with the
IServiceProvider
class. Now, will try to instantiate the entities with the service provider first, and if the service provider can't, will use the activator to create a new instance. This will allow the Paradigm.Services framework to fully delegate the instancing to DI allowing better DDD.
Version 2.1.1
- Fixed a problem in cassandra connector where the schema provider can not guess the column type when the column is a clustering key with order applied to it.
- Made the modifications to the tests to test the above problem.
Version 2.1.0
- Added a new Cassandra connector.
This new connector allows to work against Apache Cassandra o ScyllaDB. There are some limitations imposed by the
DataStax connector, and other imposed by the orm, but for most cases will be just fine.
Warning: The ORM will work with column families that mimic sql tables, aka. without lists, maps, or other not standard relational databases. Even if Cassandra does not supports joins, the ORM allows to create virtual foreign keys between tables and create navigation properties from it.
- Data Export, DbFirst and DbPublisher can work now against Cassandra and ScyllaDB.
- In all the configuration files, now the Database Type changed to Upper Camel Case syntax, the database types are:
- SqlServer,
- MySql,
- PostgreSql,
- Cassandra
- Updated MySql Connector version.
Version 2.0.1
- Updated Paradigm.Core to version
2.0.1
.
Version 2.0.0
- Updated .net core from version 1 to version 2.
Version 1.0.0
- Uploaded first version of the Paradigm ORM.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | 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. |
-
net8.0
- Microsoft.Extensions.DependencyInjection (>= 8.0.0)
- System.Data.Common (>= 4.3.0)
NuGet packages (6)
Showing the top 5 NuGet packages that depend on Paradigm.ORM.Data:
Package | Downloads |
---|---|
Paradigm.Services.Repositories.ORM
Miracle Devs ORM implementation of Paradigm repositories. |
|
Paradigm.Services.WorkingTasks.ORM
This library contains useful classes to work with task units that needs to work with transactions, and repeat the work if couldn't be completed. Contains specific implementations for Paradigm ORM. |
|
Paradigm.ORM.Data.MySql
Paradigm ORM MySql Connector library. |
|
Paradigm.ORM.Data.Cassandra
Paradigm ORM Cassandra Connector library. |
|
Paradigm.ORM.Data.PostgreSql
Paradigm ORM Posgre Connector library. |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
5.0.0 | 319 | 3/14/2024 |
4.0.1 | 433 | 12/5/2023 |
4.0.0 | 289 | 11/9/2023 |
3.0.0 | 3,924 | 3/10/2022 |
2.6.4 | 1,649 | 7/7/2021 |
2.6.3 | 2,555 | 6/30/2021 |
2.6.2 | 2,478 | 2/25/2021 |
2.6.1 | 1,019 | 2/25/2021 |
2.6.0 | 1,022 | 2/22/2021 |
2.5.0 | 1,225 | 1/25/2021 |
2.4.0 | 3,925 | 12/14/2020 |
2.3.2 | 1,359 | 8/30/2019 |
2.3.1 | 2,672 | 10/19/2018 |
2.3.0 | 2,413 | 10/12/2018 |
2.2.4 | 2,859 | 2/7/2018 |
2.2.3 | 3,734 | 1/2/2018 |
2.2.2 | 2,747 | 12/29/2017 |
2.2.1 | 2,580 | 11/30/2017 |
2.2.0 | 2,569 | 11/29/2017 |
2.1.7 | 1,699 | 11/27/2017 |
2.1.6 | 3,493 | 11/15/2017 |
2.1.5 | 2,566 | 11/14/2017 |
2.1.4 | 1,676 | 11/14/2017 |
2.1.3 | 6,311 | 11/7/2017 |
2.1.2 | 4,366 | 11/4/2017 |
2.1.1 | 2,246 | 10/30/2017 |
2.1.0 | 1,669 | 10/24/2017 |
2.0.1 | 3,517 | 10/11/2017 |
2.0.0 | 2,272 | 10/10/2017 |
1.0.0 | 2,165 | 10/10/2017 |