Franey-SqlKata
1.0.0
dotnet add package Franey-SqlKata --version 1.0.0
NuGet\Install-Package Franey-SqlKata -Version 1.0.0
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="Franey-SqlKata" Version="1.0.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Franey-SqlKata" Version="1.0.0" />
<PackageReference Include="Franey-SqlKata" />
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 Franey-SqlKata --version 1.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: Franey-SqlKata, 1.0.0"
#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 Franey-SqlKata@1.0.0
#: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=Franey-SqlKata&version=1.0.0
#tool nuget:?package=Franey-SqlKata&version=1.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
New Update and UpdateAsync upgrade: CASE
A new feature added to allow developers to programmatically set CASE WHEN when assigning values. Feature includes grouping in sub statements () or
to allow condition to point to a column variable instead of a direct paramater value. SQL injection friendly
Original Update Statement for multiple records using anonymous objects:
foreach (var item in data)
{
object obj = new
{
MyField = item.Value
};
cnt += await QueryFactory.Query(tableName).Where("Id", item.Id).UpdateAsync(value);
}
return cnt;
New Update with select case using multi-level array systems
version 1 : allows is equal condition only for now
For the Else it will always fill with name of field itself , self assigning.
This happens if format is wrong as well.
The else protects you fro your field to be set back to NULL
Warning: Limitation is requires , Suggest 200 rows for low number columns,
25 for higher number columns or clauses.
var datac = data.Chunk(200); // breaking data up to 200 rows
//each holds for each update set, which allows multiple value setting as older Update
List<object[]> cases = [];
if (datac.Any()) foreach (var d in datac)
{
try
{
foreach (var item in d) //Build case when statement , standard 3
{
cases.Add(["Id", item.Id, item.Value]);
}
object obj = new
{
MyField= cases.ToArray()
};
cases.Clear();
//if data set is smaller than whole table , best to use in statement to reduce cost
cnt += await QueryFactory.Query(tableName)
.WhereIn("Id", d.Select(dd => dd.Id).ToArray())
.UpdateAsync(value);
}
catch { throw; }
finally { cases.Clear(); }
}
else cases.Clear();
return cnt;
##standard: Case WHEN x = A then Y... END:
In your cases array the flow is [x,A,Y].
Assignmet value is always last.
Available Feaure 1 : While its common to do 3 items for basic, when can extend the criteria with AND and OR
It combine, the array column after the orevioud criteria field must be an AND or OR, unless using , () or * explained later
Note: Assignmet value is always last. you can use AND,&&,& or OR,||,|, <>. Not case sensitive.
Case WHEN x = A AND z = B then Y ... END:
In your cases array the flow is [x,A,"AND",z,B,Y]
Case WHEN x = A OR z = B then Y ... END:
Array the flow is [x,A,"OR",z,B,Y]
Available Feaure 2 : Subset (). This allows seperating your "And" & "Or" blocks
ex: case when (a = 1 or a = 5) and (b = 7 and c = 2)
This can be placed anywhere before the assignment column or * assignment column,
if you forget to add the ) to close, the engine
will compensate.
Case WHEN (x = A AND z = B) OR J = C then Y ... END:
Array the flow is ["(",x,A,"AND",z,B,")","OR",j,c,Y]
Case WHEN (x = A OR z = B) AND (J = C AND K = D) then Y ... END:
Array the flow is ["(",x,A,"OR",z,B,")","AND","(",j,c,"AND",k,d,")" Y]
Available Feaure 3 : To Another Column Field (*). This allows criteria to check if column equals another column (field)
Case WHEN (colx = colb AND colz = colx) then Y ... END:
Array the flow is [,colx,*',colb,"AND",colz,colx, Y]
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. 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. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
net8.0
- No dependencies.
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Franey-SqlKata:
Package | Downloads |
---|---|
Franey-SqlKata.Execution
Adds the execution capabilities for SqlKata |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last Updated |
---|---|---|
1.0.0 | 210 | 8/6/2025 |