广告
返回顶部
首页 > 资讯 > 精选 >如何在mybatis中将字段名转换为小写
  • 487
分享到

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

2023-06-06 18:06:40 487人浏览 安东尼
摘要

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

本篇文章为大家展示了如何在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中将字段名转换为小写,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网精选频道。

--结束END--

本文标题: 如何在mybatis中将字段名转换为小写

本文链接: https://www.lsjlt.com/news/248290.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • 如何在mybatis中将字段名转换为小写
    本篇文章为大家展示了如何在mybatis中将字段名转换为小写,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1、什么是Mybatis?MyBatis是一个优秀的持久层框架,是一个半ORM(对象关系映射...
    99+
    2023-06-06
  • 如何用PHP将字符串转换为小写
    在Web开发中,PHP是数量最多的服务器端脚本语言之一。对于PHP开发者来说,有时需要把字符串大小写转换。在本文中,我们将深入探讨如何用PHP将字符串转换为小写。在PHP中,有多种方法可以将字符串转换为小写。以下是其中一些方法:strtol...
    99+
    2023-05-14
    php 字符串
  • c# 如何将字符串转换为大写或小写
    目录c#将字符串转换为大写或小写c#大小写转换合集1.在代码中以 Excel 加日期的算法2.数字转大写3.日、月、日期转大写4.人民币金额小写转大写5.获取中文字拼音首字母6.银行...
    99+
    2022-11-13
  • javascript如何将字母转为小写
    这篇文章将为大家详细讲解有关javascript如何将字母转为小写,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。JavaScript可以做什么1.可以使网页具有交互性,例如响应用户点击,给用户提供更好的体...
    99+
    2023-06-14
  • javascript如何将大写字母转为小写
    本篇内容主要讲解“javascript如何将大写字母转为小写”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“javascript如何将大写字母转为小写”吧! ...
    99+
    2022-10-19
  • javascript如何将小写字母转为大写
    这篇文章主要介绍“javascript如何将小写字母转为大写”,在日常操作中,相信很多人在javascript如何将小写字母转为大写问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解...
    99+
    2022-10-19
  • mysql如何将字符串转为小写
    小编给大家分享一下mysql如何将字符串转为小写,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! my...
    99+
    2022-10-19
  • php如何将字符串转为小写
    这篇文章给大家分享的是有关php如何将字符串转为小写的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。php将字符串转为小写的方法:1、strtolower()函数,可以将字符串中的字母全部转换为小写,语法“strt...
    99+
    2023-06-15
  • 如何在 Python 中将数字转换为字母?
    在编程中,有时我们需要将数字转换为字母,例如将数字表示的年份转换为对应的字母表示,或者将数字编码转换为字母字符。Python 提供了多种方法来实现这种转换。本文将详细介绍在 Python 中将数字转换...
    99+
    2023-10-07
    python numpy 数据分析
  • php如何将数组键名转为小写
    本篇内容介绍了“php如何将数组键名转为小写”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在php中,可以利用array_change_ke...
    99+
    2023-07-02
  • javascript如何将字符串转换为大写
    这期内容当中小编将会给大家带来有关javascript如何将字符串转换为大写,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。转换方法:1、使用toUpperCase()函数...
    99+
    2022-10-19
  • php如何将字符串转化为小写
    在php中使用strtolower()函数将字符串转化为小写,具体方法如下:strtolower()函数作用:php中strtolower()函数的作用是用于将字符串转换为小写。strtolower()函数语法:strtolower(str...
    99+
    2022-10-19
  • 小程序如何将字符串转换为数字
    这篇“小程序如何将字符串转换为数字”除了程序员外大部分人都不太理解,今天小编为了让大家更加理解“小程序如何将字符串转换为数字”,给大家总结了以下内容,具有一定借鉴价值,内容详细步骤清晰,细节处理妥当,希望大家通过这篇文章有所收获,下面让我们...
    99+
    2023-06-26
  • python使用lower函数将字符串中的大小字符转换为小写
    在python中使用lower()函数将字符串中大小字符转换为小写的方法lower:lower()函数的作用是转换字符串中所有大写字符为小写。lower()函数语法:str.lower()lower()函数使用方法:str = "HELLO...
    99+
    2022-10-04
  • mybatis返回类型map时如何将key大写转为小写
    亲测: SELECT DEPTNO as "deptno",DEPTNAME,DEPTGRADE,PARENTDEPT FROM VMGR_DEPT ...
    99+
    2022-11-12
  • 如何将 MySQL 表字段类型从 BLOB 转换为 JSON?
    简介 如果 MySQL 中有一个包含 BLOB 字段的表,您希望将其转换为 JSON 字段,则可以通过执行一系列 ALTER TABLE 语句来完成。该过程包括创建具有所需数据类型 (JSON) 的新列、将数据从旧列复制到新列、删除旧列以及...
    99+
    2023-10-22
  • php如何将字符串全部转为小写
    本教程操作环境:windows7系统、PHP8.1版、DELL G3电脑在PHP中,想要将字符串中的字母全部转换为小写,可以利用strtolower()、mb_strtolower() 或mb_convert_case()函数方法...
    99+
    2022-10-18
  • go语言字符串如何将小写转为大写
    这篇“go语言字符串如何将小写转为大写”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“go语言字符串如何将小写转为大写”文章吧...
    99+
    2023-07-05
  • PHP如何将数字转换为人民币大写
    这篇文章主要讲解了“PHP如何将数字转换为人民币大写”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“PHP如何将数字转换为人民币大写”吧!需要用到的函数在开始编写这个程序之前,我们需要熟悉一些...
    99+
    2023-07-05
  • php中如何将汉字转换为字符串
    在PHP中,可以使用mb_convert_encoding函数将汉字转换为字符串。具体代码如下:```php$chinese = '...
    99+
    2023-09-04
    php
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作