热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

iBATIS入门介绍

iBATIS一词来源于“internet”和“abatis”的组合,是一个由ClintonBegin在2001年发起的开放源代码项目。最初侧重于密码软件的开发,现在是一个基于Java的持久层框架。第一,搭建iBatis开发环境:官网为:http://www.mybatis.org/1、导入相关的jar包,

   iBATIS一词来源于“internet”和“abatis”的组合,是一个由Clinton Begin在2001年发起的开放源代码项目。最初侧重于密码软件的开发,现在是一个基于Java的持久层框架。

第一,搭建iBatis 开发环境:官网为:http://www.mybatis.org/

 1 、导入相关的jar 包,ibatis-2.3.0.677.jar 、mysql-connector-java-5.1.6-bin.jar

 2 、编写配置文件:

1)jdbc 连接的属性文件 jdbc.proprties

2)关于每个实体的映射文件(Map 文件),如Student.xml

3)总配置文件SqlMapConfig.xml 加载1)和2)的配置文件。

 

第二,编写数据库配置文件jdbc.proprties

jdbc.driverClassName=com.mysql.jdbc.Driver
jdbc.url=jdbc\:mysql\://localhost\:3306/cyb?useUnicode\=true&characterEncoding\=UTF-8&noAccessToProcedureBodies\=true&autoReconect\=true
jdbc.username=ellll
jdbc.password=ellllcom

hibernate.show_sql=true
hibernate.format_sql=true

第二  定义实体映射文件


   "http://ibatis.apache.org/dtd/sql-map-2.dtd">


 
 

 
 
 

 
 
 

 
 

 
  insert into
  plat_student(name,password,teacher_id) values (#name#,#password#,#teacher_id#);
  
   select @@identity as inserted
   
   
   
   
   
  

 

 
  
  
  delete from plat_student where id=#id#
 

 
  update plat_student set name=#name#,password=#password# where id=#id#
 

第三 编写总的配置文件jdbc.xml


    "http://ibatis.apache.org/dtd/sql-map-config-2.dtd">


 
 
 
 
  
  
   
   
   
   
  

 

 
 

第五 编写业务逻辑

package com.cyb.model;


import java.io.IOException;
import java.io.Reader;
import java.sql.SQLException;
import java.util.List;


import org.apache.ibatis.io.Resources;

import com.cyb.vo.Plat_student;
import com.ibatis.sqlmap.client.SqlMapClient;
import com.ibatis.sqlmap.client.SqlMapClientBuilder;


public class StudentDaoImpl {


 private static SqlMapClient sqlMapClient = null;

 // 读取配置文件
 static {
  try {
       System.out.println("加载配置文件");
   Reader reader = Resources.getResourceAsReader("properties/jdbc.xml");
   sqlMapClient = SqlMapClientBuilder.buildSqlMapClient(reader);
   reader.close();
  } catch (IOException e) {
   e.printStackTrace();
  }
 }

 public boolean addPlat_student(Plat_student Plat_student) {
  Object object = null;
  boolean flag = false;
  try {
   
   object = sqlMapClient.insert("addPlat_student", Plat_student);
   System.out.println("添加学生信息的返回值:" + object);
  } catch (SQLException e) {
   e.printStackTrace();
  }
  if (object != null) {
   flag = true;
  }
  return flag;
 }

 public boolean deletePlat_studentById(int id) {
  boolean flag = false;
  Object object = null;
  try {
   object = sqlMapClient.delete("deletePlat_studentById", id);
   System.out.println("删除学生信息的返回值:" + object + ",这里返回的是影响的行数");
  } catch (SQLException e) {
   e.printStackTrace();
  }
  if (object != null) {
   flag = true;

  }
  return flag;

 }

 public boolean updatePlat_student(Plat_student Plat_student) {
  boolean flag = false;
  Object object = false;
  try {
   object = sqlMapClient.update("updatePlat_student", Plat_student);
   System.out.println("更新学生信息的返回值:" + object + ",返回影响的行数");
  } catch (SQLException e) {
   e.printStackTrace();
  }
  if (object != null) {
   flag = true;
  }
  return flag;
 }

 public List selectAllPlat_student() {
  List Plat_students = null;
  try {
   Plat_students = sqlMapClient.queryForList("selectAllPlat_student");
  } catch (SQLException e) {
   e.printStackTrace();
  }
  return Plat_students;
 }

 public List selectPlat_studentByName(String name) {
  List Plat_students = null;
  try {
   Plat_students = sqlMapClient.queryForList("selectPlat_studentByName",name);
  } catch (SQLException e) {
   e.printStackTrace();
  }
  return Plat_students;
 }

 public Plat_student selectPlat_studentById(int id) {
  Plat_student Plat_student = null;
  try {
   Plat_student = (Plat_student) sqlMapClient.queryForObject(
     "selectPlat_studentById", id);
  } catch (SQLException e) {
   e.printStackTrace();
  }
  return Plat_student;
 }
}

第六  编写测试程序

package com.cyb.model;


import java.util.List;


import com.cyb.vo.Plat_student;
import com.cyb.vo.Plat_teacher;

public class TestIbatis {

 public static void main(String[] args) {
  StudentDaoImpl studentDaoImpl = new StudentDaoImpl();
  System.out.println("测试插入start");
  Plat_student addStudent = new Plat_student();
  addStudent.setName("李四YYYY");
  addStudent.setPassword("xxx");
  addStudent.setTeacher_id("1");
  System.out.println(addStudent.getIsset_Teacher_id());
  System.out.println(studentDaoImpl.addPlat_student(addStudent));
  System.out.println("测试插入end");
  System.out.println("测试根据id查询");
  System.out.println(studentDaoImpl.selectPlat_studentById(95));

  System.out.println("测试模糊查询");
  List mohuLists = studentDaoImpl.selectPlat_studentByName("朱");
  for (Plat_student student : mohuLists) {
   System.out.println(student);
  }

  System.out.println("测试查询所有");
  List students = studentDaoImpl.selectAllPlat_student();
  for (Plat_student student : students) {
   System.out.println(student);
  }

  System.out.println("根据id删除学生信息");
  System.out.println(studentDaoImpl.deletePlat_studentById(83));
  
  System.out.println("测试更新学生信息");
  Plat_student updateStudent = new Plat_student();
  //先查询,后删除
  updateStudent=studentDaoImpl.selectPlat_studentById(80);
  updateStudent.setName("陈盛岚");
  System.out.println(studentDaoImpl.updatePlat_student(updateStudent));

 }
}

 自此,简单的ibatis框架就搭建完成了,已测试成功。


推荐阅读
  • 在当前众多持久层框架中,MyBatis(前身为iBatis)凭借其轻量级、易用性和对SQL的直接支持,成为许多开发者的首选。本文将详细探讨MyBatis的核心概念、设计理念及其优势。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • 在哈佛大学商学院举行的Cyberposium大会上,专家们深入探讨了开源软件的崛起及其对企业市场的影响。会议指出,开源软件不仅为企业提供了新的增长机会,还促进了软件质量的提升和创新。 ... [详细]
  • 本文探讨了适用于Spring Boot应用程序的Web版SQL管理工具,这些工具不仅支持H2数据库,还能够处理MySQL和Oracle等主流数据库的表结构修改。 ... [详细]
  • 本文详细介绍了如何通过多种编程语言(如PHP、JSP)实现网站与MySQL数据库的连接,包括创建数据库、表的基本操作,以及数据的读取和写入方法。 ... [详细]
  • 本文介绍如何通过创建替代插入触发器,使对视图的插入操作能够正确更新相关的基本表。涉及的表包括:飞机(Aircraft)、员工(Employee)和认证(Certification)。 ... [详细]
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
  • 网络运维工程师负责确保企业IT基础设施的稳定运行,保障业务连续性和数据安全。他们需要具备多种技能,包括搭建和维护网络环境、监控系统性能、处理突发事件等。本文将探讨网络运维工程师的职业前景及其平均薪酬水平。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 本文详细介绍了 Java 中 org.apache.xmlbeans.SchemaType 类的 getBaseEnumType() 方法,提供了多个代码示例,并解释了其在不同场景下的使用方法。 ... [详细]
author-avatar
鹏城飞将
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有