我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何在mybatis中将字段名转换为小写

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何在mybatis中将字段名转换为小写

本篇文章为大家展示了如何在mybatis中将字段名转换为小写,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

1、什么是Mybatis?

MyBatis是一个优秀的持久层框架,是一个半ORM(对象关系映射)框架,它对jdbc的操作数据库的过程进行封装,使开发者只需要关注SQL本身,而不需要花费精力去处理例如加载驱动、创建连接、创建statement等繁杂的过程。

Mybatis通过xml或注解的方式将要执行的statement配置起来,并通过java对象和statement中的sql进行映射生成最终执行的sql语句,最后由mybatis框架执行sql并将结果映射成java对象并返回。

2、Mybatis的优点与缺点?

优点:

  • 基于SQL语句编程,相当灵活,不会对应用程序或者数据库的现有设计造成任何影响,SQL写在XML里,解除sql与程序代码的耦合,便于统一管理;提供XML标签,支持编写动态SQL语句,并可重用。

  • 与JDBC相比,减少了JDBC大量冗余的代码,不需要手动开关连接

  • 很好的与各种数据库兼容

  • 能够与Spring很好的集成

  • 提供映射标签,支持对象与数据库的ORM字段关系映射;提供对象关系映射标签,支持对象关系组件维护。

缺点:

  • SQL语句的编写工作量较大,尤其当字段多、关联表多时,对开发人员编写SQL语句的功底有一定要求。

  • SQL语句依赖于数据库,导致数据库移植性差,不能随意更换数据库。

3、#{}和${}的区别是什么?

#{}是预编译处理,${}是字符串替换。

Mybatis在处理#{}时,会将sql中的#{}替换为?(占位符)号,调用PreparedStatement的set方法来赋值;

Mybatis在处理${}时,就是把${}替换成变量的值。

使用#{}可以有效的防止SQL注入,提高系统安全性。

4、Mybatis和Hibernate有什么区别?

  1. Mybatis和hibernate不同,它不完全是一个ORM框架,因为MyBatis需要程序员自己编写Sql语句。

  2. Hibernate对象/关系映射能力强,数据库无关性好,对于关系模型要求高的软件,如果用hibernate开发可以节省很多代码,提高效率。

  3. Mybatis直接编写原生态sql,可以严格控制sql执行性能,灵活度高,非常适合对关系数据模型要求不高的软件开发,因为这类软件需求变化频繁,一但需求变化要求迅速输出成果。但是灵活的前提是mybatis无法做到数据库无关性,如果需要实现支持多种数据库的软件,则需要自定义多套sql映射文件,工作量大。

5、 Mybatis是如何将sql执行结果封装为目标对象并返回的?都有哪些映射形式?

第1种: 是使用sql列的别名功能,将列别名书写为对象属性名,比如T_NAME AS NAME,对象属性名一般是name,小写,但是列名不区分大小写,Mybatis会忽略列名大小写,智能找到与之对应对象属性名,你甚至可以写成T_NAME AS NaMe,Mybatis一样可以正常工作。

第2种: 使用<resultMap>标签,逐一定义数据库列名和对象属性名之间的映射关系。

6、如何获取自动生成的(主)键值?

insert 方法总是返回一个int值 ,这个值代表的是插入的行数。

如果采用自增长策略,自动生成的键值在 insert 方法执行完后可以被设置到传入的参数对象中。

<insert id=”insertname” usegeneratedkeys=”true” keyproperty=”id”>  insert into names (name) values (#{name})</insert>name name = new name();name.setname(“fred”);int rows = mapper.insertname(name);// 完成后,id已经被设置到对象中system.out.println(“rows inserted = ” + rows);system.out.println(“generated key value = ” + name.getid());

7、Mybatis动态sql有什么用?执行原理?有哪些动态sql?

Mybatis动态sql可以让我们在Xml映射文件内,以标签的形式编写动态sql,完成逻辑判断和动态拼接sql的功能。 Mybatis提供了9种动态sql标签:trim|where|set|foreach|if|choose|when|otherwise|bind。 其执行原理为,从sql参数对象中计算表达式的值,根据表达式的值动态拼接sql,以此来完成动态sql的功能。

例如:

<select id="selectUserByListId" parameterType="com.ys.vo.UserVo" resultType="com.ys.po.User">  select * from user  <where>    <!--      collection:指定输入对象中的集合属性      item:每次遍历生成的对象      open:开始遍历时的拼接字符串      close:结束时拼接的字符串      separator:遍历对象之间需要拼接的字符串      select * from user where 1=1 and (id=1 or id=2 or id=3)     -->    <foreach collection="ids" item="id" open="and (" close=")" separator="or">      id=#{id}    </foreach>  </where></select>

8、Mybatis的Xml映射文件中,不同的Xml映射文件,id是否可以重复?

不同的Xml映射文件,如果配置了namespace,那么id可以重复;如果没有配置namespace,那么id不能重复;

原因就是namespace+id是作为Map<String, MapperStatement>的key使用的,如果没有namespace,就剩下id,那么,id重复会导致数据互相覆盖。有了namespace,自然id就可以重复,namespace不同,namespace+id自然也就不同。

但是,在以前的Mybatis版本的namespace是可选的,不过新版本的namespace已经是必须的了。

9、一对一、一对多的关联查询 ?

<mapper namespace="com.lcb.mapping.userMapper">   <!--association 一对一关联查询 -->   <select id="getClass" parameterType="int" resultMap="ClassesResultMap">     select * from class c,teacher t where c.teacher_id=t.t_id and c.c_id=#{id}   </select>    <resultMap type="com.lcb.user.Classes" id="ClassesResultMap">     <!-- 实体类的字段名和数据表的字段名映射 -->     <id property="id" column="c_id"/>     <result property="name" column="c_name"/>     <association property="teacher" javaType="com.lcb.user.Teacher">       <id property="id" column="t_id"/>       <result property="name" column="t_name"/>     </association>   </resultMap>     <!--collection 一对多关联查询 -->   <select id="getClass2" parameterType="int" resultMap="ClassesResultMap2">     select * from class c,teacher t,student s where c.teacher_id=t.t_id and c.c_id=s.class_id and c.c_id=#{id}   </select>    <resultMap type="com.lcb.user.Classes" id="ClassesResultMap2">     <id property="id" column="c_id"/>     <result property="name" column="c_name"/>     <association property="teacher" javaType="com.lcb.user.Teacher">       <id property="id" column="t_id"/>       <result property="name" column="t_name"/>     </association>      <collection property="student" ofType="com.lcb.user.Student">       <id property="id" column="s_id"/>       <result property="name" column="s_name"/>     </collection>   </resultMap> </mapper>

9、Mybatis是否支持延迟加载?如果支持,它的实现原理是什么?

Mybatis仅支持association关联对象和collection关联集合对象的延迟加载,association指的就是一对一,collection指的就是一对多查询。在Mybatis配置文件中,可以配置是否启用延迟加载lazyLoadingEnabled=true|false。

它的原理是,使用CGLIB创建目标对象的代理对象,当调用目标方法时,进入拦截器方法,比如调用a.getB().getName(),拦截器invoke()方法发现a.getB()是null值,那么就会单独发送事先保存好的查询关联B对象的sql,把B查询上来,然后调用a.setB(b),于是a的对象b属性就有值了,接着完成a.getB().getName()方法的调用。这就是延迟加载的基本原理。

当然了,不光是Mybatis,几乎所有的包括Hibernate,支持延迟加载的原理都是一样的。

10、Mybatis的一级、二级缓存?

1)一级缓存: Mybatis的一级缓存是指SQLSession,一级缓存的作用域是SQlSession, Mabits默认开启一级缓存。在同一个sqlSession中两次执行相同的sql语句,第一次执行完毕会将数据库中查询的数据写到缓存(内存),第二次会从缓存中获取数据将不再从数据库查询,从而提高查询效率。当一个sqlSession结束后该sqlSession中的一级缓存也就不存在了。

一级缓存是默认开启的;
2:底层其实是基于hashmap的本地内存缓存;
3:作用域是session(其实就相当于一个方法);
4:当session关闭或者刷新的时候缓存清空;
5:不通sqlsession之间缓存互不影响;

2)二级缓存: 二级缓存是mapper级别的,Mybatis默认是没有开启二级缓存的。多个SqlSession去操作同一个Mapper的sql语句,多个SqlSession去操作数据库得到数据会存在二级缓存区域,多个SqlSession可以共用二级缓存,二级缓存是多个SqlSession共享的。

首先mybatis默认是没有开启二级缓存的
2:二级缓存需要我们手动开启,它是mapper级别的缓存;
3:同一个namespace下的所有操作语句,都影响着同一个Cache,即二级缓存被多个SqlSession共享,
是一个全局的变量。

11、Mybatis是如何进行分页的?分页插件的原理是什么?

Mybatis使用RowBounds对象进行分页,它是针对ResultSet结果集执行的内存分页,而非物理分页。可以在sql内直接书写带有物理分页的参数来完成物理分页功能,也可以使用分页插件来完成物理分页。

分页插件的基本原理是使用Mybatis提供的插件接口,实现自定义插件,在插件的拦截方法内拦截待执行的sql,然后重写sql,根据dialect方言,添加对应的物理分页语句和物理分页参数。

12、使用MyBatis的mapper接口调用时有哪些要求?

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

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

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

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

上述内容就是如何在mybatis中将字段名转换为小写,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何在mybatis中将字段名转换为小写

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何在mybatis中将字段名转换为小写

本篇文章为大家展示了如何在mybatis中将字段名转换为小写,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1、什么是Mybatis?MyBatis是一个优秀的持久层框架,是一个半ORM(对象关系映射
2023-06-06

javascript如何将字母转为小写

这篇文章将为大家详细讲解有关javascript如何将字母转为小写,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。JavaScript可以做什么1.可以使网页具有交互性,例如响应用户点击,给用户提供更好的体
2023-06-14

php如何将字符串转为小写

这篇文章给大家分享的是有关php如何将字符串转为小写的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。php将字符串转为小写的方法:1、strtolower()函数,可以将字符串中的字母全部转换为小写,语法“strt
2023-06-15

PHP如何将字符串转化为小写

本文介绍了PHP中将字符串转换为小写的五种方法:strtolower(),mb_strtolower(),ctype_lower(),preg_replace(),和strtr().性能比较显示strtolower()在大多数情况下最快,而mb_strtolower()适用于多字节字符。根据特定需求选择最佳方法。
PHP如何将字符串转化为小写
2024-04-02

Java如何将字符串转化为小写

本文介绍了四种Java中将字符串转换为小写的方法:toLowerCase()方法、String.CASE_INSENSITIVE_ORDER比较器、Character.toLowerCase()方法和正则表达式替换。每种方法各有优缺点,本文详细探讨了其适用场景,有助于读者根据特定情况选择最合适的方法。
Java如何将字符串转化为小写
2024-04-02

如何在 Go 中将整数转换为字节

Golang不知道大家是否熟悉?今天我将给大家介绍《如何在 Go 中将整数转换为字节》,这篇文章主要会讲到等等知识点,如果你在看完本篇文章后,有更好的建议或者发现哪里有问题,希望大家都能积极评论指出,谢谢!希望我们能一起加油进步!问题内容我
如何在 Go 中将整数转换为字节
2024-04-05

php如何将数组键名转为小写

本篇内容介绍了“php如何将数组键名转为小写”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在php中,可以利用array_change_ke
2023-07-02

如何在 PHP 中将 DateTime 转换为字符串

在 PHP 中将 DateTime 转换为字符串非常容易,有一些专用的函数。例如,使用预定义的格式或使用 list()。使用 DateTime 类的 format() 方法PHP DateTime 类用于管理日期和时间,它从 PHP 5.2
如何在 PHP 中将 DateTime 转换为字符串
2024-02-27

在 PHP 中将数字转换为月份名称

在编写 PHP 应用程序时,你将使用日期和时间。使用这两者很容易,尤其是在使用不同的对象和功能时。我们可以从秒、分、时、日、月到年使用这些函数。但是,我们希望在本文中使用数字或字符串日期格式创建月份名称。在 PHP 中使用 DateTime
在 PHP 中将数字转换为月份名称
2024-02-27

PHP如何把字符串转换为小写

PHP提供多种方法将字符串转换为小写,包括使用strtolower()、mb_strtolower()、lcfirst()、ctype_lower()函数和正则表达式。首字母大写的字符串使用lcfirst()函数,含有非ASCII字符的字符串使用mb_strtolower()函数,性能敏感情况可手动遍历字符串转换。理解这些方法有助轻松实现字符串小写转换。
PHP如何把字符串转换为小写
2024-04-02

Java如何把字符串转换为小写

Java中转换字符串为小写的几种方法:toLowerCase()方法:直接返回小写字符串。String构造函数:将字符串转换为char[]数组再转换为小写。正则表达式:使用toLowerCase()方法将匹配的文本转换为小写。Character类:将字符串转换为字符数组,再将每个字符转换为小写。选择方法时考虑效率、灵活性等因素。在转换过程中注意输入字符串的类型,并采取适当的预防措施。
Java如何把字符串转换为小写
2024-04-02

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录