sql-server - Powershell Invoke-Sqlcmd 命中错误的数据库 - 系统,为什么?

标签 sql-server azure powershell terraform azure-sql-server

我通过 terraform 部署 mssql 服务器、防火墙、数据库和 sql 登录(以及更多)。

服务器、防火墙和数据库部署正确,但通过 powershell 登录失败并出现以下错误:

': exit status 1. Output: Invoke-Sqlcmd : Database 'System' does not exist. Make sure that the name is entered correctly.

我的 terraform 代码如下所示:

  resource "azurerm_mssql_server" "itan-mssql-server" {
  administrator_login = "itanadmin"
  administrator_login_password = random_password.itan-mssql-admin-password.result
  location = var.location
  name = "itan-mssql-server"
  resource_group_name = var.resource-group-name
  version = "12.0"

  depends_on = [
    azurerm_resource_group.itan-west-europe-resource-group]
}


resource "azurerm_sql_firewall_rule" "itan-mssql-server-firewall-rule" {
  start_ip_address = "${chomp(data.http.myip.body)}"
  end_ip_address = "${chomp(data.http.myip.body)}"
  name = "itan-tf-client-executer-ip"
  resource_group_name = var.resource-group-name
  server_name = azurerm_mssql_server.itan-mssql-server.name
  depends_on = [azurerm_mssql_server.itan-mssql-server]
}

resource "azurerm_mssql_database" "itan-mssql-database" {
  name = "itan"
  server_id = azurerm_mssql_server.itan-mssql-server.id
  sku_name = "basic"
  max_size_gb = "2"

  depends_on = [
    azurerm_mssql_server.itan-mssql-server]
}

resource "null_resource" "itan-mssql-logins" {
  provisioner "local-exec" {
    command =<<EOT

      $server = Get-AzSqlServer
           
      $createReaderLogin = @{
        'ServerInstance' = "${azurerm_mssql_server.itan-mssql-server.fully_qualified_domain_name}"
        'Database' = "itan"
        'Username' = "${azurerm_mssql_server.itan-mssql-server.administrator_login}"
        'Password' = "${random_password.itan-mssql-admin-password.result}"
        'Query' = "SELECT * FROM Students";
      }

      Invoke-Sqlcmd $createReaderLogin

    EOT
    interpreter = ["PowerShell", "-Command"]
  }
  
  depends_on = [azurerm_sql_firewall_rule.itan-mssql-server-firewall-rule]
}

最后一部分,null_resource 被解析为如下内容:

  $server = Get-AzSqlServer

      $createReaderLogin = @{
        'ServerInstance' = "server.database.windows.net"
        'Database' = "database"
        'Username' = "admin"
        'Password' = "***********"
        'Query' = "SELECT * FROM Students";
      }
  • 已经销毁,不用担心密码。
  • 我知道我需要在主数据库上创建登录名,并在正确的数据库上创建下一个用户,此选择*只是查询失败的一个示例

我已经测试过了,在创建服务器、防火墙、数据库之后,我能够将 azure mssql 与 mssql 连接起来。但运行 Invoke-SqlCmd 失败,并显示 “数据库‘系统’不存在”

为什么?已经为此苦苦挣扎了大约两天。

基本上,我正在尝试创建具有专用 sql 权限(db_read/db_write)的登录名/用户。

最佳答案

我用单长线而不是多线解决了这个问题: null_resource

的新代码
resource "null_resource" "itan-mssql-logins" {
  provisioner "local-exec" {
    command = "Invoke-Sqlcmd -ServerInstance ${azurerm_mssql_server.itan-mssql-server.fully_qualified_domain_name} -Database master -Username itanadmin -Password '${random_password.itan-mssql-admin-password.result}' -Query \"CREATE LOGIN [itanreader] WITH PASSWORD=N'${random_password.itan-mssql-reader-password.result}'\""
    interpreter = ["PowerShell", "-Command"]
  }
  
  depends_on = [azurerm_sql_firewall_rule.itan-mssql-server-firewall-rule, azurerm_mssql_database.itan-mssql-database]
}

所有参数看起来都一样,但这个有效。不知道你为什么。

关于sql-server - Powershell Invoke-Sqlcmd 命中错误的数据库 - 系统,为什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63205320/

相关文章:

sql-server - 带有临时表的 SSRS 存储过程

c# - 消息 - 更新 Azure 上的函数版本

powershell - Azure Powershell 用于停止订阅中的 VM

powershell - 在 PowerShell 中,如何在文件中定义函数并从 PowerShell 命令行调用它?

string - Powershell子串切割

sql-server - 从 VBA 执行 SQL Server 存储过程并检索所有消息和结果集

sql - 使用 SQL 将行转换为列

c# - 关于分布式 c# 应用程序共享数据库选项的建议

c# - 在 C# 中为 block blob 生成共享访问签名

azure - Terraform - 条件结果类型不一致