1、MyBatisNet的安装使用

用到的几个DLL按理说应该到官网下载,但这个官网是谷大哥的,不知道是不是被屏蔽,总打不开,幸好从别人的程序里拷过来一份,直接放在自己的程序里就行!

程序结构如下:

Providers.config,SqlMap.config,TUser.xml是必须的。TUser.xml为对应TUser.cs实体类的配置文件(请注意文件名,类名最好要一样,不一样的情况貌似会出错

providers.config 如下:

复制代码
xml version="1.0" encoding="utf-8"?>
<providers xmlns="http://ibatis.apache.org/providers" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  <clear/>
  <provider
    name="sqlServer2.0"
    description="Microsoft SQL Server 7.0/2000/2005, provider V2.0.0.0 in framework .NET V2.0"
    enabled="true"
    default="true"
    assemblyName="System.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" connectionClass="System.Data.SqlClient.SqlConnection"
    commandClass="System.Data.SqlClient.SqlCommand"
    parameterClass="System.Data.SqlClient.SqlParameter"
    parameterDbTypeClass="System.Data.SqlDbType"
    parameterDbTypeProperty="SqlDbType"
    dataAdapterClass="System.Data.SqlClient.SqlDataAdapter"
    commandBuilderClass="System.Data.SqlClient.SqlCommandBuilder"
    usePositionalParameters="false"
    useParameterPrefixInSql="true"
    useParameterPrefixInParameter="true"
    parameterPrefix="@"/>
providers>
复制代码

SqlMap.config 如下:

复制代码
xml version="1.0" encoding="utf-8"?>
<sqlMapConfig xmlns="http://ibatis.apache.org/dataMapper" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  <settings>
    <setting useStatementNamespaces="false"/>
    <setting cacheModelsEnabled="true"/>
  settings>

  
  <providers resource="providers.config"/>

  
  <database>
    <provider name="sqlServer2.0" />
    
    <dataSource name="SQLSERVER" connectionString="Data Source=(local);Initial Catalog=myBatis;User Id=sa;Password=anyqu989125;" />
    
  database>

  
  <sqlMaps>
    <sqlMap resource="TUser.xml"/>
  sqlMaps>
sqlMapConfig>
复制代码

 

TUser.xml 如下:

复制代码
xml version="1.0" encoding="utf-8" ?>

<sqlMap namespace="MyBatisDemo"
    xmlns="http://ibatis.apache.org/mapping"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
 
  <alias>
    <typeAlias alias="TUser" type="MyBatisDemo.TUser" />
  alias>

  <resultMaps>
    <resultMap id="FullResultMap" class="TUser">
      <result property="UID" column="U_ID" dbType="Int"/>
      <result property="UName" column="U_Name" dbType="VarChar"/>
      <result property="UDept" column="U_Dept" dbType="VarChar"/>
    resultMap>
  resultMaps>

  <statements>

    <insert id="Insert" parameterClass="TUSER">
      INSERT INTO [dbo].[T_USER] (
      [U_ID]
      , [U_Name]
      , [U_Dept]
      ) VALUES (
      #UID,dbType=Int#
      , #UName,dbType=VarChar#
      , #UDept,dbType=VarChar#
      )
    insert>
  statements>
sqlMap>
复制代码

 

实体类如下:

复制代码
using System;
using System.Collections.Generic;
using System.Text;

namespace MyBatisDemo
{
    //==============================================================================
    /// TUSER Business Object.
    [Serializable]
    public partial class TUSER
    {

        #region UID

        private Int32 m_uID;

        /// Gets or sets UID
        public Int32 UID
        {
            get { return m_uID; }
            set { m_uID = value; }
        }

        #endregion

        #region UName

        private String m_uName;

        /// Gets or sets UName
        public String UName
        {
            get { return m_uName; }
            set { m_uName = value; }
        }

        #endregion

        #region UDept

        private String m_uDept;

        /// Gets or sets UDept
        public String UDept
        {
            get { return m_uDept; }
            set { m_uDept = value; }
        }

        #endregion

    }
}
复制代码

上面提到的三个配置文件均须放在DEBUG下。同时请注意 实体类的文件名,类名,配置文件内所有涉及到类名的地方,均应一致,否则会提示无法创建SQLMAP对象,原因是找不到ProductMap.xml,错误如下:

找了一天的原因,一直以为是程序里的ProductMap.xml有问题,却查不到这个文件,后来才明白这个文件是框架中定义的实体配置类的一个代名词。查看上图中错的详细信息如下:

大道至简

你可能感兴趣的:(MyBatis.Net,学习笔记)