Skip to content

Commit

Permalink
Escape DB names correctly
Browse files Browse the repository at this point in the history
I’m trying to use SchemaZen for a database whose name contains a dot
(i.e. `MyDatabase.Dev`). Presently it fails because the DB names are
not being escaped (with square brackets) correctly. This fixes that.
  • Loading branch information
Benjamin Hodgson committed Mar 10, 2016
1 parent 83113cf commit a8df6a8
Showing 1 changed file with 7 additions and 4 deletions.
11 changes: 7 additions & 4 deletions model/DBHelper.cs
Original file line number Diff line number Diff line change
Expand Up @@ -39,13 +39,16 @@ public static void ExecBatchSql(string conn, string sql) {

public static void DropDb(string conn) {
var cnBuilder = new SqlConnectionStringBuilder(conn);
var dbName = cnBuilder.InitialCatalog;
if (DbExists(cnBuilder.ToString())) {
var initialCatalog = cnBuilder.InitialCatalog;

var dbName = "[" + initialCatalog + "]";

if (DbExists(cnBuilder.ToString())) {
cnBuilder.InitialCatalog = "master";
ExecSql(cnBuilder.ToString(), "ALTER DATABASE " + dbName + " SET SINGLE_USER WITH ROLLBACK IMMEDIATE");
ExecSql(cnBuilder.ToString(), "drop database " + dbName);

cnBuilder.InitialCatalog = dbName;
cnBuilder.InitialCatalog = initialCatalog;
ClearPool(cnBuilder.ToString());
}
}
Expand All @@ -54,7 +57,7 @@ public static void CreateDb(string conn) {
var cnBuilder = new SqlConnectionStringBuilder(conn);
var dbName = cnBuilder.InitialCatalog;
cnBuilder.InitialCatalog = "master";
ExecSql(cnBuilder.ToString(), "CREATE DATABASE " + dbName);
ExecSql(cnBuilder.ToString(), "CREATE DATABASE [" + dbName + "]");
}

public static bool DbExists(string conn) {
Expand Down

0 comments on commit a8df6a8

Please sign in to comment.