1. Trang chủ
  2. » Công Nghệ Thông Tin

Tài liệu Microsoft Windows PowerShell và SQL Server 2005 SMO – Phần 5 ppt

10 336 0
Tài liệu đã được kiểm tra trùng lặp

Đang tải... (xem toàn văn)

THÔNG TIN TÀI LIỆU

Thông tin cơ bản

Tiêu đề Microsoft Windows PowerShell và SQL Server 2005 SMO – Phần 5
Định dạng
Số trang 10
Dung lượng 414,43 KB

Các công cụ chuyển đổi và chỉnh sửa cho tài liệu này

Nội dung

Trong phần V này, chúng tôi sẽ tiếp tục giới thiệu đến các bạn cách sử dụng PowerShell và kịch bản PowerShell trong việc tạo cơ sở dữ liệu và một số vấn đề khác Phương pháp 1 Chúng ta t

Trang 1

The MAK

Phần I và phần II của loạt bài này chúng tôi đã hướng dẫn cho các bạn về cài đặt PowerShell và các cmdlet SMO cũng như WMI đơn giản Trong phần III chúng tôi đã giới thiệu cách lập kịch bản PowerShell và kết nối SQL Server Trong phần IV, chúng tôi giới thiệu về cách sử dụng kịch bản PowerShell để lặp trong toàn nội dung của file và kết nối đến các máy chủ khác

Trong phần V này, chúng tôi sẽ tiếp tục giới thiệu đến các bạn cách sử dụng PowerShell và kịch bản PowerShell trong việc tạo cơ sở dữ liệu và một số vấn

đề khác

Phương pháp 1

Chúng ta thừa nhận rằng sẽ tạo một cơ sở dữ liệu ‘MyDatabase’, trên máy chủ

‘HOME’ với các tính năng mặc định

Thực thi lệnh dưới đây:

[System.Reflection.Assembly]::LoadWithPartialName("Microsof t.SqlServer.SMO")

$Server = new-object

('Microsoft.SqlServer.Management.Smo.Server') 'HOME'

$DataBase = new-object

('Microsoft.SqlServer.Management.Smo.Database')

($Server, "MyDataBase")

$DataBaseDataFile = new-object

('Microsoft.SqlServer.Management.Smo.DataFile')

($FileGrowth, "MyDatabase_Data")

$DataBaseDataFile.FileName = "D:\MyDatabase_Data.mdf"

$DataBaseLogFile = new-object

('Microsoft.SqlServer.Management.Smo.LogFile')

($DataBase, "MyDatabase_Log")

$DataBaseLogFile.FileName = "D:\NewDB_Log.ldf"

Trang 2

Hình 1.0

Lệnh ở trên đã tạo một cơ sở dữ liệu có tên ‘MyDatabase’ trên máy chủ ‘HOME’, bằng cách sử dụng các giá trị và đường dẫn mặc định

Hình 1.1

Hình 1.2

Phương pháp 2

Giả dụ rằng chúng ta phải tạp một cơ sở dữ liệu mới có tên ‘MyDatabase1’ trên máy chủ ‘HOME’ Hãy giả dụ rằng file dữ liệu sẽ là 25MB với file Data và file bản ghi nằm trên ổ D

Thực thi lệnh dưới đây trong PowerShell:

[System.Reflection.Assembly]::LoadWithPartialName("Microsof t.SqlServer.SMO")

Trang 3

('Microsoft.SqlServer.Management.Smo.Server') 'HOME'

$DataBase = new-object

('Microsoft.SqlServer.Management.Smo.Database')

($Server, "MyDataBase1")

$FileGrowth = new-object

('Microsoft.SqlServer.Management.Smo.FileGroup')

($DataBase, "PRIMARY")

$DataBase.FileGroups.Add($FileGrowth)

$DataBaseDataFile = new-object

('Microsoft.SqlServer.Management.Smo.DataFile')

($FileGrowth, "MyDatabas1e_Data")

$FileGrowth.Files.Add($DataBaseDataFile)

$DataBaseDataFile.FileName = "D:\MyDatabase1_Data.mdf"

$DataBaseDataFile.Size = [double](25.0 * 1024.0)

$DataBaseDataFile.GrowthType = "Percent"

$DataBaseDataFile.Growth = 25.0

$DataBaseDataFile.MaxSize = [double](100.0 * 1024.0)

$DataBaseLogFile = new-object

('Microsoft.SqlServer.Management.Smo.LogFile') ($DataBase,

"MyDatabase1_Log")

$DataBaseLogFile.FileName = "D:\MyDatabase1_Log.ldf"

$DataBase.Create()

Cmdlet ở trên tạo một cơ sở dữ liệu ‘Mydatabase1’ trên máy chủ ‘HOME’ với file

dữ liệu 25MB, cả file Data và file bản ghi Log đều được tạo trên ổ D (hình 1.3 và

Trang 4

Hình 1.4

Phương pháp 3

Tạo một kịch bản cho phép chúng ta có thể tạo bất kỳ cơ sở dữ liệu nào trên bất

kỳ máy chủ nào cũng như với bất kỳ kích cỡ và đường dẫn nào mà chúng ta thích

Tạo file dưới đây như thể hiện bên dưới và lưu nó với tên file createdb.ps1

(hình 1.5)

param (

[string] $ServerName,

[string] $DatabaseName,

[Double] $DataSize ,

[string] $DataPath,

[string] $LogPath

)

echo "Creating Database "

echo " -"

echo "Input "

echo "Server Name : $ServerName"

echo "Database Name : $DatabaseName"

echo "Data Size : $DataSize"

echo "Data File Path : $DataPath"

echo "Log File Path : $LogPath"

$LogicalDataFile=$DatabaseName + "_Data"

$LogicalLogFIle=$DatabaseName + "_Log"

$datapath1=$DataPath + "\" + $DatabaseName + "_Data.mdf"

$Logpath1=$LogPath + "\" + $DatabaseName + "_Log.ldf"

$DataSize1=[double]($DataSize * 1024.0)

[System.Reflection.Assembly]::LoadWithPartialName("Microsof t.SqlServer.SMO")

Trang 5

('Microsoft.SqlServer.Management.Smo.Server') $ServerName

$DataBase = new-object

('Microsoft.SqlServer.Management.Smo.Database') ($Server,

$DatabaseName)

$FileGrowth = new-object

('Microsoft.SqlServer.Management.Smo.FileGroup')

($DataBase, "PRIMARY")

$DataBase.FileGroups.Add($FileGrowth)

$DataBaseDataFile = new-object

('Microsoft.SqlServer.Management.Smo.DataFile')

($FileGrowth, $LogicalDataFile)

$FileGrowth.Files.Add($DataBaseDataFile)

$DataBaseDataFile.FileName = $datapath1

$DataBaseDataFile.Size = [double]( $DataSize1 )

$DataBaseDataFile.GrowthType = "Percent"

$DataBaseDataFile.Growth = 25.0

$DataBaseDataFile.MaxSize = [double](100.0 * 1024.0)

$DataBaseLogFile = new-object

('Microsoft.SqlServer.Management.Smo.LogFile') ($DataBase,

$LogicalLogFIle)

$DataBaseLogFile.FileName = $Logpath1

$DataBase.Create()

echo "Output "

echo "Logical name of Data is $LogicalDataFile"

echo "Logical name of Log is $LogicalLogFile"

echo "Data File Path is $datapath1"

echo "Log file path is $LogPath1"

Trang 6

Lúc này thực thi file kịch bản PowerShell như thể hiện trong hình bên dưới (hình 1.6)

./createdb.ps1 HOME MyDatabase2 30 D: D:

Lưu ý:

HOME là tên máy chủ

MyDatabase2 là tên cơ sở dữ liệu

30 là kích thước dữ liệu tính theo MB

D: là vị trí của đường dẫn dữ liệu

D: là vị trí của đường dẫn bản ghi

Đầu ra

PS C:\ps> /createdb.ps1 HOME MyDatabase2 30 D: D:

Creating Database

-

Input

Trang 7

Data Size : 30

Data File Path : D:

Log File Path : D:

GAC Version Location

- - -

True v2.0.50727

C:\WINDOWS\assembly\GAC_MSIL\Microsoft.SqlServer.SMO\9.0.24 2.0 89845dcd8080cc91\Microsoft.Sql

Output

Logical name of Data is MyDatabase2_Data

Logical name of Log is MyDatabase2_Log

Data File Path is D:\MyDatabase2_Data.mdf

Log file path is D:\MyDatabase2_Log.ldf

Size of the file is 30720

Hình 1.6 Đoạn mã dưới đây tạo đầu ra mong muốn

Mã lệnh

[System.Reflection.Assembly]::LoadWithPartialName("Microsof t.SqlServer.SMO")

Đầu ra

GAC Version Location

Trang 8

Điều này có thể tránh bằng cách chuyển hướng đầu ra thành NULL

param (

[string] $ServerName,

[string] $DatabaseName,

[Double] $DataSize ,

[string] $DataPath,

[string] $LogPath

)

echo "Creating Database "

echo " -"

echo "Input "

echo "Server Name : $ServerName"

echo "Database Name : $DatabaseName"

echo "Data Size : $DataSize"

echo "Data File Path : $DataPath"

echo "Log File Path : $LogPath"

$LogicalDataFile=$DatabaseName + "_Data"

$LogicalLogFIle=$DatabaseName + "_Log"

$datapath1=$DataPath + "\" + $DatabaseName + "_Data.mdf"

$Logpath1=$LogPath + "\" + $DatabaseName + "_Log.ldf"

$DataSize1=[double]($DataSize * 1024.0)

[System.Reflection.Assembly]::LoadWithPartialName("Microsof t.SqlServer.SMO") | out-null

$Server = new-object

('Microsoft.SqlServer.Management.Smo.Server') $ServerName

$DataBase = new-object

('Microsoft.SqlServer.Management.Smo.Database') ($Server,

$DatabaseName)

$FileGrowth = new-object

('Microsoft.SqlServer.Management.Smo.FileGroup')

($DataBase, "PRIMARY")

$DataBase.FileGroups.Add($FileGrowth)

$DataBaseDataFile = new-object

Trang 9

$FileGrowth.Files.Add($DataBaseDataFile)

$DataBaseDataFile.FileName = $datapath1

$DataBaseDataFile.Size = [double]( $DataSize1 )

$DataBaseDataFile.GrowthType = "Percent"

$DataBaseDataFile.Growth = 25.0

$DataBaseDataFile.MaxSize = [double](100.0 * 1024.0)

$DataBaseLogFile = new-object

('Microsoft.SqlServer.Management.Smo.LogFile') ($DataBase,

$LogicalLogFIle)

$DataBaseLogFile.FileName = $Logpath1

$DataBase.Create()

echo "Output "

echo "Logical name of Data is $LogicalDataFile"

echo "Logical name of Log is $LogicalLogFile"

echo "Data File Path is $datapath1"

echo "Log file path is $LogPath1"

echo "Size of the file is $DataSize1"

Thực thi file kịch bản PowerShell như hình bên dưới (Hình 1.7)

./createdb.ps1 HOME MyDatabase2 30 D: D:

Trang 10

Đầu ra

PS C:\ps> /createdb.ps1 HOME MyDatabase2 30 D: D:

Creating Database

-

Input

Server Name : HOME

Database Name : MyDatabase2

Data Size : 30

Data File Path : D:

Log File Path : D:

Output

Logical name of Data is MyDatabase2_Data

Logical name of Log is MyDatabase2_Log

Data File Path is D:\MyDatabase2_Data.mdf

Log file path is D:\MyDatabase2_Log.ldf

Size of the file is 30720

 

Ngày đăng: 22/12/2013, 02:16

HÌNH ẢNH LIÊN QUAN

Hình 1.6   Đoạn mã dưới đây tạo đầu ra mong muốn. - Tài liệu Microsoft Windows PowerShell và SQL Server 2005 SMO – Phần 5 ppt
Hình 1.6 Đoạn mã dưới đây tạo đầu ra mong muốn (Trang 7)

TỪ KHÓA LIÊN QUAN

w