Java学习-MyBatis学习(二)

news2024/12/23 17:53:41

代码下载

MyBatis核心配置文件
jdbc.driver=com.mysql.cj.jdbc.Driver
jdbc.url=jdbc:mysql://192.168.29.201:3306/mybatis
jdbc.username=root
jdbc.password=123456
<configuration>
    <!-- 
    	environments:配置多个连接数据库环境
    	default:默认使用的环境id
    	environment id:表示连接数据库的环境的唯一标识,不能重复
    	 -->
    	 <!-- 引入properties文件 -->
    <properties resources="jdbc.properties/>
    <!-- 设置类型别名-->
    <typeAliases>
        <!-- 
            type:设置需要设置别名的类型,
            alias:设置某个类型的别名,若此项不设置,则类型别名默认为类名,且不区分大小写
        -->
	<!--<typeAlias type="com.lotus.mybatis.pojo.User" alias="User"></typeAlias>-->
        <!--
        以包为单位将包下所有类型设置默认的类型别名,即类名,且不区分大小写 
        -->
        <package name="com.lotus.mybatis.pojo"/>
    </typeAliases>
    <environments default="development">   
        <environment id="development">
        <! -- 
         type:JDBC | MANAGED
         JDBC:表示当前环境中,执行SQL时,使用的是JDBC中原生的事务管理方式,事务提交和回滚需要手动处理
         MANAGED:表示被管理,例如Spring
        -->
            <transactionManager type="JDBC"/>
            <!-- 
            dataSource:配置数据源
            type:POOLED | UNPOOLED | JNDI 数据源类型
            POOLED:使用数据库连接池缓存数据库连接
            UNPOOLED:不使用数据库连接池
            JNDI:使用上下文数据源
            -->
            <dataSource type="POOLED">
            	<!-- 设置连接数据库驱动-->
                <property name="driver" value="${jdbc.driver}"/>
            	<!-- 设置连接数据库连接地址-->
                <property name="url" value="${jdbc.url}"/>
                <!-- 设置连接数据库用户名-->
                 <property name="username" value="${jdbc.username}"/>
                <!-- 设置连接数据库密码-->
                <property name="password" value="${jdbc.password}"/>
            </dataSource>
        </environment>
    </environments>
    <!-- 引入映射文件 -->
    <mappers>
        <mapper resource="mappers/UserMapper.xml"/>
    </mappers>
</configuration>


<!-- mappers配置--->
<mappers>
<!--        <mapper resource="mappers/UserMapper.xml"/>-->
        <!--以包为单位引入映射文件
            1.mapper接口所在的包要和映射文件所在的包一致
            2.mapper接口要和映射文件的名字一致

        -->
        <package name="com.lotus.mybatis.mapper"/>
    </mappers>
设置配置文件模板
  • ①复制要创建模板的配置文件内容

  • 在这里插入图片描述

  • 在这里插入图片描述
MyBatis获取参数值
  • Mybatis获取参数值的两种方式:${} 和 #{}
  • ${}本质就是字符串拼接,#{}本质是占位符赋值
  • ${}使用字符串拼接的方式拼接SQL,若为字符串类型或日期类型的字段进行赋值时,需要手动加单引号;但#{}使用占位符赋值的方式拼接SQL,此时为字符串类型或日期类型的字段进行赋值时,可以自动添加单引号
//pojo
public class User {
    private Integer id;
    private String username;
    private String password;
    private Integer age;
    private String sex;
    private String email;

    public User() {
    }

    public User(Integer id, String username, String password, Integer age, String sex, String email) {
        this.id = id;
        this.username = username;
        this.password = password;
        this.age = age;
        this.sex = sex;
        this.email = email;
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    public String getSex() {
        return sex;
    }

    public void setSex(String sex) {
        this.sex = sex;
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }

    @Override
    public String toString() {
        return "com.lotus.mybatis.pojo.User{" +
                "id=" + id +
                ", username='" + username + '\'' +
                ", password='" + password + '\'' +
                ", age=" + age +
                ", sex='" + sex + '\'' +
                ", email='" + email + '\'' +
                '}';
    }
}

//SqlSession获取封装功能类
public class SqlSessionUtils {
    public static SqlSession getSqlSession() {
        SqlSession sqlSession = null;
        try {
            SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
            InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
            SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(is);
            sqlSession = sqlSessionFactory.openSession(true);
        } catch (IOException e) {
            e.printStackTrace();
        }
        return sqlSession;
    }
}
单个字面量类型的参数
  • 若mapper接口中的方法参数为单个字面量类型,可以使用KaTeX parse error: Expected 'EOF', got '#' at position 4: {}或#̲{}以任意名称获取参数的值,*…{}手动加单引号**
public interface ParameterMapper {
    /**
     * 根据用户名查询用户信息
     */
    User getUserByUsername(String username);
}
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.lotus.mybatis.mapper.ParameterMapper">
    <!-- getUserByUsername -->
    <select id="getUserByUsername" resultType="com.lotus.mybatis.pojo.User">
        <!-- select * from t_user where username=#{username} -->
        select * from t_user where username='${username}'
    </select>
</mapper>
@Test
    public void testGetUserByUsername() throws IOException {
        SqlSession sqlSession = SqlSessionUtils.getSqlSession();
        ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
        User user = mapper.getUserByUsername("dizzy");
        System.out.println(user);
    }
多个字面量类型的参数
  • 若mapper接口中的方法参数为多个时,MyBatis自动将这些参数放在一个Map集合中,以arg0,arg1…为键,以参数为值,以param1,param2…为键,以参数为值,只需要通过KaTeX parse error: Expected 'EOF', got '#' at position 4: {}或#̲{}访问map集合的键就可以获…{}需手动加单引号**
public interface ParameterMapper {
    /**
     * 验证登录
     */
    User checkLogin(String username,String password);
}
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.lotus.mybatis.mapper.ParameterMapper">
    <!-- checkLogin -->
    <select id="checkLogin" resultType="User">
        <!-- arg0 | param1表示username,arg1|param2表示password -->
        <!--select * from t_user where username=#{arg0} and password=#{param2}-->
        select * from t_user where username='${arg0}' and password='${param2}'
    </select>
</mapper>
 @Test
    public void testCheckLogin() throws IOException {
        SqlSession sqlSession = SqlSessionUtils.getSqlSession();
        ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
        User user = mapper.checkLogin("dizzy","12345");
        System.out.println(user);
    }
map集合类型的参数
  • 若mapper接口中的方法参数为多个时,可手动创建map集合,将这些数据放在map中,只需通过KaTeX parse error: Expected 'EOF', got '#' at position 4: {}或#̲{}访问map集合的键就可以获…{}需手动加单引号**
/**
     * 验证登录(参数为map)
     */
    User checkLoginByMap(Map<String,Object> map);
<!-- User checkLoginByMap(Map<String,Object> map);-->
    <select id="checkLoginByMap" resultType="User">
        select * from t_user where username='${username}' and password='${password}'
    </select>
@Test
    public void testCheckLoginByMap() throws IOException {
        SqlSession sqlSession = SqlSessionUtils.getSqlSession();
        ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
        Map<String,Object> map = new HashMap<>();
        map.put("arg0","dizzy");
        map.put("arg1","12345");
        map.put("param1","dizzy");
        map.put("param2","12345");
        map.put("username","dizzy");
        map.put("password","12345");
        User user = mapper.checkLoginByMap(map);
        System.out.println(user);
    }
实体类类型的参数(重点)
  • 若mapper接口中的方法参数为实体类时,只需通过KaTeX parse error: Expected 'EOF', got '#' at position 4: {}或#̲{}访问实体类属性值的方式就可…{}需手动加单引号**
/**
     * 添加用户信息
     */
    int insertUser(User user);
<!--int insertUser(User user);-->
    <insert id="insertUser">
        insert into t_user values(null,#{username},#{password},#{age},#{sex},#{email})
    </insert>
 @Test
    public void testInsertUser() throws IOException {
        SqlSession sqlSession = SqlSessionUtils.getSqlSession();
        ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
        int res = mapper.insertUser(new User(null,"water","123456",11,"男","water@qq.com"));
        System.out.println(res);
    }
使用注解@param命名参数(重点)
  • 若mapper接口中的方法参数使用@param修饰,MyBatis自动将这些参数放在一个Map集合中,以@param注解的值为键,以参数为值,以param1,param2…为键,以参数为值,只需要通过KaTeX parse error: Expected 'EOF', got '#' at position 4: {}或#̲{}访问map集合的键就可以获…{}需手动加单引号**
 /**
     * 验证登录(使用@param)
     */
    User checkLoginByParam(@Param("username") String username, @Param("password") String password);
<!--User checkLoginByParam(@Param("username") String username, @Param("password") String password);-->
    <select id="checkLoginByParam" resultType="User">
        select * from t_user where username=#{username} and password=#{password}
    </select>
 @Test
    public void testCheckLoginByParam() throws IOException {
        SqlSession sqlSession = SqlSessionUtils.getSqlSession();
        ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
        User user = mapper.checkLoginByParam("water","123456");
        System.out.println(user);
    }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1814826.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【稳定检索/投稿优惠】2024年心理健康与社会科学国际会议(MHSS 2024)

2024 International Conference on Mental Health and Social Sciences 2024年心理健康与社会科学国际会议 【会议信息】 会议简称&#xff1a;MHSS 2024截稿时间&#xff1a;点击查看大会地点&#xff1a;中国三亚会议官网&#xff1a;www.icmhss.com会议邮箱&#xff1a;mhs…

怎么只读USB存储设备?教你两种方法

电脑的USB可以帮助我们连接各种设备&#xff0c;比如移动存储设备。而只读USB则可以保护电脑数据和移动存储设备中的设备。那么&#xff0c;怎么只读USB存储设备&#xff1f;下面我们就一起来了解一下吧。 USB设备只读加密 USB设备只读加密可以在不影响移动存储设备正常使用的…

和数集团最新人事任命通知

根据集团战略发展规划&#xff0c;为进一步拓展业务领域&#xff0c;优化组织架构&#xff0c;完善客户服务&#xff0c;经公司研究决定&#xff0c;现对以下人事进行任命&#xff1a; 任命徐敬东为和数研究院院长 任命李晓峰为常务副总经理 任命陈善明为市场总监 任命窦晓…

深入理解Python多进程

目录 一、引言 二、Python多进程基础 进程与线程的区别 Python多进程模块 三、Python多进程实现原理 进程创建 进程间通信 进程同步 四、Python多进程使用方法 创建进程 进程间通信 五、实战案例 六、总结 一、引言 在Python编程中&#xff0c;多进程是一种重…

C脚本实现用键盘按键控制Wincc某按钮动作

文章目录 前言一、创建Wincc画面并添加变量及按钮二、在“事件”-“键盘”下&#xff0c;编写“按下”和“释放”的C脚本 前言 在某些特定场景下&#xff0c;需要通过电脑键盘控制上位机界面上按钮按下或释放&#xff0c;本文给出了基于C脚本的解决方案。 一、创建Wincc画面并…

commit过大文件,导致push失败如何解决

1、查看过大文件是谁 2、使用该命令删除过大文件 git filter-branch --force --index-filter git rm -rf --cached --ignore-unmatch 文件名 --prune-empty --tag-name-filter cat -- --all 例如&#xff1a; git filter-branch --force --index-filter git rm -rf --cached --…

PlugLink:让数据分析与工作流无缝连接(附源码)

PlugLink&#xff1a;让数据分析与工作流无缝连接 引言 数据分析和自动化工作流已成为各个企业和个人提高效率的关键手段。今天&#xff0c;我要介绍一款名为PlugLink的工具&#xff0c;它不仅能帮助你轻松进行数据分析&#xff0c;还能将这些分析结果无缝连接到你的工作流中&…

洛谷 P4913 二叉树深度(递归)

题目描述 有一个 &#x1d45b;(&#x1d45b;≤10^6) 个结点的二叉树。给出每个结点的两个子结点编号&#xff08;均不超过 &#x1d45b;&#xff09;&#xff0c;建立一棵二叉树&#xff08;根节点的编号为 1&#xff09;&#xff0c;如果是叶子结点&#xff0c;则输入 0。…

【大模型应用开发极简入门】提示工程二:零样本学习、少样本学习与改善提示效果

文章目录 一. 逐步思考&#xff1a;零样本思维链1. 数学计算推理2. 注意有效的方面 二. 少样本学习1. 基于提示词示例的学习2. 单样本学习 三. 改善提示效果1.指示模型提出更多问题2.格式化输出3.重复指示4.使用负面提示5. 添加长度限制 一. 逐步思考&#xff1a;零样本思维链 …

AI大模型的战场:通用大模型与垂直大模型的对决

引言 随着人工智能技术的不断进步&#xff0c;AI大模型在各个领域的应用也日益广泛。如今&#xff0c;AI大模型的战场正在分化&#xff0c;主要分为通用大模型和垂直大模型两个方向。通用大模型由于其适用范围广泛&#xff0c;在落地场景中占据了较大的优势。而垂直大模型则凭…

python3的基本语法说明三

一. 简介 前面几篇文章简单学习了 python3的基本语法&#xff0c;文章如下&#xff1a; python3的基本语法说明一-CSDN博客 python3的基本语法说明二-CSDN博客 本文继续学习 python3的基本语法。 二. python3 的基本语法 1. 等待用户输入 执行下面的程序在按回车键后就会…

就业班 第四阶段(k8s) 2401--6.11 day5 CICD实践+VPN+LDAP域管理+还有一些云产品

CICD项目实践&#xff08;扩展&#xff09; RBAC 角色&#xff1a;role 用户&#xff1a;user 角色绑定&#xff1a;rolebinding 需要自己指定好名称空间&#xff0c;只对某个名称空间有权限 集群角色&#xff1a;clusterrole 集群角色绑定&#xff1a;clusterrolebindin…

[初阶数据结构] 包装类 | 泛型

目录 一. 包装类 1.1 什么是包装类? 1.2 包装类的意义 1.3 基本数据类型与包装类 1.4 装箱 1.5 拆箱 1.6 小总结 二. 泛型 2.1 什么是泛型? 2.2 泛型的意义 2.3 泛型的语法 2.4 泛型的编译 2.4.1 下载插件 2.4.2 分析 2.5 上界 2.6 泛型方法 2.7 小总结 三. 总结 一.…

element-ui将组件默认语言改为中文

在main.js中加入以下代码即可 // 引入 Element Plus 及其样式 import ElementPlus from element-plus import element-plus/dist/index.css// 引入中文语言包 import zhCn from element-plus/es/locale/lang/zh-cn// 使用 Element Plus 并设置语言为中文 app.use(ElementPlus,…

乐鑫ESP32系列SOC技术让设备控制更简单,HMI智能屏方案应用

随着科技的飞速发展&#xff0c;我们的生活方式正在被重新定义。在智能家居领域&#xff0c;人机交互的便捷性和直观性一直是创新的焦点&#xff0c;如今正逐渐成为现实。 乐鑫以其先进的SoC技术&#xff0c;为智能家居行业带来了新的HMI智能屏方案。这一方案不仅集成了高性能…

商用OLED柔性屏,有42、48、55、65和77寸

商用OLED柔性屏在市场上的尺寸选择相对丰富&#xff0c;以下是针对您提到的42、48、55、65和77寸的具体信息&#xff1a; 42寸OLED柔性屏 目前市场上已有42寸的OLED柔性屏产品&#xff0c;如LG的42英寸电视柔性屏OLED&#xff0c;具有可曲直的特性&#xff0c;支持120Hz高刷新…

LogicFlow 学习笔记——1. 初步使用 LogicFlow

什么是 LogicFlow LogicFlow 是一个开源的前端流程图编辑器和工作流引擎&#xff0c;旨在帮助开发者和业务人员在网页端创建、编辑和管理复杂的业务流程和工作流。它提供了一个直观的界面和强大的功能&#xff0c;使得设计和管理工作流变得更加高效和便捷。 官网地址&#xff…

芯品荟 | 会议系统屏驱案例分享

一、产品简介 智能会议系统是一种对声、光、电等各种设备进行集中控制的设备。其可实现对会议过程进行签到、表决、多国语言翻译、现场摄像视像跟踪功能&#xff0c;并对进程中处以发言管理&#xff0c;达到人性化高科技水平&#xff0c;使会议可一键掌控。 系统要做到可方便快…

profiling模型性能分析与优化入门

一、定义 profiler 作用入门pyproftorch.summary/torchinfo 模型参数量分析以及模型可视化profiling 参数分析-模型分析 二、实现 1.profiler 作用&#xff1a;分析模型执行时间,内存占用 CPU/GPU 端Op执行时间统计 CPU/GPU 端Op输入Tensor的维度分析 Op的内存消耗统计 2. 入…

3D开发工具HOOPS如何推动3D打印应用实现数据格式转换、模型可视化?

3D打印技术的发展已经彻底改变了制造业、医疗、建筑和设计等众多领域。这一技术的核心在于其能够将数字模型转化为实物&#xff0c;而这一过程需要强大的软件支持。在这一领域&#xff0c;HOOPS作为一种专业的图形软件开发工具&#xff0c;发挥着至关重要的作用。 本文将深入探…