[英]Can't create database in Windows 8 with SQL Server 2008 R2
我正在尝试运行为我们的应用程序创建数据库的安装脚本,这些脚本在升级到Windows 8之前一直在工作。安装SQL Server 2008 R2 Express并运行执行以下命令的脚本以创建数据库:
USE [master]
GO
SET NUMERIC_ROUNDABORT OFF
GO
SET XACT_ABORT, ANSI_PADDING, ANSI_WARNINGS, CONCAT_NULL_YIELDS_NULL, ARITHABORT, QUOTED_IDENTIFIER, ANSI_NULLS, NOCOUNT ON
GO
SET TRANSACTION ISOLATION LEVEL SERIALIZABLE
GO
IF EXISTS (SELECT name FROM sys.databases WHERE name = N'$(db)')
BEGIN
ALTER Database [$(db)] SET SINGLE_USER WITH ROLLBACK IMMEDIATE
DROP Database [$(db)]
END
GO
CREATE DATABASE [$(db)]
GO
USE [$(db)]
GO
我可以运行以下命令行来执行脚本:
sqlcmd -i test.sql -S .\wizrms -d test -U sa -P W1zard
我收到以下错误:
消息4060,级别11,状态1,服务器。\\ WIZRMS,第1行
无法打开登录请求的数据库“测试”,登录失败。消息18456,级别14,状态1服务器。\\ WIZRMS,第1行
用户“ sa”的登录失败。
我可以使用具有相同凭据的SQL Server Management Studio登录,并使用相同的命令创建数据库。
所有这些都可以在Windows 7上运行。我的假设是Win 8中必须处理安全性更改。
可能由于参数-d test
,指定了尚不存在的初始数据库。 当您运行的脚本创建数据库时,通常首先登录master
数据库,然后创建数据库,然后切换到该数据库以完成所有剩余工作。 但是,在创建数据库之前尝试打开该数据库肯定会产生您在此处发布的错误。
SSMS正是这样做的。 它始终始终先连接到master,然后在您使用不同的DB时切换数据库。 但是CREATE DATABASE
命令始终在master
上下文中发出。
Windows版本在这里无关紧要。 可能是,在Win7安装中,您正在连接到具有预先存在的test
数据库的服务器,而在Win8计算机中,该服务器尚不存在。
谢谢亚历杭德罗。
我将-d更改为master并使用-v db = fleeb分配了数据库
我的命令行现在显示为:
sqlcmd -i test.sql -S sof202 \\ wizrms -d master -U sa -P W1zard -v db = fleeb
它运行无误,并创建了一个名为fleeb的数据库。
完善。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.