Skip to content

Releases: JordanMarr/SqlHydra

v2.4.0-beta.2 Npgsql Improvements

06 Mar 00:38
Compare
Choose a tag to compare
Pre-release
  • Adds mappings for the materialized view columns
  • "time with time zone" columns now generate DateTimeOffset properties

v2.4.0-beta.1 experimental features

21 Feb 19:56
Compare
Choose a tag to compare
Pre-release

SqlHydra.Cli

  • Added new "mutable_properties" option to toml "general" section which makes all record properties mutable. 🙀 (defaults to false, of course 😉). This is for in-memory apps that want to bind to generated types directly for edits.
  • Postgres now generates materialized views (requires net8 and npgsql v8 or greater). #84
  • All providers will now ignore any tables / views with no columns (just in case)

SqlHydra.Query

  • Added an experimental Diff utility to assist with saving batch changes. #83
  • Exposed KataQuery property on all queries (the resulting type of query builders) to make it possible to manipulate the underlying SqlKata query for inserts, updates and selects before executing the query.

SqlHydra v2.3.0

25 Nov 01:28
e040e98
Compare
Choose a tag to compare

Adds support for .NET 8

NOTE: Npgsql v8.0.0 fails when inserting an enum, so use Npgsql v7.0.0 for now.

v2.2.1 - SqlHydra.Query

10 Nov 20:36
Compare
Choose a tag to compare
  • Fixes: #71 - selected columns of left joined tables can now be marked as optional by wrapping them with Some.
  • In addition to isNullValue and isNotNullValue functions, added support for the built-in isNull function

v2.2.0

05 Nov 03:04
Compare
Choose a tag to compare

SqlHydra.Cli

  • SQL Server - All table properties now have a generated parameter type attribute
  • Npgsql - All table properties now have a generated parameter type attribute

SqlHydra.Query

  • Fixed bug #68 where QueryContext Logger was sometimes not showing the final query (for inserts with manually modified query)
  • Improved Logger output so that query shows parameter names and parameter values are listed below query
  • Improved Logger output so that query parameters show their generated column/parameter type

v2.1.0

22 Aug 21:31
Compare
Choose a tag to compare

SqlHydra.Cli

  • The TOML configuration [filters] section now has a new restrictions setting that allows passing restrictions (filters) to GetSchema. This gives you the ability to pre-filter the queried schema. For example, you can pre-filter to only pull tables in a certain schema. (These filters are not as configurable as the existing include and exclude glob patterns, but they have been added to help pre-filter extremely large databases to reduce generation times. Unless you are experiencing performance issues, you should use the glob include and exclude post-filters instead.)
    See TOML configuration docs here: https://github.com/JordanMarr/SqlHydra/wiki/TOML-Configuration#schema-restrictions
  • TOML configuration glob filters are now applied to filter tables before columns are collected / processed for each table. This is a small efficiency change.

SqlHydra.Query

  • Boolean unary expressions are now supported (without having to explicitly assign = true or = false)

✅ This is now valid and doesn't require an extra parameter!

    select {
        for o in Sales.SalesOrderHeader do
        where o.OnlineOrderFlag
    }

✅ This is now valid and doesn't require an extra parameter!

    select {
        for o in Sales.SalesOrderHeader do
        where (not o.OnlineOrderFlag)
    }

SqlHydra.Query v2.0.2

21 Jul 06:15
Compare
Choose a tag to compare

Adds the kata custom operation to the select computation expression.
This provides direct access to the underlying SqlKata.Query object within your query.

let getCustomers filters = 
  select {
      for c in main.Customer do
      where (c.FirstName = "John")
      kata (fun query -> 
          match filters.LastName with
          | Some lastName -> query.Where("c.LastName", lastName)
          | None -> query
      )
      kata (fun query -> 
          query.OrderBy(filters.SortColumns)
      )
  }

SqlHydra.Cli v2.0.2 - Maintenance Release

09 Jun 18:17
Compare
Choose a tag to compare

#58 Now sets SQL Server DateOnly and TimeOnly parameter types to DbType.Date and DbType.Time to improve query performance.

SqlHydra.Cli v2.0.1 - Maintenance Release

04 Jun 18:36
Compare
Choose a tag to compare
  • Bug fix #57
  • Consolidates generated ColumnReader methods

v2.0.0 - SqlHydra.Cli

11 Apr 16:29
b1c89dc
Compare
Choose a tag to compare

New in v2.0

  • All generator tools have been consolidated into SqlHydra.Cli.
    • Note that this changes command line syntax from dotnet sqlhydra-npgsql to dotnet sqlhydra npgsql
  • SqlHydra.SqlServer, SqlHydra.Npgsql, SqlHydra.Sqlite and SqlHydra.Oracle tools have been deprecated on NuGet.
  • Support for net5.0 has been dropped (use the legacy tools if you still need it).
  • SqlHydra.Query has been updated to v2.0 to maintain parity with SqlHydra.Cli.