Mybatis(四)特殊SQL的查询:模糊查询、批量删除、动态设置表明、添加功能获取自增的主键
创始人
2024-11-15 15:12:05
0

实体类:

数据库:

1、模糊查询

方案一:

不适用#{ },’%?%‘ 问号是属于字符串的一部分 不会被解析成占位符,会被当作是我们字符串的一部分来解析,所以我们执行的语句中找不到占位符,但是我们却为占位符进行了赋值,所以说就会报错。

我们使用${ } ,将#{}替换成${ }

这个不适用: // select * from t_user where username like '%#{username}%'   select * from t_user where username like '%${username}%'

方案二:

使用字符串拼接的方法

select * from t_user where username like concat('%',#{username},'%')

方案三:

最常用的方式

select * from t_user where username like "%"#{username}"%"

2、批量删除

#{ } 在sql语句中被解析之后本身就会加上一个单引号 ' '

表中的 字符串 日期 字段名 都可以加单引号

不可以使用#{} 需要使用${ }

/** * 批量删除 */     int deleteMore(@Param("ids") String ids);           delete from t_user where id in(${ids})       

3、动态设置表明

使用${ }

#{ } 还是不使适用,会产生 ' '   ,动态设置表名的时候不可以带  '  ' 

List getUserByTableName(@Param("tableName") String tableName);  

4、添加功能获取自增的主键

void insertUser(User user);            insert into t_user values(null,#{username},#{password},#{age},#{sex},#{email})     
//测试代码     @Test     public void testGetUserByLike1(){         SqlSession sqlSession = SqlSessionUtils.getSqlSession();         SQLMapper mapper = sqlSession.getMapper(SQLMapper.class);         User user = new User(null,"asdff","456789",14,"男","asdf.com");         mapper.insertUser(user);      }

相关内容

热门资讯

一分钟了解!陕西三代辅助(辅助... 1、一分钟了解!陕西三代辅助(辅助挂)确实有挂(详细辅助黑科技教程)。2、陕西三代辅助透视辅助简单,...
第二分钟辅助挂!多乐辅助app... 第二分钟辅助挂!多乐辅助app(辅助挂)竟然是有挂(详细辅助科技教程)1、多乐辅助appai辅助优化...
3分钟了解!余干辅助软件哪个好... 3分钟了解!余干辅助软件哪个好(辅助挂)本来真的有挂(详细辅助工具)1、许多玩家不知道余干辅助软件哪...
技术分享"微信欢乐卡... 技术分享"微信欢乐卡五星辅助"微信欢乐卡五星辅助(一贯是有挂);一、微信欢乐卡五星辅助软件透明挂的定...
推荐几款新版!衢州都莱辅助器是... 推荐几款新版!衢州都莱辅助器是真的假的(辅助挂)果然存在有挂(详细辅助攻略教程);1分钟了解详细教程...
黑科技辅助“泸州大二新手攻略”... 黑科技辅助“泸州大二新手攻略”外挂透视辅助神器(切实存在有挂)1、玩家可以在泸州大二新手攻略软件透明...
第6分钟辅助器!樱花之盛低价挂... 第6分钟辅助器!樱花之盛低价挂(辅助挂)果然真的是有挂(详细辅助德州教程);一、樱花之盛低价挂软件透...
十分钟了解!微信大厅辅助软件(... 十分钟了解!微信大厅辅助软件(辅助挂)竟然真的有挂(详细辅助插件)1、不需要AI权限,帮助你快速的进...
一分钟快速了解"荔枝... 一分钟快速了解"荔枝辅助器免费"荔枝辅助器免费(真是有挂);1、全新机制【荔枝辅助器免费软件透明挂】...
分享实测!榕城510k有没有挂... 分享实测!榕城510k有没有挂(辅助挂)一直是真的有挂(详细辅助第三方教程);支持多人共享记分板与复...