DubUrl 0.20.2

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

// Install DubUrl as a Cake Tool
#tool nuget:?package=DubUrl&version=0.20.2                

DubUrl

DubUrl provides a standard, URL style mechanism for parsing database connection strings and opening DbConnections for .NET. With DubUrl, you can parse and open URLs for popular databases such as Microsoft SQL Server, PostgreSQL, MySQL, SQLite3, Oracle Database and most of the other SQL databases. This project is inspired from the package dburl available in the GoLang ecosystem and is trying to match the aliases for portocols.

About | Overview | Quickstart | Examples | Schemes | Installing | Using

About

Social media: website twitter badge

Releases: nuget licence badge

Dev. activity: GitHub last commit Still maintained GitHub commit activity

Continuous integration builds: Build status Tests CodeFactor codecov FOSSA Status

Status: stars badge Bugs badge Top language

Mappers for ADO.Net Provider implemented badge Mappers for ODBC drivers implemented badge Mappers for OLE DB providers implemented badge Mappers for ADOMD.NET providers implemented badge

Upcoming features badge Upcoming databases badge Upcoming ADO.Net badge Upcoming ODBC badge

Database Connection URL Overview

Supported database connection URLs are of the form:

driver:alias://user:pass@host/dbname?opt1=a&opt2=b

Where:

Component Description
alias database type (see below)
driver driver/provider name (only for odbc/oleodbc)
user username
pass password
host host
dbname<sup>*</sup> database, instance, or service name/ID to connect to
?opt1=... additional database driver options (see respective SQL driver for available options)

<i><sup><b>*</b></sup> for Microsoft SQL Server, /dbname can be /instance/dbname, where /instance is optional. For Oracle Database, /dbname is of the form /service/dbname where /service is the service name or SID, and /dbname is optional. Please see below for examples.</i>

Quickstart

Database connection URLs in the above format can be parsed to a standard connection string with the [Parse] as such:

string connectionUrl = "mssql://{server}/{database_name}";
string connectionString = new ConnectionUrl(connectionUrl).Parse();

Additionally, a simple helper, [Open], is provided that will parse, open, and return a standard DbConnection.

string connectionUrl = "mssql://{server}/{database_name}";
IDbConnection connection = new ConnectionUrl(connectionUrl).Open();

If you don't want to open the connection but only return it and manage its state by yourself, use the function [Connect]

string connectionUrl = "mssql://{server}/{database_name}";
IDbConnection connection = new ConnectionUrl(connectionUrl).Connect();

Example URLs

The following are example database connection URLs that can be handled by [Parse], [Connect] and [Open]:

mssql://user:pass@remote-host.com/instance/dbname?keepAlive=10
oledb+mssql://user:pass@localhost/dbname

postgres://user:pass@localhost/dbname
odbc+postgres://user:pass@localhost:port/dbname?option1=

mysql://user:pass@localhost/dbname
oracle://user:pass@somehost.com/sid
db2://user:pass@localhost/dbname

Protocol Schemes and Aliases

ADO.Net data providers

The following databases and their associated schemes are supported out of the box:

Database Aliases Provider Invariant Name
Microsoft SQL Server mssql, ms, sqlserver, mssqlserver Microsoft.Data.SqlClient
MySQL mysql, my MySqlConnector
PostgreSQL pg, pgx, pgsql, postgres, postgresql Npgsql
Oracle Database oracle, or, ora Oracle.ManagedDataAccess
IBM DB2 db2 IBM.Data.Db2
MariaDB maria, mariadb MySqlConnector
DuckDB duck, duckdb DuckDB.NET.Data
Firebird SQL fb, firebird FirebirdSql.Data.FirebirdClient
SQLite3 sq, sqlite Microsoft.Data.Sqlite
Teradata td, teradata, tera Teradata.Client
Snowflake sf, snowflake Snowflake.Data
CockRoachDB cr, cockroach, cockroachdb, crdb, cdb Npgsql
CrateDB crt, crate, cratedb Npgsql
SingleStore sg, sgs, singlestore, single SingleStoreConnector
Trino tr, trino NReco.PrestoAdo
QuestDb quest, questdb Npgsql
Timescale ts, timescale Npgsql

ODBC driver locators

The following databases and their associated schemes are supported out of the box:

Database Aliases Name Pattern
Microsoft SQL Server mssql, ms, sqlserver, mssqlserver ^\bODBC Driver\s([0-9]{1,2}(?:.[0-9]{1,2}){0,2})\s\bfor SQL Server$
MySQL mysql, my ^\bMySQL ODBC\s([0-9]{1,2}(?:.[0-9]{1,2}){0,2})\s(ANSI|Unicode)\s\bDriver$
PostgreSQL pg, pgx, pgsql, postgres, postgresql ^\bPostgreSQL\s(ANSI|Unicode)((x64))?$
MariaDB maria, mariadb ^\bMariaDB ODBC\s([0-9]{1,2}(?:.[0-9]{1,2}){0,2})\s\bDriver$
DuckDB duck, duckdb ^\bDuckDB\s\bDriver$
Apache Drill drill ^\bMapR Drill ODBC Driver$
Trino tr, trino ^(Simba)\s\bTrino ODBC Driver$
Microsoft Access accdb, access, msaccess, mdb ^\bMicrosoft Access Driver\s(*.mdb, *.accdb)$
Microsoft Excel xls, xlsx, xlsb, xlsm ^\bMicrosoft Excel Driver\s(*.xls, *.xlsx, *.xlsm, *.xlsb)$
Text files txt, csv, tsv ^\bMicrosoft Access Text Driver\s(*.txt, *.csv)$
QuestDb quest, questdb ^\bPostgreSQL\s(ANSI|Unicode)((x64))?$
Timescale ts, timescale ^\bPostgreSQL\s(ANSI|Unicode)((x64))?$

Extension for OLEDB provider locators

The following databases and their associated schemes are supported through the OLE DB data provider extension:

Database Aliases Name Pattern
Microsoft SQL Server mssql, ms, sqlserver, mssqlserver ^\bMSOLEDBSQL$
MySQL mysql, my ^\bMySQL Provider$
Microsoft Excel xls ^\bMicrosoft.ACE.OLEDB.([0-9]{1,2}(?:.[0-9]{1,2}){0,2})$
Microsoft Excel xlsx ^\bMicrosoft.ACE.OLEDB.([0-9]{1,2}(?:.[0-9]{1,2}){0,2})$
Microsoft Excel xlsm ^\bMicrosoft.ACE.OLEDB.([0-9]{1,2}(?:.[0-9]{1,2}){0,2})$
Microsoft Excel xlsb ^\bMicrosoft.ACE.OLEDB.([0-9]{1,2}(?:.[0-9]{1,2}){0,2})$
Microsoft Access accdb, access, msaccess, mdb ^\bMicrosoft.ACE.OLEDB.([0-9]{1,2}(?:.[0-9]{1,2}){0,2})$

Extension for ADOMD.NET data provider

The following databases and their associated schemes are supported through the ADOMD.NET data provider extension:

Database Aliases Provider Invariant Name
Azure Analysis Services asazure, asa Microsoft.AnalysisServices.AdomdClient
Power BI Desktop pbidesktop, pbix, powerbidesktop Microsoft.AnalysisServices.AdomdClient
Power BI Premium powerbi, pbi, pbiazure, pbipremium, powerbipremium Microsoft.AnalysisServices.AdomdClient
SQL Server Analysis Services - Multidimensional ssasmultidim, ssasmdx Microsoft.AnalysisServices.AdomdClient
SQL Server Analysis Services - Tabular ssastabular, ssasdax Microsoft.AnalysisServices.AdomdClient

Installing

Install in the usual .NET fashion:

Install-Package DubUrl

To install the extension for OLEDB provider locators

Install-Package DubUrl.OleDb

To install the extension for ADOMD.NET data provider

Install-Package DubUrl.Adomd

Using

Check the first steps guide on the website.

Please note that DubUrl does not install actual drivers, and only provides a standard way to [Parse] respective database connection URLs then [Connect] or [Open] connections.

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

NuGet packages (5)

Showing the top 5 NuGet packages that depend on DubUrl:

Package Downloads
DubUrl.OleDb

DubUrl provides a standardized URL-style mechanism for providing database connection information and opening a DbConnection in the .NET ecosystem

DubUrl.Extensions.DependencyInjection

DubUrl provides a standardized URL-style mechanism for providing database connection information and opening a DbConnection in the .NET ecosystem

DubUrl.Adomd

DubUrl provides a standardized URL-style mechanism for providing database connection information and opening a DbConnection in the .NET ecosystem

DubUrl.Extensions

DubUrl provides a standardized URL-style mechanism for providing database connection information and opening a DbConnection in the .NET ecosystem

Tseesecake

Package Description

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
0.20.28 20 1/22/2025
0.20.27 76 1/20/2025
0.20.26 75 1/18/2025
0.20.25 72 1/18/2025
0.20.22 76 1/16/2025
0.20.21 85 1/15/2025
0.20.19 83 1/15/2025
0.20.18 81 1/11/2025
0.20.16 83 1/10/2025
0.20.15 99 1/2/2025
0.20.14 98 1/2/2025
0.20.12 100 12/28/2024
0.20.11 105 12/26/2024
0.20.10 107 12/26/2024
0.20.9 109 12/26/2024
0.20.8 109 12/16/2024
0.20.7 116 12/14/2024
0.20.6 110 12/11/2024
0.20.5 100 12/9/2024
0.20.4 109 12/3/2024
0.20.3 102 12/2/2024
0.20.2 102 12/2/2024
0.20.1 104 12/1/2024
0.20.0 108 12/1/2024
0.19.0 127 11/25/2024
0.18.91 136 11/24/2024
0.18.90 144 11/24/2024
0.18.86 128 11/18/2024
0.18.85 132 11/18/2024
0.18.84 134 11/16/2024
0.18.82 133 11/14/2024
0.18.81 136 11/8/2024
0.18.80 138 11/6/2024
0.18.78 143 10/24/2024
0.18.76 174 10/18/2024
0.18.75 171 10/18/2024
0.18.74 123 10/16/2024
0.18.73 133 10/14/2024
0.18.72 132 10/14/2024
0.18.71 143 10/14/2024
0.18.70 143 10/11/2024
0.18.68 153 9/30/2024
0.18.67 179 9/16/2024
0.18.66 159 9/15/2024
0.18.65 155 9/15/2024
0.18.64 176 9/14/2024
0.18.62 171 9/9/2024
0.18.61 169 9/9/2024
0.18.60 164 9/2/2024
0.18.59 160 9/2/2024
0.18.58 155 9/3/2024
0.18.57 169 8/26/2024
0.18.56 197 8/21/2024
0.18.55 186 8/18/2024
0.18.54 178 8/15/2024
0.18.53 174 8/11/2024
0.18.51 114 7/29/2024
0.18.50 154 7/17/2024
0.18.49 146 7/17/2024
0.18.47 154 7/17/2024
0.18.45 167 7/14/2024
0.18.44 159 7/7/2024
0.18.43 162 7/7/2024
0.18.42 155 7/6/2024
0.18.41 160 7/6/2024
0.18.39 154 7/6/2024
0.18.38 182 7/6/2024
0.18.37 156 6/25/2024
0.18.36 171 6/23/2024
0.18.33 173 5/20/2024
0.18.32 163 5/20/2024
0.18.31 167 5/19/2024
0.18.30 184 5/15/2024
0.18.29 177 5/15/2024
0.18.28 182 5/15/2024
0.18.27 164 5/14/2024
0.18.24 154 5/14/2024
0.18.22 192 4/15/2024
0.18.20 178 4/15/2024
0.18.19 179 4/1/2024
0.18.18 249 3/25/2024
0.18.17 242 3/23/2024
0.18.16 240 3/23/2024
0.18.15 226 3/23/2024
0.18.14 226 3/23/2024
0.18.13 224 3/23/2024
0.18.12 265 3/11/2024
0.18.11 278 3/10/2024
0.18.10 284 3/10/2024
0.18.9 291 2/28/2024
0.18.8 303 2/17/2024
0.18.6 316 2/17/2024
0.18.5 292 2/17/2024
0.18.4 308 2/17/2024
0.18.3 302 2/17/2024
0.18.2 319 2/17/2024
0.18.0 341 2/11/2024
0.17.6 348 2/9/2024
0.17.5 335 2/9/2024
0.17.4 346 2/7/2024
0.17.3 341 2/7/2024
0.17.2 339 2/7/2024
0.17.1 323 1/30/2024
0.17.0 304 1/28/2024
0.16.0 332 1/27/2024
0.15.0 318 1/27/2024
0.14.0 329 1/27/2024
0.13.1 356 1/27/2024
0.13.0 348 1/22/2024
0.12.1 356 1/22/2024
0.12.0 333 1/22/2024
0.11.0 349 1/20/2024
0.10.0 352 1/20/2024
0.9.11 328 1/20/2024
0.9.10 317 1/20/2024
0.9.9 339 1/19/2024
0.9.8 336 1/19/2024
0.9.7 350 1/19/2024
0.9.6 320 1/19/2024
0.9.5 330 1/18/2024
0.9.2 436 1/8/2024
0.9.1 380 1/5/2024
0.9.0 391 12/30/2023
0.8.7 397 12/30/2023
0.8.6 422 12/25/2023
0.8.5 398 12/21/2023
0.8.4 397 12/21/2023
0.8.3 447 12/11/2023
0.8.2 435 12/11/2023
0.8.1 439 12/11/2023
0.8.0 436 12/9/2023
0.7.3 421 12/6/2023
0.7.2 467 12/5/2023
0.7.1 465 11/28/2023
0.7.0 430 11/27/2023
0.6.0 446 11/26/2023
0.5.11 457 11/25/2023
0.5.9 438 11/25/2023
0.5.8 443 11/25/2023
0.5.6 451 11/25/2023
0.5.5 432 11/25/2023
0.5.1 438 11/25/2023
0.5.0 467 11/18/2023
0.4.14 417 11/16/2023
0.4.6 439 11/16/2023
0.4.5 457 11/13/2023
0.4.4 415 11/13/2023
0.4.3 452 11/12/2023
0.4.2 421 11/12/2023
0.4.1 441 11/7/2023
0.4.0 416 11/6/2023
0.3.3 447 11/6/2023
0.3.2 442 11/6/2023
0.3.1 449 11/6/2023
0.3.0 479 10/30/2023
0.2.13 455 10/30/2023
0.2.12 429 10/30/2023
0.2.11 423 10/30/2023
0.2.10 431 10/23/2023
0.2.9 467 10/23/2023
0.2.8 474 10/16/2023
0.2.7 477 10/16/2023
0.2.6 473 10/9/2023
0.2.5 438 10/9/2023
0.2.4 442 10/9/2023
0.2.3 475 10/2/2023
0.2.0 562 9/30/2023
0.1.233 652 9/21/2023
0.1.231 549 9/19/2023
0.1.230 506 9/18/2023
0.1.228 483 9/18/2023
0.1.227 564 9/15/2023
0.1.226 510 9/14/2023
0.1.225 510 9/12/2023
0.1.224 512 9/10/2023
0.1.223 517 9/10/2023
0.1.222 509 9/9/2023
0.1.219 538 9/8/2023
0.1.218 532 9/7/2023
0.1.217 538 9/6/2023
0.1.216 574 8/28/2023
0.1.215 530 8/28/2023
0.1.214 540 8/23/2023
0.1.213 536 8/23/2023
0.1.212 592 8/15/2023
0.1.211 573 8/14/2023
0.1.210 561 8/12/2023
0.1.209 621 8/8/2023
0.1.208 709 8/1/2023
0.1.207 745 7/31/2023
0.1.206 642 7/31/2023
0.1.205 617 7/31/2023
0.1.204 644 7/30/2023
0.1.203 608 7/30/2023
0.1.202 629 7/30/2023
0.1.201 629 7/29/2023
0.1.200 648 7/11/2023
0.1.199 696 7/3/2023
0.1.198 653 7/1/2023
0.1.197 695 6/30/2023
0.1.196 952 6/29/2023
0.1.195 696 6/26/2023
0.1.194 861 6/23/2023
0.1.193 645 6/23/2023
0.1.192 689 6/21/2023
0.1.191 666 6/19/2023
0.1.190 628 6/18/2023
0.1.188 660 6/18/2023
0.1.187 648 6/17/2023
0.1.186 697 6/16/2023
0.1.184 657 6/11/2023
0.1.183 683 6/8/2023
0.1.182 681 5/31/2023
0.1.180 655 5/30/2023
0.1.179 616 5/30/2023
0.1.178 638 5/29/2023
0.1.177 669 5/28/2023
0.1.176 675 5/27/2023
0.1.175 679 5/23/2023
0.1.174 674 5/22/2023
0.1.173 656 5/21/2023
0.1.172 686 5/20/2023
0.1.171 650 5/20/2023
0.1.170 651 5/15/2023
0.1.169 692 5/14/2023
0.1.168 694 5/13/2023
0.1.167 744 5/11/2023
0.1.166 687 5/11/2023
0.1.165 671 5/3/2023
0.1.164 708 4/27/2023
0.1.163 721 4/22/2023
0.1.162 727 4/18/2023
0.1.161 715 4/17/2023
0.1.160 719 4/17/2023
0.1.159 740 4/17/2023
0.1.158 745 4/17/2023
0.1.157 710 4/13/2023
0.1.156 738 4/10/2023
0.1.155 700 4/10/2023
0.1.154 738 4/10/2023
0.1.153 700 4/10/2023
0.1.152 711 4/4/2023
0.1.151 720 4/3/2023
0.1.150 808 3/28/2023
0.1.149 776 3/20/2023
0.1.148 760 3/14/2023
0.1.147 785 3/6/2023
0.1.146 774 3/5/2023
0.1.145 845 3/5/2023
0.1.144 844 3/1/2023
0.1.143 858 1/31/2023
0.1.142 874 1/31/2023
0.1.141 866 1/25/2023
0.1.140 863 1/23/2023
0.1.139 851 1/20/2023
0.1.138 923 1/3/2023
0.1.136 893 1/3/2023
0.1.133 927 12/26/2022
0.1.132 929 12/20/2022
0.1.131 902 12/20/2022
0.1.130 928 12/14/2022
0.1.129 923 11/28/2022
0.1.128 942 11/20/2022
0.1.127 972 11/20/2022
0.1.126 955 11/20/2022
0.1.125 923 11/19/2022
0.1.124 929 11/19/2022
0.1.123 980 11/19/2022
0.1.122 1,009 11/19/2022
0.1.121 989 11/19/2022
0.1.120 931 11/17/2022
0.1.119 946 11/17/2022
0.1.118 961 11/17/2022
0.1.115 954 11/9/2022
0.1.114 967 11/7/2022
0.1.113 927 11/2/2022
0.1.112 982 11/2/2022
0.1.111 969 11/2/2022
0.1.110 1,026 11/1/2022
0.1.109 1,014 11/1/2022
0.1.108 1,046 10/28/2022
0.1.107 1,054 10/28/2022
0.1.106 1,008 10/28/2022
0.1.103 1,061 10/22/2022
0.1.101 1,096 10/17/2022
0.1.100 1,103 10/17/2022
0.1.99 1,057 10/17/2022
0.1.98 1,033 10/17/2022
0.1.97 1,102 10/13/2022
0.1.96 1,090 10/3/2022
0.1.94 1,105 9/26/2022
0.1.93 1,137 9/26/2022
0.1.92 1,090 9/26/2022
0.1.91 1,097 9/24/2022
0.1.90 1,129 9/24/2022
0.1.89 1,070 9/24/2022
0.1.88 1,052 9/21/2022
0.1.87 1,117 9/20/2022
0.1.86 1,158 9/20/2022
0.1.84 1,111 9/15/2022
0.1.83 1,120 9/15/2022
0.1.82 1,111 9/11/2022
0.1.81 1,137 9/10/2022
0.1.80 1,127 9/10/2022
0.1.79 1,134 9/10/2022
0.1.78 1,123 9/10/2022
0.1.77 1,030 9/7/2022
0.1.76 948 9/7/2022
0.1.75 1,013 8/30/2022
0.1.74 988 8/29/2022
0.1.72 993 8/27/2022
0.1.71 817 8/27/2022
0.1.70 857 8/21/2022
0.1.69 791 8/15/2022
0.1.68 887 8/15/2022
0.1.67 843 8/15/2022
0.1.66 871 8/15/2022
0.1.65 840 8/15/2022
0.1.63 807 8/14/2022
0.1.62 822 8/14/2022
0.1.61 768 8/13/2022
0.1.60 873 8/13/2022
0.1.59 879 8/12/2022
0.1.57 801 8/12/2022
0.1.52 849 8/12/2022
0.1.50 823 8/11/2022
0.1.49 881 8/8/2022
0.1.48 846 8/8/2022
0.1.47 790 8/7/2022
0.1.46 856 8/6/2022
0.1.45 856 8/6/2022
0.1.44 847 8/5/2022
0.1.43 884 8/2/2022
0.1.42 848 8/2/2022
0.1.39 901 8/2/2022
0.1.38 872 7/31/2022
0.1.37 880 7/31/2022
0.1.36 883 7/31/2022
0.1.33 873 7/31/2022
0.1.32 873 7/16/2022
0.1.31 828 7/16/2022
0.1.27 899 7/16/2022
0.1.26 887 7/16/2022
0.1.25 866 7/15/2022
0.1.24 891 7/12/2022
0.1.23 836 7/12/2022
0.1.22 894 7/12/2022
0.1.21 866 7/12/2022
0.1.20 815 7/11/2022
0.1.19 910 7/11/2022
0.1.18 899 7/10/2022
0.1.17 879 7/5/2022
0.1.16 849 6/30/2022
0.1.15 847 6/30/2022
0.1.14 924 6/30/2022
0.1.14-beta.IBM-DB2.1 118 6/30/2022
0.1.13 850 6/30/2022
0.1.13-beta.teradata.1 127 6/30/2022
0.1.12 898 6/28/2022
0.1.12-beta.refactor-mapper.1 127 6/28/2022
0.1.11 890 6/28/2022
0.1.10 890 6/28/2022
0.1.10-beta.odbc.8 130 6/28/2022
0.1.10-beta.odbc.7 127 6/28/2022
0.1.10-beta.odbc.4 127 6/26/2022
0.1.9 875 6/25/2022
0.1.9-beta.parse-open-funct... 135 6/25/2022
0.1.8 895 6/18/2022
0.1.7 886 6/18/2022
0.1.7-beta.1 136 6/18/2022
0.1.6 832 6/18/2022
0.1.6-beta.2 140 6/18/2022
0.1.5 854 6/18/2022
0.1.4 925 6/18/2022
0.1.3-beta.7 141 6/18/2022
0.1.3-beta.3 124 6/18/2022
0.1.0 889 6/18/2022
0.1.0-alpha.8 115 6/18/2022
0.1.0-alpha.7 125 6/18/2022
0.1.0-alpha.4 125 6/18/2022