记不清是从哪里的结论,一直以来印象里CLOB字段是不支持like关键字查询的(至少Oracle等部分数据库不支持),网上也能搜到一堆说是需要进行函数转换后才可以进行like的帖子、文章,今天实际测试验证SQL Server、Oracle、PgSQL、MySQL、DB2、DM、KingBase、Oscar,均支持like操作。估计是CLOB字段不支持创建索引,结果被误传了,真是害人不浅。
另外,DM有个长度限制,如果超出会报:“报字符串截断”的错误。不过,DM也提供了CLOB_LIKE_MAX_LEN 参数,可以自定义配置“限制 LIKE 语句中CLOB类型的最大长度(单位KB)”,有效值范围(8~102400)默认值为31K(DM8中默认值为10240)。
查询及设置参数值的命令:
select para_name,para_value from v$dm_ini where para_name ='CLOB_LIKE_MAX_LEN';
sp_set_para_value(2, 'CLOB_LIKE_MAX_LEN', 10240);
需要注意:CLOB_LIKE_MAX_LEN属于静态参数,需重启数据库使参数生效。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?