Sqlserver 模糊查询中文及在mybatis xml【非中文不匹配查询】N@P2问题

问题

sqlserver模糊查询或相等,两者都无法查询。

百度方案解释

Like 后的N是表示unicode字符。获取SQL Server数据库中Unicode类型的数据时,字符串常量必须以大写字母 N 开头,否则字符串将转换为数据库的默认代码页(字符集编码),这可能导致字符串内容发生变化,无法识别。

在SQL界面中

sql 复制代码
select * from table where column like N'%文档%'

但是在mybatis这样就不好写了。

注意点

一定不要使用mybatis的where标签,否则mybatis会识别为N@P2
N后面必须用 '' + #{queryColumn} 这种格式

模糊查询

sql 复制代码
select * from table where 
<if test="queryColumn != null and queryColumn != ''">
	column like N'%'+#{queryColumn}+'%'
</if>

相等查询

结合上面,我们发现N后面不能直接拼接#{queryColumn}参数,否则就会报错!

sql 复制代码
select * from table where 
<if test="queryColumn != null and queryColumn != ''">
	column = N''+#{queryColumn}
</if>
相关推荐
tb_first8 小时前
SSM速通3
java·jvm·spring boot·mybatis
woshilys9 小时前
sql server 索引选择
数据库·sqlserver
tb_first10 小时前
SSM速通4
java·jvm·spring·tomcat·maven·mybatis
程可爱10 小时前
springboot整合mybatis和postgresql
spring boot·postgresql·mybatis
risc12345611 小时前
【Elasticsearch】LeafDocLookup 详述
大数据·elasticsearch·mybatis
松涛和鸣12 小时前
DAY67 IMX6 Development Board Configuration from Scratch
数据库·postgresql·sqlserver
李少兄15 小时前
解决 org.springframework.context.annotation.ConflictingBeanDefinitionException 报错
java·spring boot·mybatis
一只大袋鼠15 小时前
分布式 ID 生成:雪花算法原理、实现与 MyBatis-Plus 实战
分布式·算法·mybatis
码农小卡拉16 小时前
MyBatis-Flex 全面解析与实战教程:轻量高效的 MyBatis 增强方案
java·mybatis
弓弧名家_玄真君17 小时前
在ubuntu中安装redis
前端·bootstrap·mybatis