BenBurgers.InternationalStandards.Iso.EFCore.SqlServer 0.5.0

dotnet add package BenBurgers.InternationalStandards.Iso.EFCore.SqlServer --version 0.5.0
NuGet\Install-Package BenBurgers.InternationalStandards.Iso.EFCore.SqlServer -Version 0.5.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="BenBurgers.InternationalStandards.Iso.EFCore.SqlServer" Version="0.5.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add BenBurgers.InternationalStandards.Iso.EFCore.SqlServer --version 0.5.0
#r "nuget: BenBurgers.InternationalStandards.Iso.EFCore.SqlServer, 0.5.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.
// Install BenBurgers.InternationalStandards.Iso.EFCore.SqlServer as a Cake Addin
#addin nuget:?package=BenBurgers.InternationalStandards.Iso.EFCore.SqlServer&version=0.5.0

// Install BenBurgers.InternationalStandards.Iso.EFCore.SqlServer as a Cake Tool
#tool nuget:?package=BenBurgers.InternationalStandards.Iso.EFCore.SqlServer&version=0.5.0

Contents

Introduction

Thank you for choosing this package.

The BenBurgers.InternationalStandards.Iso.EFCore.SqlServer package contains Entity Framework Core SQL Server features for codes and features that belong to standards of the International Organization for Standardization (ISO).

The International Organization for Standardization (ISO) is an international standard development organization composed of representatives from the national standards organizations of member countries. The organization develops and publishes standardization in all technical and nontechnical fields other than electrical and electronic engineering.[^1]

[^1]: Wikipedia, downloaded at 31 October 2022, 23:33 CET.

You are kindly encouraged to buy the standards you use at the ISO Store in order to fund their mission.

GitHub Sponsors

If you like my contributions, please have a look at my GitHub Sponsors profile. My open source contributions are available free of charge (but subject to licenses) and the contributions are made entirely in my free time, but sponsorship would be sincerely appreciated. Thank you.

If possible, please also buy a standard from the respective Maintenance Agency or ISO itself to cover the costs of the Maintenance Agencies and the ISO in maintaining the standards.

Packages

These are the packages that concern the ISO standards:

Name Description
BenBurgers.InternationalStandards.Iso The main package with the codes and metadata.
BenBurgers.InternationalStandards.Iso.EFCore Features for storing codes using Entity Framework Core.
BenBurgers.InternationalStandards.Iso.EFCore.SqlServer Features for storing codes using Entity Framework Core and SQL Server.
BenBurgers.InternationalStandards.Iso.IO Features for reading Code Tables from authorities.
BenBurgers.InternationalStandards.Iso.Json Features for serializing and deserializing codes in JSON.

Please refer to NuGet to download the packages and GitHub for the source code.

Manual

Supported ISO standards

The following are the currently supported ISO standards.

Name Description
ISO 639 Language codes
ISO 3166 Country codes
ISO 4217 Currency codes

Alpha

Property builders for Alpha2 and Alpha3 property values may be found in the namespace:

  • BenBurgers.InternationalStandards.Iso.EFCore.SqlServer.Metadata.Builders

These are extension methods that may be used in the fluent configuration of entities for Entity Framework Core.

ISO 639 language codes

Property builders and a Database Context for migrations and queries may be found in the namespaces:

  • BenBurgers.InternationalStandards.Iso.EFCore.SqlServer.Iso639
  • BenBurgers.InternationalStandards.Iso.EFCore.SqlServer.Iso639.Metadata.Builders

ISO 3166 country codes

Property builders and a Database Context for migrations and queries may be found in the namespaces:

  • BenBurgers.InternationalStandards.Iso.EFCore.SqlServer.Iso3166
  • BenBurgers.InternationalStandards.Iso.EFCore.SqlServer.Iso3166.Metadata.Builders

ISO 4217 currency codes

Property builders and a Database Context for migrations and queries may be found in the namespaces:

  • BenBurgers.InternationalStandards.Iso.EFCore.SqlServer.Iso4217
  • BenBurgers.InternationalStandards.Iso.EFCore.SqlServer.Iso4217.Metadata.Builders

Migrations

Bootstrapping

In order to access migrations through the dotnet-ef tool, it is possible to create your own Migrations assembly and inherit the class BenBurgers.InternationalStandards.Iso.EFCore.SqlServer.Design.IsoDesignTimeDbContextFactory, with a particular Database Context for the desired standard as its type parameter.

An inherited class of BenBurgers.InternationalStandards.Iso.EFCore.SqlServer.Design.IsoDesignTimeServices will be necessary for generating the C# migrations.

Configuration

The configuration options for the Database Context Factory may be provided by overriding the IsoSqlServerOptions property, or command line arguments with the dotnet-ef tool.

The configuration parameters may be found in BenBurgers.InternationalStandards.Iso.EFCore.SqlServer.Configuration.IsoSqlServerOptions.

Multiple Database Contexts for multiple ISO standards

If there are multiple Database Contexts, it will be necessary to tell the dotnet-ef tool which one to generate migrations for in a particular run.

The migrations will populate a specified database with a lookup table for any supported standard. The lookup table will be read-only for public database users.

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  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 is compatible.  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 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
0.5.0 210 12/5/2023
0.4.0 196 1/3/2023

Version 0.5.0
- .NET 8.0 support.
Version 0.4.0
- Added Entity Framework Core features for value converters and model builders.
- ISO 3166: Breaking change; Iso3166AlphaMode moved from JSON package to main package.
- ISO 3166: Country codes are now generated from the data from the ISO 3166 Maintenance Agency (Online Browsing Platform), some field names may have changed. Properties "Independent" and official full names and short names in some languages added.
- ISO 639, 3166, 4217: Comparers added.
- ISO 639, 3166, 4217: Added ToModel method for retrieving the full model of an ISO code.
- ISO 639, 3166, 4217: Added TryTo[ISO] method for attempting to convert a string to its ISO code equivalent, without throwing an exception if it fails.
- ISO 8601: Added ISO 8601 date and time value types, including EFCore and JSON converters.
- If .NET 6.0 use official .NET 6.0 packages, if .NET 7.0 use official .NET 7.0 packages.
Version 0.3.0
- ISO 639: Fixed bug; if an unassigned Part of ISO 639 was requested, an exception was thrown that said it was deprecated.
- ISO 639: Implemented stub for conversion from string to ISO 639 code.
- ISO 3166: Improved documentation.
- ISO 4217: Added ISO 4217 currency codes.
- ISO 4217/IO: Added ISO 4217 Input/Output for importing currency codes from authority.
- ISO 4217/JSON: Added ISO 4217 (de)serialization.
Version 0.2.0
- ISO 639: Added ISO 639 language codes.
- ISO 639/IO: Added ISO 639 Input/Output for importing Code Tables from authority.
- ISO 639/JSON: Added ISO 639 (de)serialization.
- ISO 3166/JSON: Support for reading (in addition to writing) ISO 3166 numeric code as string.
- Added support for .NET 7.0 .
Version 0.1.0
- ISO 3166: Added ISO 3166 country codes.
- ISO 3166/JSON: Added ISO 3166 (de)serialization.