Daikoz.SQLWrapper
2.2.0
Prefix Reserved
dotnet add package Daikoz.SQLWrapper --version 2.2.0
NuGet\Install-Package Daikoz.SQLWrapper -Version 2.2.0
<PackageReference Include="Daikoz.SQLWrapper" Version="2.2.0" />
paket add Daikoz.SQLWrapper --version 2.2.0
#r "nuget: Daikoz.SQLWrapper, 2.2.0"
// Install Daikoz.SQLWrapper as a Cake Addin #addin nuget:?package=Daikoz.SQLWrapper&version=2.2.0 // Install Daikoz.SQLWrapper as a Cake Tool #tool nuget:?package=Daikoz.SQLWrapper&version=2.2.0
SQLWrapper makes it easier to create code wrappers for SQL queries. It's a powerful tool that helps speed up development by reducing the need for manual coding. It works with databases various SQL database (MySQL, MariaDB, ...), checking the syntax and performance of SQL queries before you execute them.
It's important to note that SQLWrapper isn't like other tools that map objects to database tables (ORMs). Instead, it directly generates code from your SQL queries and database structure, which performs better than tools like LINQ, EntityFramework, dapper, ... and doesn't have the same limitations.
One feature is that it can look at your database's structure to check if your SQL queries are correct, and it can create an XML file listing all the data your queries need and return. Then, you can use XSLT templates to turn that XML into code in languages like C#, and more.
Overall, SQLWrapper is a handy tool for making SQL code easier to work with, saving time, and helping you write better code.
Links
Features
Database | language | function wrapper | stored procedure wrapper | SQL query wrapper | check SQL query syntax |
---|---|---|---|---|---|
mysql | C# .Net<br/>Visual Basic .Net | ✓ | ✓ | ✓ | ✓ |
mariadb | C# .Net<br/>Visual Basic .Net | ✓ | ✓ | ✓ | ✓ |
Getting started with package NuGet Daikoz.SQLWrapper
Video of demonstration:
The .NET package NuGet Daikoz.SQLWrapper integrate SQLWrapper in build process of our .NET project.
- Create your .NET project
- Add package NuGet Daikoz.SQLWrapper.
.NET CLI:
dotnet add package Daikoz.SQLWrapper
or use [Manage NuGet Packages...] in Visual Studio
- The first build create on your project root, the configuration file sqlwrapper.conf
{
"Verbose": false,
"Schema": [
{
"Name": "Name of this database. Should be contain only characters: a-z A-Z 0-9 _ -",
"ConnectionString": ".NET connection string to connect to database. If empty, use FilePath to get cached database previously generated.",
"FilePath": "File path of cached database schema. If empty, store it in obj of project",
"CustomType": [
"SQLTable.SQLType=LanguageType",
"SQLColumnName=LanguageType",
"@SQLVariable=LanguageType"
]
}
],
"Wrapper": {
"Database": [
{
"Schema": "Name of database schema defined in Schema section",
"Namespace": "Namespace in generated source. If empty, take the default namespace of project",
"XLST": "Provide your own XLST to generate a helper. If empty, use default XLST provided by SQLWrapper",
"OutputFilePath": "File path of schema"
}
],
"SQL": [
{
"Database": "Name of database defined in Schema section",
"Namespace": "Namespace in generated source. If empty, take the default namespace of project",
"XLST": "Provide your own XLST to generate the wrapper. If empty, use default XLST provided by SQLWrapper",
"Path": "Absolute or relative path where to search sql file pattern. If empty, use path of project",
"FilePattern": "SQL file to wrap. If empty, use \"*.sql\""
}
]
}
}
To start, follow a minimal configuration file. Modify HOSTNAME, USERID, PASSWORD and DATABASENAME
{
"Schema": [
{
"Name": "MyDatabase",
"ConnectionString": "server=HOSTNAME;user id=USERID;password='PASSWORD';database=DATABASENAME"
}
],
"Wrapper": {
"Database": [
{
"Schema": "MyDatabase",
"OutputFilePath": "MyDatabaseHelper.cs"
}
],
"SQL": [
{
"Schema": "MyDatabase"
}
]
}
}
- Add your database query in files .sql in your project
- Build you project
- Your database schema is cached in obj
- A database helper if generate in file MyDataseHelper.cs
- For each *.sql, a wrapper is generated
Getting started with command line SQLWrapper
SQLWrapper can be use in console.
Cache Schema
First, extract and cache database structure in XML File:
>SQLWrapper.exe help schema
SQL Wrapper Generator 2.1
Copyright (C) DAIKOZ. All rights reserved.
USAGE:
Extract and cache database schema in XML file:
SQLWrapper schema --connectionstring "server=servernamedb;user id=userid;password='password';database=db1"
--outputfile sqlwrapper-cachedb.xml --type mariadb --verbose
-t, --type Required. Type of database: mysql, mariadb.
-c, --connectionstring Required. List of .net database connection string
(https://docs.microsoft.com/en-us/dotnet/framework/data/adonet/connection-string-syntax).
-o, --outputfile Output XML file (default: stdout).
-v, --verbose Set output to verbose messages.
--help Display this help screen.
--version Display version information.
Example:
SQLWrapper schema --connectionstring "server=servernamedb;user id=userid;password='password';database=db1" --outputfile sqlwrapper-cachedb.xml --type mariadb --verbose
This command connect to database of type with connection information connectionstring. It generate a schema in XML. The output is written in outputfile.
SQL Wrapper
Generate the wrapper source code from SQL queries:
>SQLWrapper.exe help wrapper-sql
SQL Wrapper Generator 2.1
Copyright (C) DAIKOZ. All rights reserved.
USAGE:
Generate code from sql request:
SQLWrapper wrapper-sql --inputfiles request1.mysql request2.mysql --outputfile mysqlrequest.cs --params
namespace=DAIKOZ classname=SQLWrapper --schema sqlwrapper-cachedb.xml --xslt Template\sql-cshapr-ado.xslt
-s, --schema Required. XML file of cache database schema to load. Generate it before with database command
-i, --inputfiles Required. SQL files. Relative or full path. wildcard * is supported for filename.
-o, --outputfile Output file
-p, --params XLST Parameters
-t, --customtypes Force custom type for database field (table.col=MyEmu
-x, --xslt XSLT file path to transform XML output.
-v, --verbose Set output to verbose messages.
--help Display this help screen.
--version Display version information.
Example:
SQLWrapper wrapper-sql --schema sqlwrapper-cachedb.xml --inputfiles request1.mysql request2.mysql --outputfile mysqlrequest.cs --params namespace=DAIKOZ classname=SQLWrapper --xslt template\sql-cshapr-ado.xslt
This command create a SQL wrapper from database for 2 queries defined in inputfiles. It use the XSLT file to generate the outputfile. params give parameters defined in XLST file (here the namespace).
Database Wrapper Helper
Generate a source code helper to help the access to database. For example: the length of all text columns, functions and stored procedures
>SQLWrapper.exe help wrapper-database
SQL Wrapper Generator 2.0.1.1+fe5be6893053615a1ac4a351bb4da3c110a6355d
Copyright (C) DAIKOZ. All rights reserved.
USAGE:
Generate code helper to access database:
SQLWrapper wrapper-database --outputfile helper.cs --schema sqlwrapper-cachedb.xml --xslt Template\database-csharp-ado.xslt
-s, --schema Required. XML file of cache database schema to load. Generate it before with database command
-o, --outputfile Output file
-p, --params XLST Parameters
-t, --customtypes Force custom type for database field (table.col=MyEmu
-x, --xslt XSLT file path to transform XML output.
-v, --verbose Set output to verbose messages.
--help Display this help screen.
--version Display version information.
Example:
SQLWrapper wrapper-database --schema sqlwrapper-cachedb.xml --outputfile MyDatabaseHelper.cs --xslt template\database-csharp-ado.xslt
This command create a helper for database. It use XLST file to generate the outputfile.
Template XLST
In template section, you can found several XLST files to generate SQL and database wrappers/helpers in several programming language. You can create or modify your own and use it with --xslt parameter. DAIKOZ can help you to create your own XLST. Contact us.
Template available
Generate a database helper from XML Schema in:
- C# .Net: database-csharp-ado.xslt
- Visual Basic .Net: database-vb-ado.xslt
Generate a SQL query wrapper from XML schema and SQL query in:
- C# .Net: sql-cshapr-ado.xslt
- Visual Basic: sql-vb-ado.xslt
Product | Versions 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 was computed. 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. |
.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 was computed. 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. |
-
.NETStandard 2.0
- Microsoft.Build.Utilities.Core (>= 17.10.4)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
# Changelog
## [2.2] (2024-08-02)
### SQLWrapper
- Replace isnull by nullable attribute for database type
### Template
- **Database VB**: add new template database-vb-ado.xslt and sql-vb-ado.xslt to generate Visual Basic .Net wrapper
- Unify isnull and nullable for database type
- **sql-csharp-ado.xslt**: Read data asyn (await reader.ReadAsync())
- **Rename template** to use this rules:
* database or sql: use database for template to apply to all database and use sql for template to apply on SQL queries
* language: charp, vb, ...
* type: ado
- **Template available**:
* **database-csharp-ado.xslt**: generate a database helper from schema xml in C# ADO
* **database-vb-ado.xslt**: generate a database helper from schema xml in Visual Basic ADO
* **sql-cshapr-ado.xslt**: generate a SQL query wrapper from schema xml and SQL query in C# ADO
* **sql-vb-ado.xslt**: generate a SQL query wrapper from schema xml and SQL query in Visual Basic ADO