3

我在 powershell 中编写了一个脚本,该脚本应该连接到 MySQL 服务器,创建一个新数据库,然后对该数据库运行查询命令。我有一个预制的 .sql 文件,其中包含要执行的所有命令,但是我的代码似乎存在问题,它从未真正执行过 .sql 文件。任何帮助,将不胜感激。我的代码如下。

[void][system.reflection.Assembly]::LoadWithPartialName("MySql.Data")

#Creates a connection to the server
$connStr ="server=mySql;Persist Security Info=false;user id=" + "username" + ";pwd=" + "pass" + ";"
$conn = New-Object MySql.Data.MySqlClient.MySqlConnection($connStr)

#Open connection
$conn.Open()

#Drops database if it currently exists
$cmd = New-Object MySql.Data.MySqlClient.MySqlCommand
$cmd.Connection  = $conn
$cmd.CommandText = "DROP DATABASE IF EXISTS " + $dbname
$cmd.ExecuteNonQuery()

#Create the new database
$cmd.CommandText = 'CREATE SCHEMA `' + $dbname + '`'
$cmd.ExecuteNonQuery()

#Load the sql file
$sql = (Get-Content C:\"path to sql file") -join "'r'n"
$cmd.CommandText = $sql

#Close connection
$conn.Close()
4

1 回答 1

1

你不是错过了 $cmd.ExecuteNonQuery() 调用吗?看起来你正在用文字“'r'n”加入文件行。您需要改用反引号字符(例如“`r`n”)。我会使用 Out-String cmdlet 将文件内容转换为一个字符串:

#Load the sql file
$sql = Get-Content C:\"path to sql file" | Out-String
$cmd.CommandText = $sql
$cmd.ExecuteNonQuery()
于 2012-05-16T20:34:42.120 回答