Metoda Server.SetDefaultInitFields (Type, array<String[])
Określa właściwości, które są pobierane, gdy są tworzone wystąpienia obiektów określonego typu.
Przestrzeń nazw: Microsoft.SqlServer.Management.Smo
Zestaw: Microsoft.SqlServer.Smo (w Microsoft.SqlServer.Smo.dll)
Składnia
'Deklaracja
Public Sub SetDefaultInitFields ( _
typeObject As Type, _
ParamArray fields As String() _
)
'Użycie
Dim instance As Server
Dim typeObject As Type
Dim fields As String()
instance.SetDefaultInitFields(typeObject, _
fields)
public void SetDefaultInitFields(
Type typeObject,
params string[] fields
)
public:
void SetDefaultInitFields(
Type^ typeObject,
... array<String^>^ fields
)
member SetDefaultInitFields :
typeObject:Type *
fields:string[] -> unit
public function SetDefaultInitFields(
typeObject : Type,
... fields : String[]
)
Parametry
- typeObject
Typ: System.Type
A Type wartość obiektu systemu, który określa typ obiektu.
- fields
Typ: array<System.String[]
A String wartość, która określa pola właściwość, które mają być pobierane podczas inicjowania obiektu array.
Uwagi
Optymalizacja SMO umożliwia tylko minimalne właściwości mają być załadowane podczas tworzenia obiektu.Kiedy uzyskują właściwości niezainicjowanej SMO sprawia, że indywidualne żądania załadować informacji z wystąpienie SQL Server.Ta metoda umożliwia dostosowanie właściwości, które są inicjowane obiektu w chwili utworzenia dalszej optymalizacji wydajności.
Przykłady
Visual Basic
'Connect to the local, default instance of SQL Server.
Dim srv As Server
srv = New Server
'Reference the AdventureWorks2008R2 database.
Dim db As Database
db = srv.Databases("AdventureWorks2008R2")
'Assign the Table object type to a System.Type object variable.
Dim tb As Table
Dim typ As Type
tb = New Table
typ = tb.GetType
'Assign the current default initialization fields for the Table object type to a
'StringCollection object variable.
Dim sc As StringCollection
sc = srv.GetDefaultInitFields(typ)
'Set the default initialization fields for the Table object type to the CreateDate property.
srv.SetDefaultInitFields(typ, "CreateDate")
'Retrieve the Schema, Name, and CreateDate properties for every table in AdventureWorks2008R2.
'Note that the improvement in performance can be viewed in SQL Profiler.
For Each tb In db.Tables
Console.WriteLine(tb.Schema + "." + tb.Name + " " + tb.CreateDate)
Next
'Set the default initialization fields for the Table object type back to the original settings.
srv.SetDefaultInitFields(typ, sc)
PowerShell
$srv = new-Object Microsoft.SqlServer.Management.Smo.Server("(local)")
$db = New-Object Microsoft.SqlServer.Management.Smo.Database
$db = $srv.Databases.Item("AdventureWorks2008R2")
$tb = new-object Microsoft.SqlServer.Management.Smo.Table
$typ = $tb.GetType()
$sc = $srv.GetDefaultInitFields($typ)
$srv.SetDefaultInitFields($typ, "CreateDate")
foreach ($tb in $db.Tables)
{
Write-Host $tb.Schema,".",$tb.Name,".",$tb.CreateDate
}
$srv.SetDefaultInitFields($typ, $sc)
Zobacz także