Như nó đã được đề cập, bạn sử dụng SMO để thực hiện việc này, đây là một ví dụ sử dụng C # để tập lệnh cho cơ sở dữ liệu, tôi đã đề cập đến một số tùy chọn, nhưng như trong bài đăng của @David Brabant, bạn có thể chỉ định giá trị của nhiều tùy chọn .
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();
}
Liên kết này có thể giúp bạn lấy và viết kịch bản các thủ tục đã lưu trữ