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);      }

相关内容

热门资讯

教学黑科技!aapoker a... 教学黑科技!aapoker ai软件(透视)太坑了真的有挂(可靠技巧黑科技介绍);亲,关键说明,aa...
黑科技透明挂!微扑克系统是不是... 黑科技透明挂!微扑克系统是不是有问题(wEpoKe)黑科技辅助机制(总算了解黑科技技巧)1、玩家可以...
ai代打黑科技!微扑克辅助器是... ai代打黑科技!微扑克辅助器是真的吗(透视)太坑了真的是有挂(详细教程黑科技详情)1、超多福利:超高...
黑科技透明挂!wpk到底有没有... 黑科技透明挂!wpk到底有没有辅助(wEpoKe)外挂透视辅助机制(安装程序教程黑科技技巧);wpk...
挂黑科技!红龙扑克记牌器(透视... 挂黑科技!红龙扑克记牌器(透视)太坑了有挂(曝光教程黑科技方法)1、很好的工具软件,可以解锁游戏的红...
黑科技私人局!wepoke是不... 这是一款非常优秀的wepoke是不是有辅助 ia辅助检测软件,能够让你了解到wepoke是不是有辅助...
存在黑科技!德州之星app辅助... 存在黑科技!德州之星app辅助器怎么用(透视)太坑了有挂(介绍教程黑科技细节)1、下载好德州之星ap...
黑科技ai!wepoke辅助挂... 黑科技ai!wepoke辅助挂(Wepoke)外挂黑科技辅助app(分享开挂内幕黑科技软件);致您一...
教程黑科技!wepoker真的... 教程黑科技!wepoker真的有挂吗(透视)太坑了真的有挂(详细教程黑科技介绍)1、这是跨平台的we...
黑科技软件!wpk的发牌有规律... 黑科技软件!wpk的发牌有规律吗(WEPOke)外挂黑科技辅助软件(热点推荐黑科技技巧);wpk的发...