sql >> データベース >  >> RDS >> Sqlserver

プログラムによるSQLコードの生成

    すでに述べたように、これを行うにはSMOを使用します。これは、C#を使用してデータベースのスクリプトを作成する例です。いくつかのオプションについて説明しましたが、@ David Brabantの投稿にあるように、多くのオプションの値を指定できます。 。

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

    このリンクは、ストアドプロシージャの取得とスクリプト作成に役立つ場合があります



    1. 単一のクエリでの複数のselectステートメント

    2. SQLServer2019でMDFファイルを管理する

    3. Postgresql更新時の現在のタイムスタンプ

    4. WITH句とサブクエリの違いは?