YeSql.Net 0.3.0-alpha

This is a prerelease version of YeSql.Net.
There is a newer version of this package available.
See the version list below for details.
dotnet add package YeSql.Net --version 0.3.0-alpha                
NuGet\Install-Package YeSql.Net -Version 0.3.0-alpha                
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="YeSql.Net" Version="0.3.0-alpha" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add YeSql.Net --version 0.3.0-alpha                
#r "nuget: YeSql.Net, 0.3.0-alpha"                
#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.
// Install YeSql.Net as a Cake Addin
#addin nuget:?package=YeSql.Net&version=0.3.0-alpha&prerelease

// Install YeSql.Net as a Cake Tool
#tool nuget:?package=YeSql.Net&version=0.3.0-alpha&prerelease                

YeSQL.NET

yesql.net yesql.net yesql.net Nuget-Badges

yesql.net

YeSQL.NET is a class library for loading SQL statements from .sql files instead of writing SQL code in your C# source files.

  • This library was inspired by krisajenkins/yesql.
  • YepSQL library has been used as a reference for the creation of the parser.

Important

This project is still in the development phase, so it is not yet ready for production use.

Please note that the current API may change in future versions.

Advantages

By keeping the SQL and C# separate you get:

  • Better editor support. Your editor probably already has great SQL support. By keeping the SQL as SQL, you get to use it.
  • Query reuse. Drop the same SQL files into other projects, because they're just plain ol' SQL. Share them as a submodule.
  • Team interoperability. Your DBAs can read and write the SQL you use in your .NET project.
  • Separation of concerns. Since your SQL statements are not embedded (hard-coded) directly in the application code, you can make minor changes to the SQL file without having to open the C# source file.
    • Any changes you make to the SQL file should not affect the C# source file unless it is a major change (e.g., renaming a column).
  • Independent development. A developer can create the SQL statements without waiting for another developer to create the C# source file with the proposed feature.

Installation

If you're want to install the package from Visual Studio, you must open the project/solution in Visual Studio, and open the console using the Tools > NuGet Package Manager > Package Manager Console command and run the install command:

Install-Package YeSql.Net

If you are making use of the dotnet CLI, then run the following in your terminal:

dotnet add package YeSql.Net

Overview

Create a file with .sql extension containing the SQL statements:

-- name: GetUsers
-- Gets user information.
SELECT 
id, 
username, 
email 
FROM users;

-- name: GetRoles
SELECT * FROM roles;

Each SQL statement must be associated with a tag using the name: prefix and must begin with a comment.

This is necessary so that the parser can uniquely identify each SQL statement by its tag.

You must then import the namespace types at the beginning of your class file:

using YeSql.Net;

Load from files

You can load SQL statements from the specified files:

var sqlStatements = new YeSqlLoader().LoadFromFiles("users.sql", "sample.sql");

Load from directories

You can load SQL statements from all the SQL files in the specified directories:

var sqlStatements = new YeSqlLoader().LoadFromDirectories("sql", "samples");

Parsing .sql files

You can use the parser to extract SQL statements from any data source:

var source =
"""
-- name: GetUsers
SELECT id, username, email FROM users;
""";
YeSqlValidationResult validationResult;
var sqlStatements = new YeSqlParser().Parse(source, out validationResult);
if(validationResult.HasError())
{
    // Some code to handle the error.
}

If you want to handle the error in another way, you can use the ParseAndThrow method:

var sqlStatements = new YeSqlParser().ParseAndThrow(source);

This method throws an exception of type YeSqlParserException when the parser encounters an error.

Accessing SQL statements

You can access SQL statements using the IYeSqlCollection interface:

// Tag: GetUsers
string sql = sqlStatements["GetUsers"];

But you must specify the tag name to access the SQL statement. Remember that each SQL code is identified with its respective tag.

Copying .sql files to the output directory

It is recommended to copy the .sql files to the output directory because currently the loader search for the .sql files in the current directory where the application is running, so to avoid possible errors, it is better to copy the following instruction to your project file (.csproj):

<ItemGroup>
  <Content Include="**\*.sql" CopyToOutputDirectory="Always" TargetPath="sql\%(Filename)%(Extension)" />
</ItemGroup>

This will copy the .sql files into an sql folder in the output directory (e.g., /bin/Debug/net7.0).

Contribution

Any contribution is welcome! Remember that you can contribute not only in the code, but also in the documentation or even improve the tests.

Follow the steps below:

  • Fork it
  • Create your feature branch (git checkout -b my-new-feature)
  • Commit your changes (git commit -am 'Added some feature')
  • Push to the branch (git push origin my-new-feature)
  • Create new Pull Request
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 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • .NETStandard 2.0

    • No dependencies.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories (1)

Showing the top 1 popular GitHub repositories that depend on YeSql.Net:

Repository Stars
ose-net/yesql.net
A class library for loading SQL statements from .sql files instead of writing SQL code in your C# source files
Version Downloads Last updated
2.0.0 2,337 7/6/2024
1.0.1 101 7/6/2024
1.0.0 871 1/21/2024
0.8.0-alpha 88 1/20/2024
0.7.0-alpha 115 1/13/2024
0.6.0-alpha 116 1/8/2024
0.5.0-alpha 100 1/2/2024
0.4.0-alpha 263 6/15/2023
0.3.0-alpha 126 6/11/2023