Mybatis动态SQL环境及常用标签

Mybatis动态SQL环境及常用标签,第1张

Mybatis动态SQL环境及常用标签

动态SQL

动态SQL概述和环境搭建

编写一个基础工程编写辅助工具测试数据插入根据传入参数查询博客 解决if标签问题

解决方案1解决方案2 测试相关 *** 作

更新博客数据导入sql片段测试foreach标签

动态SQL概述和环境搭建

什么是动态SQL:就是根据不同的条件生成不同的SQL语句,例如拼接SQL

编写一个基础工程

导包导依赖编写配置文件编写实体类编写实体类对应的Mapper接口和xml文件 编写辅助工具

开启驼峰命名转换




    
    

    
        
        
    

    
        
    
    
        
            
            
                
                
                
                
            
        
    
    
        
    

编写id随机生成工具类

package com.bkms.utils;

import java.util.UUID;


public class IdUtils {
    public static String getRandomId() {
        return UUID.randomUUID().toString().replaceAll("-","");
    }
}
测试数据插入



    
    
        insert into mydb.blog (id,title,author,create_time,views)
        values (#{id},#{title},#{author},#{createTime},#{views});
    

    @Test
    // 测试插入数据
    public void incrementBlogTest() {
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        BlogMapper mapper = sqlSession.getMapper(BlogMapper.class);
        Blog blog = new Blog();

        blog.setId(IdUtils.getRandomId());
        blog.setTitle("Mybatis");
        blog.setAuthor("Philip");
        blog.setCreateTime(new Date());
        blog.setViews(9999);

        mapper.incrementBlog(blog);

        blog.setId(IdUtils.getRandomId());
        blog.setTitle("Java");
        mapper.incrementBlog(blog);

        blog.setId(IdUtils.getRandomId());
        blog.setTitle("Spring");
        mapper.incrementBlog(blog);

        blog.setId(IdUtils.getRandomId());
        blog.setTitle("微服务");
        mapper.incrementBlog(blog);

        sqlSession.commit();
        sqlSession.close();
    }
根据传入参数查询博客
    @Test
    // 测试博客查询
    public void searchBlogIfTest() {
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        BlogMapper mapper = sqlSession.getMapper(BlogMapper.class);
        HashMap map = new HashMap();
        map.put("title","Spring");
        List blogs = mapper.searchBlogIf(map);
        for (Blog blog : blogs) {
            System.out.println(blog);
        }
        sqlSession.close();
    }
    
    
        select * from mydb.blog
        
            
                title = #{title}
            
            
                and name = #{name}
            
        
    
解决方案2
    
    
        select * from mydb.blog
        
            
        
    

sql片段使用注意事项

最好基于单表定义sql字段,不要封装太过复杂的 *** 作不要存在where标签 测试foreach标签

	
    
    

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5717680.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-17
下一篇 2022-12-17

发表评论

登录后才能评论

评论列表(0条)

保存