2020-08-11 Mybatis重要对象生命周期、ResultMap结果集映射、日志工厂、log4j使用、分页操作、注解实现功能替代XML文件

生命周期、作用域

SqlSessionFactoryBuilder:只是用来创建SqlSessionFactory,创建完毕后就不需要了

SqlSessionFactory:可以理解为数据库连接池,完整贯穿整个应用运行期间,不可丢弃创建

SqlSession:相当于数据库连接请求,每次需要操作数据库就用一次,用完马上关闭,相当于释放,避免并发问题
而SqlSession每一次连接Mapper,都在处理一个业务

ResultMap结果集映射

专门用于解决数据库字段和属性名不一致的问题。

解决方法一:可以在SQL中直接用别名

解决方法二:在Mapper.xml文件中,直接不用resultType,而使用resultMap

    <resultMap id="UserMap" type="User">
        <result column="pwd" property="password"/>
    </resultMap>
	
   <select id="getUserByLimit" parameterType="map" resultMap="UserMap">
        select * from mybatis.user limit #{startIndex},#{pageSize}
    </select>

日志工厂

如果一个数据库操作出现异常,需要排错
问题:怎么打印SQL?

在Settings中可以进行设置,主要有STDOUT_LOGGING标准输出,可以不用配直接使用
另外一个就是LOG4J

 <!-- 记住一定要放在properties和typeAliases标签中间,有先后顺序设定的 -->
    <settings>
        <setting name="logImpl" value="STDOUT_LOGGING"/>
    </settings>

这个是标准的日志工厂实现

Log4j讲解

上面那个是标准工厂实现,但是Log4j需要导包等步骤

建立log4j.properties文件,然后填入内容

测试类中:
导包:

import org.apache.log4j.Logger;

根据不同的情况,使用其日志打印信息:

    public static Logger logger = Logger.getLogger(UserMapper01.class);


    @Test
    public void test(){
        //通过工具类获得sqlsession对象
        SqlSession sqlSession = MybatisUtils.getSqlSession();
                                MybatisUtils.getSqlSession();
        UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
        List<User> Userlist = userMapper.getUserList();
        logger.info(Userlist);
        logger.debug(Userlist);
        logger.error(Userlist);
        for (User user : Userlist) {
            System.out.println(user);
        }
        //关闭sqlsession
        sqlSession.close();
    }

Limit分页

分页主要是减少数据的处理量
select * from user limit 0,5;

//接口中:
    List<User> getUserByLimit(Map<String,Integer> map);
//Mapper.xml中:
    <resultMap id="UserMap" type="User">
        <result column="pwd" property="password"/>
    </resultMap>

    <select id="getUserByLimit" parameterType="map" resultMap="UserMap">
        select * from mybatis.user limit #{startIndex},#{pageSize}
    </select>
//测试方法:
    public void getUserBylimit(){
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
        Map<String,Integer> map = new HashMap<String,Integer>();
        map.put("startIndex",0);
        map.put("pageSize",2);
        System.out.println(map);
        List<User> list = userMapper.getUserByLimit(map);
        for(User user : list){
            System.out.println(user);
        }
        sqlSession.close();
    }

尤其注重Mapper.xml中的标签名参数:
一)、parameterType代表了参数的类型。它是通过HashMap的形式传入了两个键值对,代表limit方法的下标

二)、resultMap代表返回结果的映射,因为返回结果的类型名和数据库不一样,所以用了ResultMap来映射,UserMap是在UserMapper中配置的ID,注意看

RowBounds分页

是面向对象思想做的,基本不会使用,已淘汰
直接创建RowBounds类,使用方法来进行实现,可以直接点进方法看使用方法

分页插件

Mybatis PageHelper

使用注解执行整个查询过程

@select(“select * from user”)
这里底层主要是使用反射的机制来读取接口的方法、参数、执行体等等,这样就做完了全部功能
但是使用注解,对于参数、返回值等操作就很会很麻烦,复杂的SQL语句还是要用XML配置文件来使用
记得一定要在核心配置文件中进行配置

    <mappers>
        <mapper resource="com/wang/Dao/UserMapper.xml"/>
    </mappers>

	<mappers>
        <mapper class="com.wang.Dao.UserMapper"/>
    </mappers>
	

静态代理/动态代理

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 智慧社区背景与挑战 随着城市化的快速发展,社区面临健康、安全、邻里关系和服务质量等多方面的挑战。华为技术有限公司提出智慧社区解决方案,旨在通过先进的数字化技术应对这些问题,提升城市社区的生活质量。 2. 技术推动智慧社区发展 技术进步,特别是数字化、无线化、移动化和物联化,为城市社区的智慧化提供了可能。这些技术的应用不仅提高了社区的运行效率,也增强了居民的便利性和安全性。 3. 智慧社区的核心价值 智慧社区承载了智慧城市的核心价值,通过全面信息化处理,实现对城市各个方面的数字网络化管理、服务与决策功能,从而提升社会服务效率,整合社会服务资源。 4. 多层次、全方位的智慧社区服务 智慧社区通过构建和谐、温情、平安和健康四大社区模块,满足社区居民的多层次需求。这些服务模块包括社区医疗、安全监控、情感沟通和健康监测等。 5. 智慧社区技术框架 智慧社区技术框架强调统一平台的建设,设立数据中心,构建基础网络,并通过分层建设,实现平台能力及应用的可持续成长和扩展。 6. 感知统一平台与服务方案 感知统一平台是智慧社区的关键组成部分,通过统一的RFID身份识别和信息管理,实现社区服务的智能化和便捷化。同时,提供社区内外监控、紧急救助服务和便民服务等。 7. 健康社区的构建 健康社区模块专注于为居民提供健康管理服务,通过整合医疗资源和居民接入,实现远程医疗、慢性病管理和紧急救助等功能,推动医疗模式从治疗向预防转变。 8. 平安社区的安全保障 平安社区通过闭路电视监控、防盗报警和紧急求助等技术,保障社区居民的人身和财产安全,实现社区环境的实时监控和智能分析。 9. 温情社区的情感沟通 温情社区着重于建立社区居民间的情感联系,通过组织社区活动、一键呼叫服务和互帮互助平台,增强邻里间的交流和互助。 10. 和谐社区的资源整合 和谐社区作为社会资源的整合协调者,通过统一接入和身份识别,实现社区信息和服务的便捷获取,提升居民生活质量,促进社区和谐。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值