gpt4 book ai didi

mysql - 使用powershell变量查询MYSQL DB

转载 作者:行者123 更新时间:2023-11-29 06:41:15 26 4
gpt4 key购买 nike

我试图将 MYSQL DB 中的数据解析到 powershell 中,然后使用该数据根据 powershell 变量和 upn 更新 AD 帐户,但我无法使 MySQL 数据和 powershell 变量正常运行。我不是 SQL 专家,所以不确定它是否使用 MYSQL 语法或 powershell 脚本的编写方式。

这是脚本末尾的命令,我无法运行,但我在下面包含了整个代码

$mysqlquery1 =  Invoke-MySqlQuery -Connection $oConnection  -Query 'Select * from user_informations where login='"$user.sAMAccountName" 
<小时/>
#
# Script.ps1
#
$GetUsersemail = Get-ADUser -Filter * -Properties mail, sAMAccountName, userPrincipalName -SearchBase "OUNAME"| Where-Object {($_.mail -ne $null)} | Select-Object mail,sAMAccountName,userPrincipalName

Import-Module activedirectory
Set-Location C:\MySQL\MySQL-master
Unblock-File -Path .\MySQL.psm1
Import-Module .\mysql.psm1

[System.Reflection.Assembly]::LoadWithPartialName("MySql.Data")
[string]$sMySQLUserName = sqluserid
[string]$sMySQLPW = 'password'
[string]$sMySQLDB = 'DB'
[string]$sMySQLHost = 'IP'
[string]$sConnectionString = "server="+$sMySQLHost+";port=3306;uid=" + $sMySQLUserName + ";pwd=" + $sMySQLPW + ";database="+$sMySQLDB+";SslMode=none"

$oConnection = New-Object MySql.Data.MySqlClient.MySqlConnection($sConnectionString)
$Error.Clear()

try

{
$oConnection.Open()
write-warning ("it connected")
$dataSet = New-Object System.Data.DataSet
}
catch
{
write-warning ("Could not open a connection to Database $sMySQLDB on Host $sMySQLHost. Error: "+$Error[0].ToString())
}




ForEach ($user in $GetUsersemail) {
$spn = $null
$fullemail = $null
$spnsplit = $user.mail.split("@")
$spn = "@" + $spnsplit[1]
$fullemail = $user.sAMAccountName + $spn

if ($fullemail -ne $user.userPrincipalName) {


Switch ($spn) {
"@upn1.com" {
Set-ADUser -UserPrincipalName $fullemail -Identity $user.sAMAccountName
}
"@upn2.com" {
Set-ADUser -UserPrincipalName $fullemail -Identity $user.sAMAccountName
}
"@upn3" {
Set-ADUser -UserPrincipalName $fullemail -Identity $user.sAMAccountName
}
"@upn4" {
Set-ADUser -UserPrincipalName $fullemail -Identity $user.sAMAccountName
}
"@upn5" {
Set-ADUser -UserPrincipalName $fullemail -Identity $user.sAMAccountName
}
"@upn6" {
Set-ADUser -UserPrincipalName $fullemail -Identity $user.sAMAccountName
}
"@upn7" {
Set-ADUser -UserPrincipalName $fullemail -Identity $user.sAMAccountName
}
"@upn8" {
Set-ADUser -UserPrincipalName $fullemail -Identity $user.sAMAccountName
}
}
}

$mysqlquery1 = Invoke-MySqlQuery -Connection $oConnection -Query 'Select * from user_informations where login='"$user.sAMAccountName"
}

$oConnection.Close()

最佳答案

您需要小心 PowerShell 字符串引用;单引号字符串 'abc' 内部不能有变量,双引号字符串 "abc" 可以,例如"abc $xyz" 但您不能使用 "abc $xyz.property" 因为 PowerShell 将 .property 视为文本的一部分,而不是变量的一部分。为此,您需要一个子表达式 "abc $($xyz.property)"

根据您需要如何引用字符串,尝试:

"select * from user_informations where login='$($user.sAMAccountName)'" 

双引号在外面,所以你可以在里面放单引号和子表达式。结果应该是这样的:

select * from user_informations where login='john.hancock'

(应该是user_information,单数吗?)

关于mysql - 使用powershell变量查询MYSQL DB,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51523087/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com