sql >> Database >  >> RDS >> Sqlserver

SQL-code programmatisch genereren

Zoals al vermeld, kun je SMO gebruiken om dit te doen, hier is een voorbeeld van het gebruik van C# om een ​​database te scripten, ik noemde een paar opties, maar zoals het is in de post van @David Brabant, kun je de waarden van veel opties specificeren .

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();
 }

Deze link kan u helpen bij het verkrijgen en scripten van opgeslagen procedures



  1. Postgres pg_dump dumpt database elke keer in een andere volgorde

  2. Oracle SQL - Hoe de hoogste 5 waarden van een kolom op te halen

  3. mysql int als valuta selecteren of int converteren naar valutaformaat?

  4. SQLAlchemy, Psycopg2 en Postgresql KOPIE