sql >> Databasteknik >  >> RDS >> Sqlserver

Genererar sql-kod programmatiskt

Som det redan har nämnts, kan du använda SMO för att göra detta, här är ett exempel med C# för att skripta en databas, jag nämnde några alternativ, men som det är i inlägget av @David Brabant, kan du specificera värdena för många alternativ .

public string ScriptDatabase()
{
      var sb = new StringBuilder();

      var server = new Server(@"ServerName");
      var databse = server.Databases["DatabaseName"];

      var scripter = new Scripter(server);
      scripter.Options.ScriptDrops = false;
      scripter.Options.WithDependencies = true;
      scripter.Options.IncludeHeaders = true;
      //And so on ....


      var smoObjects = new Urn[1];
      foreach (Table t in databse.Tables)
      {
          smoObjects[0] = t.Urn;
          if (t.IsSystemObject == false)
          {
              StringCollection sc = scripter.Script(smoObjects);

              foreach (var st in sc)
              {
                  sb.Append(st);
              }
           }
       }
            return sb.ToString();
 }

Den här länken kan hjälpa dig att hämta och skripta lagrade procedurer



  1. Bästa nya funktioner i PostgreSQL 14

  2. Se om en tabell har en DEFAULT-begränsning i SQL Server med OBJECTPROPERTY()

  3. Bästa sättet att förkorta UTF8-strängen baserat på bytelängd

  4. Funktioner med variabelt antal ingångsparametrar