码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • MyBatis学习:自定义别名


    1、本篇博文的背景和目的

    目前我本人正在学习MyBatis框架,在原先了解并且懵懵懂懂使用的基础上,开始系统正式的学习。阐述了MVC架构模式和三层架构,明晰了在Web项目中的普遍编码层次,回顾了JDBC连接数据库,建立了使用MyBatis和MySQL的Maven项目,解释了STDOUT_LOGGING日志和手动提交事务,记录了MyBatis中#占位符的使用方法,回顾了MyBatis执行SQL语句的过程和使用到的一些重要类和接口,记录了将固定化的代码整合到一个工具类MyBatisUtil中,以减少代码量。记录了dao层接口的实现以及为什么要实现它。记录了MyBatis动态代理和使用动态代理的要求以及使用了动态代理生成的实现类。记录了MyBatis框架下传参的五种方法,占位符#和$。本篇博客记录一下如何自定义别名。

    2、我的上一篇博文

    上一篇博文我记录的是$占位符的具体使用方法,感兴趣的读者可以移步查阅,链接如下所示:

    MyBatis学习:$占位符的使用_你是我的日月星河的博客-CSDN博客目前我本人正在学习MyBatis框架,在原先了解并且懵懵懂懂使用的基础上,开始系统正式的学习。阐述了MVC架构模式和三层架构,明晰了在Web项目中的普遍编码层次,回顾了JDBC连接数据库,建立了使用MyBatis和MySQL的Maven项目,解释了STDOUT_LOGGING日志和手动提交事务,记录了MyBatis中#占位符的使用方法,回顾了MyBatis执行SQL语句的过程和使用到的一些重要类和接口,记录了将固定化的代码整合到一个工具类MyBatisUtil中,以减少代码量。...https://blog.csdn.net/weixin_46281472/article/details/126189174

    3、MyBatis中什么是别名,为什么会用到别名

    这里的别名指的是:某一种数据类型的别名。这里提到的数据类型,可以是JAVA中自带的基本数据类型,也可以是自己编写的实体类。

    在MyBatis的mapper.xml文件中,parameterType属性和resultType属性的值都是某一种数据类型的全限定路径名称,但是全限定路径名称太长了,所以,MyBatis允许给每一种数据类型都起一个别名,使用别名来代替它的全限定路径名称。

    MyBatis已经帮我们给每一种基本数据类型起好了对应的别名,这个可以在MyBatis的官方手册中查询到。

    但是,我们自定义的实体类怎么给别名呢?这就需要我们自己配置了。

    4、在MyBatis的总配置文件中自定义别名

    如果我们需要给自定义实体类配置别名,那么就需要在MyBatis的总配置文件中配置。

    下面我直接给出代码:

    1. configuration
    2. PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
    3. "http://mybatis.org/dtd/mybatis-3-config.dtd">
    4. <configuration>
    5. <settings>
    6. <setting name="logImpl" value="STDOUT_LOGGING"/>
    7. settings>
    8. <typeAliases>
    9. <typeAlias type="com.dcy.domain.Student" alias="Student">typeAlias>
    10. <package name="com.dcy.domain"/>
    11. typeAliases>
    12. <environments default="development">
    13. <environment id="development">
    14. <transactionManager type="JDBC">transactionManager>
    15. <dataSource type="POOLED">
    16. <property name="driver" value="com.mysql.cj.jdbc.Driver"/>
    17. <property name="url" value="jdbc:mysql://localhost:3306/ssm?useUnicode=true&characterEncoding=utf8&useSSL=false&serverTimezone=Hongkong&allowMultiQueries=true"/>
    18. <property name="username" value="root"/>
    19. <property name="password" value="123456"/>
    20. dataSource>
    21. environment>
    22. environments>
    23. <mappers>
    24. <mapper resource="com/dcy/dao/StudentDao.xml">mapper>
    25. mappers>
    26. configuration>

    注意看我代码中的注释。

    这里说一个需要注意的点:与自定义配置别名有关的typeAliases标签必须写在settings标签之后。MyBatis的总配置文件中标签之间是有顺序的,这个顺序我们可以看到。方法是:Windows操作系统下,按着Ctrl键,左键点击configuration标签,进入到如下页面:

     上面就是标签之间的先后顺序。

    配置别名有两种语法格式:1、使用标签,此标签的type属性值是某数据类型的全限定路径名称,alias属性值是别名。2、使用标签,只有一个name属性。name属性值是某一个包的全限定路径名称。使用这种方法默认会将此包中的所有类名作为这个类的别名。

    最后,我们就可以使用别名,例如下面的使用方法:

    1. <select id="queryStudentOrderByColume" resultType="Student">
    2. select * from student order by ${colume}
    3. select>

    5、我的下一篇博文

  • 相关阅读:
    大数据(9e)Flink侧输出流
    基于Java的旅游管理系统设计与实现(源码+lw+部署文档+讲解等)
    Codeforces Round #816 (Div. 2) 题解 A,B,C
    kafka面试连环问(2),你能撑到哪一问?
    计算机毕业设计ssm宠物托运网站8m8iz系统+程序+源码+lw+远程部署
    JavaScript/uni-app对接海康ISC openapi
    2022年第一季度保险服务数字化跟踪分析
    Vuecli项目结构,及组件的使用
    计算机毕业论文选题微信小程序毕业设计论文SSM食堂订餐点餐项目+后台管理系统|前后分离VUE[包运行成功]
    Linux安装Zookeeper详细步骤
  • 原文地址:https://blog.csdn.net/weixin_46281472/article/details/126242249
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号