zoukankan      html  css  js  c++  java
  • Mybatis容易遇到的问题

    1.MyBatis中#和$的区别?

     1.使用#的原理是?占位符,而$的原理为直接字符串拼接方式

        2.$方式一般使用在写数据库中的固定字段时候才会使用例如表名或者列名(select * from user order by xxx)这个中的xxx可以使用$

     3.#可以防止注入,$不能防止sql注入

     4.一般情况下能使用#就不适用$.

    2.MyBatis的编程步骤是什么样的?

      1.创建SqlSessionFactory

      2.通过sqlSessionFactory创建SqlSession

      3.通过sqlSession执行数据库操作.

      4.调用session.commit()提交事务

      5.调用sessioin.close()关闭会话

    3.JDBC编程有那些不足之处,NyBatis是如何解决的?

    1.数据库的创建,释放频繁造成系统资源浪费从而影响性能,如果使用数据库连接池可解决此问题.

      解决:在Sqlmapconfig.xml中配置数据连接池,使用连接池管理数据库连接

    2.sql语句写在代码中造成代码不易维护,实际用sql变化大,sql变动需要改变java代码

      解决:将sql语句配置在xxxmapper.xml文件中与java代码分离.

    3.向sql语句传参麻烦,因为sql语句的where条件不一定,可能多也可能少,占位符需要和参数一一对应.

      解决:mybatis自动将java对象映射至sql语句.

    4.对结果即解析麻烦,sql变化导致解析代码变化,且解析前需要进行遍历,如果能将数据库记录封装成pojo对象解析还比较方便.

      解决:mybatis自动将sql执行结果映射至java对象

    4.使用mybatis的mapper接口调用时有那些要求?

      1.Mapper.xml文件中的namespace即是mapper接口的类路径

      2.Mapper接口方法名和mapper.xml中定义的每个sql的id相同

      3.Mapper接口方法的输入参数类型和mapper.xml中定义的每个sql的parameterType的类型相同.

      4.Mapper接口方法的输出参数类型和mapper.xml中定义的每个sql的resultType的类型相同.

    MyBatis中一级缓存和二级缓存?

    1.一级缓存:基于perpetualCache的HashMap本地缓存,其存储作用域为session,当session flush或者close()之后,该session中的所有cache将清空.

    2.二级缓存和一级缓存其机制相同,默认也是采用PerpetualCache,HashMap存储,不同在于其存储作用域为Mapper(NameSpace),并且可自定义存储源,如Ehcache.作用域为namespace是指该namespace对应的配置文件中所有的select操作结果都缓存,这样不同于线程之间就可以共用二级缓存,启动二级缓存:在mapper配置文件中<cache/>

      二级缓存可以设置返回的缓存对象策略:<cache readOnly="true">.当readOnly="true"时,表示二级缓存返回给所有调用者同一个缓存对象实例,调用者可以update获取的缓存实例,但是这样可能造成其他调用者出现数据不一致的情况(因为所有调用的是同一个实例).当readOnly=false时,返回给调用者的是二级缓存总缓存对象的拷贝,即不同调用者获取的是缓存对象的不同实例,这样调用者对各自的缓存对象的修改不会影响到其他的调用者,即是安全的,所以默认是readOnly="false"

    3.对于缓存数据更新机制,当某一个作用域(一级缓存session/二级缓存namespaces)的进行了cud操作后,默认该作用域下所有select中的缓存将被clear'

    6.Mybstis在insert插入数据操作时返回主键ID?

    数据库为mysql时:

      

    <insert id="insertUser" parameterType="com.qingmu.pojo.User" useGeneratedKeys="true" keyProperty="id">
            <!--<selectKey keyProperty="id" order="AFTER" resultType="int">-->
                <!--select LAST_INSERT_ID()-->
            <!--</selectKey>-->
            insert into USER VALUES (#{id},#{username},#{sex},#{birthday},#{address})
        </insert>

    keyproperty表示返回的id要保存到对象的那个属性中,useGeneratedKeys表示主键id为自增长模式.Mysql中做上配置就可以了.

    数据库为Oracle时"

    "

     由于Oracle没有自增长这一说,只有序列这种模仿自增的形式,所以不能再使用UserGeneratedKeys属性,而是使用selectKey将Id获取并赋值到对象的属性中,insert插入操作时正常插入id

  • 相关阅读:
    C#创建ActiveX
    easy-ui 中的事件触发 (tree)
    程序目录
    微信公众平台开发
    Redis分片机制
    Redis主从切换
    Redis主从复制
    Redis持久化机制
    Redis缓存击穿、缓存穿透、缓存雪崩
    Redis与数据库数据一致性
  • 原文地址:https://www.cnblogs.com/qingmuchuanqi48/p/10921019.html
Copyright © 2011-2022 走看看