热门标签 | 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框架就搭建完成了,已测试成功。


推荐阅读
  • docker镜像重启_docker怎么启动镜像dock ... [详细]
  • 本文详细介绍了MySQL数据库中的Bin Log和Redo Log,阐述了它们在日志记录机制、应用场景以及数据恢复方面的区别。通过对比分析,帮助读者更好地理解这两种日志文件的作用和特性。 ... [详细]
  • ssm框架整合及工程分层1.先创建一个新的project1.1配置pom.xml ... [详细]
  • 本文详细介绍了如何在云服务器上配置Nginx、Tomcat、JDK和MySQL。涵盖从下载、安装到配置的完整步骤,帮助读者快速搭建Java Web开发环境。 ... [详细]
  • 优化Flask应用的并发处理:解决Mysql连接过多问题
    本文探讨了在Flask应用中通过优化后端架构来应对高并发请求,特别是针对Mysql 'too many connections' 错误的解决方案。我们将介绍如何利用Redis缓存、Gunicorn多进程和Celery异步任务队列来提升系统的性能和稳定性。 ... [详细]
  • 本文深入探讨了MySQL中常见的面试问题,包括事务隔离级别、存储引擎选择、索引结构及优化等关键知识点。通过详细解析,帮助读者在面对BAT等大厂面试时更加从容。 ... [详细]
  • 本文详细介绍如何使用 Apache Spark 执行基本任务,包括启动 Spark Shell、运行示例程序以及编写简单的 WordCount 程序。同时提供了参数配置的注意事项和优化建议。 ... [详细]
  • 软件工程课堂测试2
    要做一个简单的保存网页界面,首先用jsp写出保存界面,本次界面比较简单,首先是三个提示语,后面是三个输入框,然 ... [详细]
  • MySQL Debug 模式的实现与应用
    本文详细介绍了如何启用和使用 MySQL 的调试模式,包括编译选项、环境变量配置以及调试信息的解析。通过实际案例展示了如何利用调试模式解决客户端无法连接服务器的问题。 ... [详细]
  • 近期我们开发了一款包含天气预报功能的万年历应用,为了满足这一需求,团队花费数日时间精心打造并测试了一个稳定可靠的天气API接口,现正式对外开放。 ... [详细]
  • 如何从python读取sql[mysql基础教程]
    从python读取sql的方法:1、利用python内置的open函数读入sql文件;2、利用第三方库pymysql中的connect函数连接mysql服务器;3、利用第三方库pa ... [详细]
  • MySQL 'Too Many Connections' 错误处理及优化方案
    本文详细介绍了如何诊断和解决MySQL数据库中出现的‘Too Many Connections’错误,包括查看当前连接状态、调整配置文件以及优化应用代码等方法。 ... [详细]
  • 本文详细介绍了MySQL中的存储过程,包括其定义、优势与劣势,并提供了创建、调用及删除存储过程的具体示例,旨在帮助开发者更好地利用这一数据库特性。 ... [详细]
  • 最新计算机专业原创毕业设计参考选题都有源码+数据库是近期作品ling取参考你的选题刚好在下面有,有时间看到机会给您发1ssm资源循环利用2springboot校园考勤系统3ssm防 ... [详细]
  • 本文介绍了如何在WildFly 10中配置MySQL数据源时遇到的服务依赖问题及其解决方案。 ... [详细]
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社区 版权所有