5

我正在完成这个 MyBatis 教程,并且遇到了在 SqlMapConfig.xml 中设置数据源的问题。该教程使用 MySql,就像互联网上存在的所有其他教程一样,但我使用的是 SqlServer 2008。

请帮助我将以下代码转换为连接到本地 SqlServer,或帮助我了解如何设置环境/SqlMapConfig 如何与连接工厂一起使用。

信息/教程的链接也很棒。

谢谢!

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
    PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
    "http://mybatis.org/dtd/mybatis-3-config.dtd">

<configuration>

    <typeAliases>
        <typeAlias alias="Contact" type="com.name.model.Contact"/>
    </typeAliases>

    <environments default="development">
        <environment id="development">
          <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/blog"/>
                <property name="username" value="root"/>
                <property name="password" value="root"/>
            </dataSource>
       </environment>
    </environments>

    <mappers>
       <mapper resource="com/name/data/Contact.xml"/>
    </mappers>

</configuration>

更新:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
    PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
    "http://mybatis.org/dtd/mybatis-3-config.dtd">

<configuration>

    <typeAliases>
        <typeAlias alias="Contact" type="com.name.model.Contact"/>
    </typeAliases>

    <environments default="development">
        <environment id="development">
          <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="com.microsoft.sqlserver.jdbc.SQLServerDriver"/>
            <property name="url" value="jdbc:sqlserver://localhost(or name of server):1433;databaseName=yourdbname; catalogName=sameasdbname"/>
            <property name="username" value="root"/>
            <property name="password" value="root"/>
            </dataSource>
       </environment>
    </environments>

    <mappers>
       <mapper resource="com/name/data/Contact.xml"/>
    </mappers>

</configuration>

注意: 我在 SQL 2008 中使用最新的 JDBC 驱动程序 4,并且有版本问题,特别是错误:“异常数据:java.lang.UnsupportedClassVersionError (com/microsoft/sqlserver/jdbc/SQLServerDriver) 偏移量 = 6 处的主要版本错误……”

切换到 sqljdbc3/sqljdbc4.jar 上的兼容驱动程序 sqljdbc.jar 以解决此问题。

4

1 回答 1

4

要连接到 SQL Server(或任何其他数据库),您需要两个基本的东西:

  • 适当的 JDBC 驱动程序。
  • 配置数据源时的适当属性;

对于驱动程序,我想您可以选择“官方”Microsoft JDBC Driver for SQL Server 分发版,您必须在应用程序的类路径中提供该驱动程序,然后在 MyBatis 配置中配置数据源属性,其中涉及指定驱动程序类(com.microsoft.sqlserver.jdbc.SQLServerDriver如果我是没有记错)和连接 url(必须以jdbc:sqlserver://代替开头jdbc:mysql://)。

您可以在官方页面上找到更多信息,该页面将提供适当的链接来帮助您完成所有操作(只需确保您阅读了您的 SQL Server 版本的文档;SQL Server 2012 已经发布,因此 Microsoft 更新了他们的文档)。

然后根据您正在运行的查询类型(对于基本教程,因为这不应该是一个问题),您必须确保使用正确的 SQL 语法

于 2012-05-01T14:50:45.617 回答