zoukankan      html  css  js  c++  java
  • java面试要点ibatiS框架的使用方法介绍随时更新

    1.ibatIS的基本使用方法,这里通过一个例子来学习
    a.创梦技术qq交流群:CreDream:251572072
    --------------------------------------------------
    a.新建IbatisTest项目
    /IbatisTest/src/com/credream/test/testimpl.java
    package com.credream.test;

    import java.sql.Date;
    import com.credream.IStudentDao;
    import com.credream.IStudentDaoImpl;
    import com.credream.Student;
    public class testimpl {
        public static void main(String[] args) {
      IStudentDao dao=new IStudentDaoImpl();
      //测试queryAllStudent()方法
            /*for (Student student:dao.queryAllStudent()) {
       System.out.println(student);
      }*/
      //测试queryStudentById()方法
      /*System.out.println("id is 1:"+dao.queryStudentById(1));*/
      //测试addStudent(Student student) 方法
      /*Student student=new Student();
      student.setSid(4);
      student.setSname("xushu");
      student.setMajor("games");
      student.setBirth(Date.valueOf("2012-12-22"));
      student.setScore((float) 18.5);
         dao.addStudent(student);*/
      //测试delteStudentById(int id)方法
      //dao.delteStudentById(3);
           //测试updateStudentById(Student student) 方法;
      /*Student student=new Student();
      student.setSid(4);
      student.setSname("xushen");
      student.setMajor("games");
      student.setBirth(Date.valueOf("2012-12-22"));
      student.setScore((float) 18.5);
         dao.updateStudentById(student);*/
        //测试queryStudentByName(String name)方法
         /*List<Student> students=dao.queryStudentByName("x");
           for(Student student:students){
         System.out.println(student);
        }*/
        //测试:addStudentBySequence(Student student) 方法
      Student student=new Student();
      student.setSid(4);
      student.setSname("xushen");
      student.setMajor("games");
      student.setBirth(Date.valueOf("2012-12-22"));
      student.setScore((float) 18.5);
      dao.addStudentBySequence(student);
      
        }
    }
    -------------------------------
    2./IbatisTest/src/com/credream/util/DButil.java
    package com.credream.util;
    public class DButil {
     
    }
    ---------------------------------------------------------
    3./IbatisTest/src/com/credream/IStudentDao.java
    package com.credream;

    import java.util.List;

    public interface IStudentDao {
    public void addStudent(Student student);
    public void addStudentBySequence(Student student);
    public void delteStudentById(int id);
    public void updateStudentById(Student student);
    public List<Student> queryAllStudent();
    public List<Student> queryStudentByName(String name);
    public Student queryStudentById(int id);
    }
    ------------------------------------------------
    4./IbatisTest/src/com/credream/IStudentDaoImpl.java
    package com.credream;

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

    import com.ibatis.sqlmap.client.SqlMapClient;

    public class IStudentDaoImpl implements IStudentDao {

     private static SqlMapClient sqlMapClient=null;
        static{
         Reader reader;
      try {
       reader = com.ibatis.common.resources.Resources.getResourceAsReader("com/credream/SqlMapConfig.xml");
       sqlMapClient=com.ibatis.sqlmap.client.SqlMapClientBuilder.buildSqlMapClient(reader);
          reader.close();
      } catch (IOException e) {
       e.printStackTrace();
      }
        } 

     public void addStudent(Student student) {
     try {
      sqlMapClient.insert("insertStudent", student);
     } catch (SQLException e) {
     
      e.printStackTrace();
     }

     }

     public void addStudentBySequence(Student student) {
    try {
     //1.从数据库序列中获取主键值
     //2.让student表中插入记录
     sqlMapClient.insert("insertStudentBySequence", student);
        System.out.println("sid="+student.getSid());
    } catch (SQLException e) {
     e.printStackTrace();
    }
     }

     public void delteStudentById(int id) {
        try {
         System.out.println("开始删除....");
      System.out.println(sqlMapClient.delete("delteStudentById", id));
      System.out.println("删除成功...");
     } catch (SQLException e) {
      
      e.printStackTrace();
     }  

     }

     public List<Student> queryAllStudent() {
      List<Student> studentList=null;
      try {
       studentList=sqlMapClient.queryForList("selectAllStudent");
      } catch (SQLException e) {
       e.printStackTrace();
      }
      return studentList;
     }

     public Student queryStudentById(int id) {
      Student student=null;
      try {
       student=(Student) sqlMapClient.queryForObject("selectStudentById",id);
      } catch (SQLException e) {
       e.printStackTrace();
      }
      return student;
     }
     public List<Student> queryStudentByName(String name) {
      List<Student> students=null;
      try {
       students=sqlMapClient.queryForList("queryStudentByName",name);
      } catch (SQLException e) {
      
       e.printStackTrace();
      }
      return students;
     }
     public void updateStudentById(Student student) {
      try {
       System.out.println(sqlMapClient.update("updateStudentById", student));
      } catch (SQLException e) {
       e.printStackTrace();
      }
     }
    }
    ---------------------------------------------------------------------------
    5./IbatisTest/src/com/credream/Student.java
    package com.credream;

    import java.util.Date;

    public class Student {
     /**
      * 这个地方最好不要覆盖父类的构造方法
      */
    private int sid=0;
    private String sname=null;
    private String major=null;
    private Date birth=null;
    private float score=0;
    public int getSid() {
     return sid;
    }
    public void setSid(int sid) {
     this.sid = sid;
    }
    public String getSname() {
     return sname;
    }
    public void setSname(String sname) {
     this.sname = sname;
    }
    public String getMajor() {
     return major;
    }
    public void setMajor(String major) {
     this.major = major;
    }
    public Date getBirth() {
     return birth;
    }
    public void setBirth(Date birth) {
     this.birth = birth;
    }
     
    public float getScore() {
     return score;
    }
    public void setScore(float score) {
     this.score = score;
    }
    @Override
    public String toString() {
     String content="sid="+sid+"/sname"+sname+"tmajor:"+major+"birth:"+
     birth;
     return content;
    }


    }
    -------------------------------------------------------------------------
    6./IbatisTest/src/com/credream/SqlMap.propertiesdriver=com.mysql.jdbc.Driver
    url=jdbc\:mysql\://localhost\:3306/test
    username=root
    password=1234
    -------------------------------------------------
    7./IbatisTest/src/com/credream/SqlMapConfig.xml
    <?xml version="1.0" encoding="UTF-8"?> 
    <!DOCTYPE sqlMapConfig PUBLIC "-//iBATIS.com//DTD SQL Map Config 2.0//EN" 
        "http://www.ibatis.com/dtd/sql-map-config-2.dtd">
    <!--<!DOCTYPE sqlMap PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN" 
       "http://ibatis.apache.org/dtd/sql-map-2.dtd">
      -->
       <sqlMapConfig>
      <properties resource="com/credream/SqlMap.properties"/>
      <transactionManager type="JDBC">
       <dataSource type="SIMPLE">
       <property name="JDBC.Driver" value="${driver}"/>
       <property name="JDBC.ConnectionURL" value="${url}"/>
       <property name="JDBC.Username" value="${username}"/>
       <property name="JDBC.Password" value="${password}"/>
       </dataSource>
      </transactionManager>
      <sqlMap resource="com/credream/Student.xml"/>
      </sqlMapConfig>
     -------------------------------------------------------------
     8./IbatisTest/src/com/credream/Student.xml
     <?xml version="1.0" encoding="UTF-8"?> 
    <!DOCTYPE sqlMap PUBLIC "-//iBATIS.com//DTD SQL Map 2.0//EN" "http://www.ibatis.com/dtd/sql-map-2.dtd">
      <sqlMap>
      <typeAlias alias="Student" type="com.credream.Student"/>
      <select id="selectAllStudent" resultClass="Student">
      select * from student;
      </select>
     <select id="selectStudentById" parameterClass="int" resultClass="Student">
     select * from student where sid=#sid#
     </select>
     <insert id="insertStudent" parameterClass="Student">
     insert into Student (sid,sname,major,birth,score)values (#sid#,#sname#,#major#,#birth#,#score#)
     </insert>
     
     <delete id="delteStudentById" parameterClass="int">
    delete from student where sid=#sid#
     </delete>
     
     <update id="updateStudentById" parameterClass="student">
     update Student set sname=#sname#,major=#major#,score=#score#,birth=#birth#
     where sid=#sid#
     </update>
     
     
     <select id="queryStudentByName" parameterClass="string" resultClass="Student">
     select sid,sname,major,birth,score from student where sname like '%$sname$%'
     
     </select>
     
     
     <insert id="insertStudentBySequence" parameterClass="Student">
     <selectKey resultClass="int" keyProperty="sid">
     select studentPKSequence.netVal from dual
     </selectKey>
     insert into student(sid,sname,birth,major,score)values(#sid#,#sname#,
     #birth#,#major#,#score#)
     </insert>
     
      </sqlMap>
      ------------------------------------------------------
      9.G:\javalib\mysqldriver\mysql-connector-java-5.1.16-bin.jar
      G:\javalib\ibatis\ibatis-2.3.0.677.jar
      --------------------------------------------------------------------------
      2.原理理解:
      a.创梦技术qq交流群:CreDream:251572072
       iBATIS对于工程是不是最好的选择
       iBATIS是一种数据映射工具。它的作用就在把数据库查询与对象的属性间建立映射关系。如果将要开发的工程是基于业务对象(包括映射或
    数据字典对象),那么iBATIS可以算是个好的选择。当应用程序进行分层设计实现时,它更是个好的选择,这样的话,业务层就可以和用户界面
    层分开。
    -------------------------------------------
    3.private static SqlMapClient sqlMapClient=null;
        static{
         Reader reader;
      try {
       reader = com.ibatis.common.resources.Resources.getResourceAsReader("com/credream/SqlMapConfig.xml");
       sqlMapClient=com.ibatis.sqlmap.client.SqlMapClientBuilder.buildSqlMapClient(reader);
          reader.close();
      } catch (IOException e) {
       e.printStackTrace();
      }
        } 
    -------------------------------------------------------------------
    4.public void addStudent(Student student) {
     try {
      sqlMapClient.insert("insertStudent", student);
     } catch (SQLException e) {
     
      e.printStackTrace();
     }

     }
    -------------------------------------------
    public List<Student> queryAllStudent() {
      List<Student> studentList=null;
      try {
       studentList=sqlMapClient.queryForList("selectAllStudent");
      } catch (SQLException e) {
       e.printStackTrace();
      }
    ----------------------------------------------------------------

  • 相关阅读:
    pyinstaller
    screen
    docker
    rsync
    shutil模块
    mysql innodb 理解
    B 树和B+树存储的区别
    B-树原理分析
    mysql 通过mycat 读写分离
    mysql 主从复制
  • 原文地址:https://www.cnblogs.com/dyllove98/p/3132327.html
Copyright © 2011-2022 走看看