91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Powershell 查詢SQL數據庫資料

發布時間:2020-06-16 16:04:09 來源:網絡 閱讀:1815 作者:beanxyz 欄目:數據庫

豆子對SQL Server自帶的sqlps模塊并不熟悉。昨天發現Don Jones提供的一個SQL模塊,理論上支持任何兼容ODBC Driver的數據庫(MySQL, MSSQL, Oracle 等等),原理就是調用.Net框架的一些底層函數。使用起來很方便順手,也不需要學習新的技能。


https://technet.microsoft.com/zh-cn/magazine/hh855069.aspx


下載以后,發現這個模塊其實就只包括了兩個函數,一個用來查詢,另外一個用來修改刪除。兩個函數都只有3個參數,分別是connectionString, 需要執行的SQL語句,以及是否為SQLServer。 第一個的格式根據數據庫有所不同,可以去http://www.connectionstrings.com/ 看對應的例子。 第二個就是真正執行的SQL語句,最后一個其實是個布爾值,如果輸入了這個參數就是真,沒輸入就是假。


function Get-DatabaseData {
    [CmdletBinding()]
    param (
        [string]$connectionString,
        [string]$query,
        [switch]$isSQLServer
    )
    if ($isSQLServer) {
        Write-Verbose 'in SQL Server mode'
        $connection = New-Object -TypeName `
            System.Data.SqlClient.SqlConnection
    } else {
        Write-Verbose 'in OleDB mode'
        $connection = New-Object -TypeName `
            System.Data.OleDb.OleDbConnection
    }
    $connection.ConnectionString = $connectionString
    $command = $connection.CreateCommand()
    $command.CommandText = $query
    if ($isSQLServer) {
        $adapter = New-Object -TypeName `
        System.Data.SqlClient.SqlDataAdapter $command
    } else {
        $adapter = New-Object -TypeName `
        System.Data.OleDb.OleDbDataAdapter $command
    }
    $dataset = New-Object -TypeName System.Data.DataSet
    $adapter.Fill($dataset)
    $dataset.Tables[0]
    $connection.close()
}


function Invoke-DatabaseQuery {
    [CmdletBinding(SupportsShouldProcess=$True,
                   ConfirmImpact='Low')]
    param (
        [string]$connectionString,
        [string]$query,
        [switch]$isSQLServer
    )
    if ($isSQLServer) {
        Write-Verbose 'in SQL Server mode'
        $connection = New-Object -TypeName `
            System.Data.SqlClient.SqlConnection
    } else {
        Write-Verbose 'in OleDB mode'
        $connection = New-Object -TypeName `
            System.Data.OleDb.OleDbConnection
    }
    $connection.ConnectionString = $connectionString
    $command = $connection.CreateCommand()
    $command.CommandText = $query
    if ($pscmdlet.shouldprocess($query)) {
        $connection.Open()
        $command.ExecuteNonQuery()
        $connection.close()
    }
}



下載腳本之后,重命名然后拷貝到$env:psmodulepath對應的路徑上就可以使用了


Powershell 查詢SQL數據庫資料

現在看看怎么使用。


例如:豆子想查詢一下某個數據庫的備份記錄。首先登陸MSSQL2012 Express的管理界面,利用T-SQL語句查詢看看應該的效果。


Powershell 查詢SQL數據庫資料


把T-SQL的語句拷貝下來,作為傳入的字符串參數,如下所示,調用第一個查詢的函數


Import-Module db
$ConnectionString = "server=sydav01\Sophos;database=sophos521;trusted_connection=True;"
$query="
SELECT TOP 100
s.database_name,
CAST(CAST(s.backup_size / 1000000 AS INT) AS VARCHAR(14)) + ' ' + 'MB' AS bkSize,
CAST(DATEDIFF(second, s.backup_start_date,
s.backup_finish_date) AS VARCHAR(4)) + ' ' + 'Seconds' TimeTaken,
s.backup_start_date,
CAST(s.first_lsn AS VARCHAR(50)) AS first_lsn,
CAST(s.last_lsn AS VARCHAR(50)) AS last_lsn,
CASE s.[type] WHEN 'D' THEN 'Full'
WHEN 'I' THEN 'Differential'
WHEN 'L' THEN 'Transaction Log'
END AS BackupType,
s.server_name,
s.recovery_model
FROM msdb.dbo.backupset s
where s.database_name='SOPHOS521'
"
Get-DatabaseData  -connectionString $ConnectionString -isSQLServer -query $query | ft


結果如下所示


Powershell 查詢SQL數據庫資料


成功獲取,可以看見和在圖形界面下看見的結果是一樣的。

附件:http://down.51cto.com/data/2367697
向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

同德县| 拉萨市| 上饶县| 遵义市| 宁乡县| 灌阳县| 万载县| 恭城| 沈丘县| 慈溪市| 昆明市| 萍乡市| 贵阳市| 买车| 保康县| 铜川市| 新乐市| 瑞金市| 东源县| 昭觉县| 神农架林区| 平江县| 龙陵县| 宁明县| 登封市| 长宁区| 张家口市| 武邑县| 汕尾市| 禹州市| 河曲县| 台江县| 安庆市| 类乌齐县| 齐河县| 湟源县| 东山县| 吴堡县| 偏关县| 潢川县| 瓮安县|