我的IBatisNet实践

2024-02-21 08:18
文章标签 实践 ibatisnet

本文主要是介绍我的IBatisNet实践,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


 

1.关于IBatis及IBatisNet

iBatis是又一个O/R Mapping解决方案,j2ee的O/R方案真是多,和Hibernate相比,iBatis最大的特点就

是小巧,上手很快。如果你不需要太多复杂的功能,iBatis是能满足你的要求又足够灵活的最简单的解

决方案。

iBatisNet是iBatis的.NET版本。

iBatis及iBatisNet的主站是www.ibatis.com

2.下载
   http://www.ibatis.com/common/download.html
   当然需要将IBatisNet.Common.dll,IBatisNet.DataMapper.dll,IBatisNet.DataAccess.dll等引用到

你的项目中
   另外有一些数据库连接驱动包,在"NPetShop Example

Application"的范例中的目录"source/External-bin/"中可以找到.

下面进行实践第一个IBatisNet项目
1.数据库:
  使用SQLServer2000:
  在Northwind的test中建立表Person

  CREATE TABLE [Person] (
 [PER_ID] [int] NOT NULL ,
 [PER_FIRST_NAME] [varchar] (40) COLLATE Chinese_PRC_CI_AS NOT NULL ,
 [PER_LAST_NAME] [varchar] (40) COLLATE Chinese_PRC_CI_AS NOT NULL ,
 [PER_BIRTH_DATE] [datetime] NOT NULL ,
 [PER_WEIGHT_KG] [float] NOT NULL ,
 [PER_HEIGHT_M] [float] NOT NULL
        )

2.添加配置文件
SqlMap.config(我的理解是:SqlMap.config是IBatisNet默认读取的配置文件,暂时不知道怎样使IBatisN

et读文件来取代SqlMap.config)
 <?xml version="1.0" encoding="UTF-8" ?>
<sqlMapConfig xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:noNamespaceSchemaLocation="SqlMapConfig.xsd">
 <providers file="providers.config" />
 <settings>
  <setting useFullyQualifiedStatementNames="false" />
  <setting cacheModelsEnabled="true" />
 </settings>
 <database>
  <provider name="sqlServer1.1"></provider>
  <dataSource name="iBatisTest"

connectionString="server=localhost;database=test;user id=sa;password=123;connection

reset=false;connection lifetime=5; min pool size=1; max pool size=50"/>
 </database>
 <sqlMaps>
  <sqlMap resource="Person.xml" />
 </sqlMaps>
</sqlMapConfig>

//<database>定义了数据库连接方法,我这里采用的是连接SQLServer2000的,你可以根据自己需要修改
//providers.config文件是配置数据库连接方式的文件,可以去下载官方的providers.config的文件,比较长,就不贴出来了


3.加入映射文件Person.xml
<?xml version="1.0" encoding="utf-8" ?>
<sqlMap namespace="Person" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:noNamespaceSchemaLocation="SqlMap.xsd">
 <alias>
  <typeAlias alias="Person" assembly="iBatisTest.dll"

type="iBatisTest.Person" />
 </alias>
 <resultMaps>
  <resultMap id="SelectAllResult" class="Person">
   <result property="Id" column="PER_ID" />
   <result property="FirstName" column="PER_FIRST_NAME" />
   <result property="LastName" column="PER_LAST_NAME" />
   <result property="BirthDate" column="PER_BIRTH_DATE" />
   <result property="WeightInKilograms" column="PER_WEIGHT_KG" />
   <result property="HeightInMeters" column="PER_HEIGHT_M" />
  </resultMap>
 </resultMaps>
 <statements>
  <select id="SelectAll" resultMap="SelectAllResult">
        select
        PER_ID,
        PER_FIRST_NAME,
        PER_LAST_NAME,
        PER_BIRTH_DATE,
        PER_WEIGHT_KG,
        PER_HEIGHT_M
        from PERSON
        </select>
 </statements>
</sqlMap>


4.下面是测试代码:
private void Button1_Click(object sender, System.EventArgs e)
  {
   

//IBatisNet.Common.Utilities.Resources.GetConfigAsXmlDocument(System.Web.HttpContext.Curren

t.Server.MapPath("SqlMap.xml"));
   DataGrid1.DataSource =

Mapper.Instance().QueryForList("SelectAll",null);
   DataGrid1.DataBind();
  }



这篇关于我的IBatisNet实践的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/731117

相关文章

Java Optional的使用技巧与最佳实践

《JavaOptional的使用技巧与最佳实践》在Java中,Optional是用于优雅处理null的容器类,其核心目标是显式提醒开发者处理空值场景,避免NullPointerExce... 目录一、Optional 的核心用途二、使用技巧与最佳实践三、常见误区与反模式四、替代方案与扩展五、总结在 Java

Spring Boot循环依赖原理、解决方案与最佳实践(全解析)

《SpringBoot循环依赖原理、解决方案与最佳实践(全解析)》循环依赖指两个或多个Bean相互直接或间接引用,形成闭环依赖关系,:本文主要介绍SpringBoot循环依赖原理、解决方案与最... 目录一、循环依赖的本质与危害1.1 什么是循环依赖?1.2 核心危害二、Spring的三级缓存机制2.1 三

Python 中的 with open文件操作的最佳实践

《Python中的withopen文件操作的最佳实践》在Python中,withopen()提供了一个简洁而安全的方式来处理文件操作,它不仅能确保文件在操作完成后自动关闭,还能处理文件操作中的异... 目录什么是 with open()?为什么使用 with open()?使用 with open() 进行

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

tomcat多实例部署的项目实践

《tomcat多实例部署的项目实践》Tomcat多实例是指在一台设备上运行多个Tomcat服务,这些Tomcat相互独立,本文主要介绍了tomcat多实例部署的项目实践,具有一定的参考价值,感兴趣的可... 目录1.创建项目目录,测试文China编程件2js.创建实例的安装目录3.准备实例的配置文件4.编辑实例的

Python 中的异步与同步深度解析(实践记录)

《Python中的异步与同步深度解析(实践记录)》在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键,这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际... 目录python中的异步与同步:深度解析与实践异步与同步的定义异步同步阻塞与非阻塞的概念阻塞非阻塞同步

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

springboot集成Deepseek4j的项目实践

《springboot集成Deepseek4j的项目实践》本文主要介绍了springboot集成Deepseek4j的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录Deepseek4j快速开始Maven 依js赖基础配置基础使用示例1. 流式返回示例2. 进阶

Android App安装列表获取方法(实践方案)

《AndroidApp安装列表获取方法(实践方案)》文章介绍了Android11及以上版本获取应用列表的方案调整,包括权限配置、白名单配置和action配置三种方式,并提供了相应的Java和Kotl... 目录前言实现方案         方案概述一、 androidManifest 三种配置方式

Spring Boot中定时任务Cron表达式的终极指南最佳实践记录

《SpringBoot中定时任务Cron表达式的终极指南最佳实践记录》本文详细介绍了SpringBoot中定时任务的实现方法,特别是Cron表达式的使用技巧和高级用法,从基础语法到复杂场景,从快速启... 目录一、Cron表达式基础1.1 Cron表达式结构1.2 核心语法规则二、Spring Boot中定