网站首页 > 技术文章 正文
博主将会针对Java面试题写一组文章,包括J2ee,SQL,主流Web框架,中间件等面试过程中面试官经常问的问题,欢迎大家关注。一起学习,一起成长,文章底部有面试题。
分页:
分页是一种通过表数据分段展示给用户的技术。使用户每次看到的是其中一部分数据,而非全部数据,就和我们翻阅电子书或者阅读书籍类似。分页能加快页面反应速度,增强用户使用体验。
古典JDCB实现分页:
先查询出总的条数,用于计算总页数;
select count(1) from 表 where 条件;
再根据pageNum和pageSize计算出startRownum和endRownum;
再拼接sql时,拼接入startRownum和endRownum,用于获取分页数据;
以下是Oracle分页demo:
select *from (select t.*,rownum rn from (select *from 表 where 条件 order by 字段 )t )a where a.rn>=搜索开始行 and a.rn<= 搜索结束行
最后处理resultSet结果集,关闭connection。
Mybatis分页简介(方言为mysql时):
mybatis提供了RowBounds分页,
return userDao.queryObjectByPage(name, new RowBounds(start, limit));
这种分页不适合大量数据存在的情况。而实际工作中,往往数据量比较大,最实用分页的实现方式还是运用拦截器实现,支持根据不同数据库配置不同分页sql的方言。
拦截器实现简易分页核心代码如下:
面试拓展:
昨日回顾
1.mybatis 如何防止SQL注入。
#号的入参时候,mybatis在拼接sql后,会进行预编译。不会直接用入参对象的值直接替换,而是将待替换的值先用?(问号)代替,执行时,直接使用编译好的SQL,替换占位符“?”就可以了。这样就很好避免了sql注入的风险。
$号入参会有sql注入风险。
今日问题
1.谈谈返回映射中resultMap和resultType区别。
-------------
写的不好,如果大家有更高的见解欢迎评论。
- 上一篇: 一、手写mybatis框架
- 下一篇: Mybatis入门
猜你喜欢
- 2024-11-21 MyBatis详解(二)
- 2024-11-21 想要开发中灵活的使用Mybatis?精通结果映射,你准了吗?
- 2024-11-21 小学妹问:Mybatis常见注解有哪些?
- 2024-11-21 重学Mybatis(二)-------主键自增 (含面试题)
- 2024-11-21 Mybatis入门
- 2024-11-21 一、手写mybatis框架
- 2024-11-21 MyBatis中的翻页
- 2024-11-21 Mybatis的基础和高级查询应用实践
- 2024-11-21 看完这一篇学会MyBatis就够了
- 2024-11-21 MyBatis 总结
- 最近发表
- 标签列表
-
- cmd/c (57)
- c++中::是什么意思 (57)
- sqlset (59)
- ps可以打开pdf格式吗 (58)
- phprequire_once (61)
- localstorage.removeitem (74)
- routermode (59)
- vector线程安全吗 (70)
- & (66)
- java (73)
- org.redisson (64)
- log.warn (60)
- cannotinstantiatethetype (62)
- js数组插入 (83)
- resttemplateokhttp (59)
- gormwherein (64)
- linux删除一个文件夹 (65)
- mac安装java (72)
- reader.onload (61)
- outofmemoryerror是什么意思 (64)
- flask文件上传 (63)
- eacces (67)
- 查看mysql是否启动 (70)
- java是值传递还是引用传递 (58)
- 无效的列索引 (74)