SqlServer/MyBatis SqlMapConfig数据源设置

JWi*_*ley 5 java sql-server mybatis

我正在研究这个MyBatis教程,并且遇到了在SqlMapConfig.xml中设置dataSource的问题.本教程使用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>
Run Code Online (Sandbox Code Playgroud)

更新:

<?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>
Run Code Online (Sandbox Code Playgroud)

注意: 我在SQL 2008中使用了最新的JDBC驱动程序4,并且遇到了版本问题,特别是错误:"异常数据:java.lang.UnsupportedClassVersionError(com/microsoft/sqlserver/jdbc/SQLServerDriver)错误的主要版本在offset = 6 ........."

通过sqljdbc3/sqljdbc4.jar切换到兼容的驱动程序sqljdbc.jar来解决此问题.

Bog*_*dan 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 语法