0

当它是 SQL Server 2008 R2 时,我成功连接到我的数据库。但是升级到 SQL Server 2012 后,我的 java 代码中出现以下错误我使用的应用程序服务器是 Tomcat7

错误如下:

Jun 10, 2012 1:56:10 PM org.apache.naming.NamingContext lookup
WARNING: Unexpected exception resolving reference
com.microsoft.sqlserver.jdbc.SQLServerException: Cannot open database "MyDB" requested by the login. The login failed.
    at com.microsoft.sqlserver.jdbc.SQLServerException.makeFromDatabaseError(SQLServerException.java:197)
    at com.microsoft.sqlserver.jdbc.TDSTokenHandler.onEOF(tdsparser.java:246)
    at com.microsoft.sqlserver.jdbc.TDSParser.parse(tdsparser.java:83)

context.xml 中的连接字符串是

<Resource name="jdbc/theDB" type="javax.sql.DataSource" auth="Container"
            factory="org.apache.tomcat.jdbc.pool.DataSourceFactory"
            driverClassName="com.microsoft.sqlserver.jdbc.SQLServerDriver" initialSize="30"
            maxActive="100"
        url="jdbc:sqlserver://localhost:1433;databaseName=MyDB;integratedSecurity=true"
            />

以下在 web.xml 中

<resource-ref>
<description>My Database</description>
<res-ref-name>jdbc/theDB</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>

我可以通过在 Eclipse 中打开数据连接来成功连接到数据库,事实上,生成的连接字符串与我在上面重现的 context.xml 中的 url 相同。

有人有什么想法吗?

谢谢!

4

1 回答 1

0

确保运行应用程序服务器的用户对数据库具有足够的权限。

于 2012-06-14T12:45:57.367 回答