zoukankan      html  css  js  c++  java
  • JAVA之Mybatis基础入门--框架搭建与简单查询

      JAVA中,操作数据库有JDBC、hibernate、Mybatis等技术,今天整理了下,来讲一讲下Mybatis。也为自己整理下文档;

      hibernate是一个完全的ORM框架,是完全面向对象的。但是由于全部都是以对象的形式来操作数据库,sql代码都是由框架自动生成,可操作性和灵活性比较Mybatis都要差一些。所以,Mybatis慢慢的变成多数开发的标准配置;

    一、myBatis框架建设

      myBatis的整体框架结构如下图所示,按照下图的工程原样建立即可(其中jar包在文章末尾提供)

    二、编写数据库表对应的实体类

    首先,数据库表结构如下(mysql数据库):

    1、实体类User.java中写入如下代码:

    public class User {
        @Override
        public String toString() {
            return "User [id=" + id + ", username=" + username + ", sex=" + sex
                    + ", address=" + address + ", birthday=" + birthday + "]";
        }
        private int id;
        private String username;
        private String sex;
        private String address;
        private Date birthday;
        public int getId() {
            return id;
        }
        public void setId(int id) {
            this.id = id;
        }
        public String getUsername() {
            return username;
        }
        public void setUsername(String username) {
            this.username = username;
        }
        public String getSex() {
            return sex;
        }
        public void setSex(String sex) {
            this.sex = sex;
        }
        public String getAddress() {
            return address;
        }
        public void setAddress(String address) {
            this.address = address;
        }
        public Date getBirthday() {
            return birthday;
        }
        public void setBirthday(Date birthday) {
            this.birthday = birthday;
        }
    }

    2、向SqlMapConfig.xml中写入配置文件

    <!DOCTYPE configuration
    PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
    "http://mybatis.org/dtd/mybatis-3-config.dtd">
    <configuration>
    <!-- 和spring整合后 environments配置将废除-->
    <environments default="development">
    <environment id="development">
    <!-- 使用jdbc事务管理-->
    <transactionManager type="JDBC" />
    <!-- 数据库连接池-->
    <dataSource type="POOLED">
    <property name="driver" value="com.mysql.jdbc.Driver" />
    <property name="url" value="jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf-8" />
    <property name="username" value="root" />
    <property name="password" value="123456" />
    </dataSource>
    </environment>
    </environments>
    <mappers>
    <mapper resource="sqlmap/User.xml"></mapper>
    </mappers>
    </configuration>

    注意:SqlMapConfig中的mysql账户与密码需要改成你自己的账号密码

    三、在config包下建立log4j.properties(公用文件)

    在文件中写入默认参数:

    # Global logging configuration,建议开发环境中要用debug
    log4j.rootLogger=DEBUG, stdout
    # Console output...
    log4j.appender.stdout=org.apache.log4j.ConsoleAppender
    log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
    log4j.appender.stdout.layout.ConversionPattern=%5p [%t] - %m%n

    四、开始编写User.xml

    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE mapper
    PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
    "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
    <!-- namespace命名空间,为了对sql语句进行隔离,方便管理 ,mapper开发dao方式,使用namespace有特殊作用 -->
    <mapper namespace="test">
    <!-- 在mapper.xml文件中配置很多的sql语句,执行每个sql语句时,封装为MappedStatement对象
    mapper.xml以statement为单位管理sql语句
     -->
        <!-- 根据id查询用户信息 -->
        <!-- 
            id:唯一标识 一个statement
            #{}:表示 一个占位符,如果#{}中传入简单类型的参数,#{}中的名称随意
            parameterType:输入 参数的类型,通过#{}接收parameterType输入 的参数
            resultType:输出结果 类型,不管返回是多条还是单条,指定单条记录映射的pojo类型
         -->
        <select id="findUserById" parameterType="int" resultType="cn.qkp.mybatis.po.User"> 
        SELECT * FROM USER WHERE id=#{id}
        </select>
    </mapper>

    以上配置完成,整个Mybatis基础框架就算是搭建完毕了。我们就可以使用代码来操作数据库了。我们先对数据库进行简单的查询操作;

    =============================================使用Mybatis!===================================================

    一、在first包中建立测试类(MybatisFrist.java)

    内容代码为:

    private SqlSessionFactory sqlsessionfactory;//存储SqlSessionFactory 对象
    @Before
        public void star() throws Exception{
            //设置配置路径,mybitis是以SqlMapConfig.xml为主路径。因为SqlMapConfig中的mapper关联了user.xml
            //因为在config根目录下,所以可以直接引用而不用带config
            String resource = "SqlMapConfig.xml";
            //SqlMapConfig.xml读给输入流,使用mybitis的Resources类下的getResourceAsStream实现
            InputStream inputStream = Resources.getResourceAsStream(resource);
            //创建Mybitis的SqlSessionFactory工厂类
            sqlsessionfactory = new SqlSessionFactoryBuilder().build(inputStream);
        }
        @Test
        public void test(){
            //通过工厂类打开数据接口
            SqlSession sqlsession = sqlsessionfactory.openSession();
            //设置接收对象
            User user = null;
            
            try {
                //查询数据selectOne为查询一条的方法第一个参数是user.xml中的namespace.id;第二个参数是user配置文件中的#{id}
                user = sqlsession.selectOne("test.findUserById", 1);
            } catch (Exception e) {
                // TODO: handle exception
            }finally{
                sqlsession.close();//读完要关闭sqlsession
            }
             System.out.println(user);//打印输出
        }

    运行上述代码,结果为:

    以上便成功连通数据库,并获取到指定数据!

    ps:以上是查询单一数值的查询方法,如果要查询一组数据使用SqlSession的selectList方法,接收一个List;代码如下:

    在User.xml中:

    <select id="selectByName" parameterType="String" resultType="cn.qkp.po.User">
    select * from User where username like '%${value}%'
    </select>

    PS:在xml中,使用#{}占位符表示系统自动会进行java类型和jdbc类型自动转换;而${}表示原样输出,使用${}会造成sql注入漏洞攻击,慎用

    在myBatisRun代码中:

    @Test
        public void star2(){
            SqlSession sqlsession = sqlsessionfactory.openSession();
            List<User> user = sqlsession.selectList("test.selectByName", "小明");
            sqlsession.close();
            System.out.println(user.get(0));
        }    

    结果为:

    相关的jar包连接:http://pan.baidu.com/s/1dF9UtlJ

    以上就是基本的框架大家和简单的查询操作,其余操作正在整理发布,敬请期待~~~~谢谢!!!

  • 相关阅读:
    线程执行器(一)
    修改锁的公平性
    Spark学习视频整合
    使用读写锁实现同步数据访问
    使用锁实现同步
    使用工厂类创建线程
    线程的分组
    android手机状态解释,比方android.os.Build.VERSION.SDK
    Android-Dalvik指令集
    selenium使用Xpath定位之完整篇
  • 原文地址:https://www.cnblogs.com/mylydg/p/6419498.html
Copyright © 2011-2022 走看看