SQL Server 2005 でインデックス付きのビューに関連する SMO オブジェクトのスクリプトも、インデックス付きビューで定義されているスクリプトの一部が生成されません。

文書翻訳 文書翻訳
文書番号: 918480
# をバグ: 403696 (SQLBUDT)
すべて展開する | すべて折りたたむ

目次

現象

場合 Microsoft SQL Server 2005 のクラスター化インデックス、インデックス付きのビューで定義されているスクリプトの一部でインデックス付きのビューに関連する SQL Server 管理オブジェクト (SMO) のオブジェクトをスクリプトは生成されません。したがって、ビューを最初に指定するのには、クラスター化インデックスが必要なオブジェクトを作成するのには、生成されたスクリプトを実行できません。

回避策

この問題を回避には、どのように、スクリプトは、SMO オブジェクト、に応じて、次の方法のいずれかを使用してインデックス付きのビューに関連します。

SMO オブジェクトのスクリプト メソッドを呼び出します。

  1. 定義します。 ScriptingOptions オブジェクトです。
  2. 値の設定、 インデックス プロパティが ScriptingOptions true オブジェクトです。
  3. 電話の代わりに、 スクリプト SMO オブジェクトの呼び出し方法を Script(ScriptingOptions) SMO オブジェクトのメソッドです。これを行うには、パスを ScriptingOptions オブジェクトのメソッド スクリプト.
たとえば、次のコード例のようなコードを使用します。

Microsoft の Visual C#

Server srv = new Server(@".\MySQLServer");
Database db = srv.Databases["MyDB"];
View vw = db.Views["MyView"];

//Define the ScriptingOptions object.
ScriptingOptions sco = new ScriptingOptions();

//Set the value of the Indexes property.
sco.Indexes = true;

//Specify the values of the other members of the sco object.

System.Collections.Specialized.StringCollection script = null;

//Pass the ScriptingOptions object.
script = vw.Script(sco);

foreach (string str in script)
{
    Console.WriteLine(str);
    Console.WriteLine("go");
}

マイクロソフトの Visual Basic。NET

Dim srv As Server = New Server(".\MySQLServer")
Dim db As Database = srv.Databases("MyDB")
Dim vw As View = db.Views("MyView")

'Define the ScriptingOptions object.
Dim sco As ScriptingOptions = New ScriptingOptions()

'Set the value of the Indexes property.
sco.Indexes = True

'Specify the values of the other members of the sco object.

'Pass the ScriptingOptions object.
Dim script As System.Collections.Specialized.StringCollection = vw.Script(sco)

Dim str As String
For Each str In script
    Console.WriteLine(str)
    Console.WriteLine("go")
Next str

スクリプト オブジェクトを使用します。

  1. 値の設定、 Options.Indexes メンバー、 スクリプト true オブジェクトです。
  2. スクリプトを生成するには、[SMO オブジェクトへの参照を渡す、 スクリプト メソッドは、 スクリプト オブジェクトです。
たとえば、次のコード例のようなコードを使用します。

Visual C#

Server srv = new Server(@".\MySQLServer");
Database db = srv.Databases["MyDB"];
View vw = db.Views["MyView"];

Scripter scr = new Scripter();
scr.Server = srv;

//Set the value of the Options.Indexes member.
scr.Options.Indexes = true;

//Specify the value of the other members of the scr.Options property.

SqlSmoObject[] objs = new SqlSmoObject[1];
objs[0] = vw;

System.Collections.Specialized.StringCollection script = null;

//Pass the SMO object reference to the Script method.
script = scr.Script(objs);

foreach (string str in script)
{
    Console.WriteLine(str);
    Console.WriteLine("go");
}

Visual Basic。NET

Dim srv As Server = New Server(".\MySQLServer")
Dim db As Database = srv.Databases("MyDB")
Dim vw As View = db.Views("MyView")

Dim scr As Scripter = New Scripter()
scr.Server = srv

'Set the value of the Options.Indexes member.
scr.Options.Indexes = True

'Specify the value of the other members of the scr.Options object.

Dim objs As SqlSmoObject() = New SqlSmoObject() {vw}

'Pass the ScriptingOptions object.
Dim script As System.Collections.Specialized.StringCollection = scr.Script(objs)

Dim str As String
For Each str In script
    Console.WriteLine(str)
    Console.WriteLine("go")
Next str
メモ は、 オプション プロパティは スクリプト オブジェクトの取得を ScriptingOptions オブジェクトです。

転送オブジェクトを使用します。

  1. 値の設定、 Options.Indexes メンバー、 転送 オブジェクトに true.
  2. 使用するスクリプトを生成するには、 ScriptTransfer メソッドは、 転送 オブジェクトです。
たとえば、次のコード例のようなコードを使用します。

Visual C#

Server srv = new Server(@".\MySQLServer");
Database db = srv.Databases["MyDB"];

Transfer trans = new Transfer(db);

//Set the value of the Options.Indexes member.
trans.Options.Indexes = true;

//Specify the value of the other members of the trans.Options property.

System.Collections.Specialized.StringCollection script = null;

//Use the ScriptTransfer method of the Transfer object to generate the script.
script = trans.ScriptTransfer();

foreach (string str in script)
{
    Console.WriteLine(str);
    Console.WriteLine("go");
}

Visual Basic。NET

Dim srv As Server = New Server(".\MySQLServer")
Dim db As Database = srv.Databases("MyDB")

Dim trans As Transfer = New Transfer(db)

'Set the value of the Options.Indexes member.
trans.Options.Indexes = True

'Specify the value of the other members of the trans.Options property.

'Use the ScriptTransfer method of the Transfer object to generate the script.
Dim script As System.Collections.Specialized.StringCollection = trans.ScriptTransfer()

Dim str As String
For Each str In script
    Console.WriteLine(str)
    Console.WriteLine("go")
Next str
メモ は、 オプション プロパティは 転送 オブジェクトの取得を ScriptingOptions オブジェクトです。

状況

マイクロソフトでは、この「対象」に記載されているマイクロソフト製品の問題として認識しています。

関連情報

詳細については、 ScriptingOptions クラスには、次のマイクロソフト開発ネットワーク (MSDN) Web サイトを参照してください。
http://msdn2.microsoft.com/en-us/library/microsoft.sqlserver.management.smo.scriptingoptions.aspx

プロパティ

文書番号: 918480 - 最終更新日: 2011年7月19日 - リビジョン: 3.0
キーワード:?
kbtshoot kbprb kbexpertiseadvanced kbmt KB918480 KbMtja
機械翻訳の免責
重要: このサポート技術情報 (以下「KB」) は、翻訳者による翻訳の代わりに、マイクロソフト機械翻訳システムによって翻訳されたものです。マイクロソフトは、お客様に、マイクロソフトが提供している全ての KB を日本語でご利用いただけるように、翻訳者による翻訳 KB に加え機械翻訳 KB も提供しています。しかしながら、機械翻訳の品質は翻訳者による翻訳ほど十分ではありません。誤訳や、文法、言葉使い、その他、たとえば日本語を母国語としない方が日本語を話すときに間違えるようなミスを含んでいる可能性があります。マイクロソフトは、機械翻訳の品質、及び KB の内容の誤訳やお客様が KB を利用されたことによって生じた直接または間接的な問題や損害については、いかなる責任も負わないものとします。マイクロソフトは、機械翻訳システムの改善を継続的に行っています。
英語版 KB:918480
Microsoft Knowledge Base の免責: Microsoft Knowledge Baseに含まれている情報は、いかなる保証もない現状ベースで提供されるものです。Microsoft Corporation及びその関連会社は、市場性および特定の目的への適合性を含めて、明示的にも黙示的にも、一切の保証をいたしません。さらに、Microsoft Corporation及びその関連会社は、本文書に含まれている情報の使用及び使用結果につき、正確性、真実性等、いかなる表明・保証も行ないません。Microsoft Corporation、その関連会社及びこれらの権限ある代理人による口頭または書面による一切の情報提供またはアドバイスは、保証を意味するものではなく、かつ上記免責条項の範囲を狭めるものではありません。Microsoft Corporation、その関連会社 及びこれらの者の供給者は、直接的、間接的、偶発的、結果的損害、逸失利益、懲罰的損害、または特別損害を含む全ての損害に対して、状況のいかんを問わず一切責任を負いません。(Microsoft Corporation、その関連会社 またはこれらの者の供給者がかかる損害の発生可能性を了知している場合を含みます。) 結果的損害または偶発的損害に対する責任の免除または制限を認めていない地域においては、上記制限が適用されない場合があります。なお、本文書においては、文書の体裁上の都合により製品名の表記において商標登録表示、その他の商標表示を省略している場合がありますので、予めご了解ください。

フィードバック

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com