在项目中要对数据表的Clob字段进行检索,用于Clob是采用字节方式存储的,因此普通的查询语句不能检索Clob字段内的内容,使用SELECT * FROM 表名 WHERE dbms_lob.instr(表名.Clob字段名,'内容',1,1) > 0; 或 SELECT * FROM 表名 别名 WHERE dbms_lob.instr(别名.Clob字段名, '内容', 1, 1) > 0;语句可以检索Clob内的内容,使用Spring的HibernateTemplate执行上述语句的例子如下:所采用的数据表: Sql代码 drop table csms_ps_genericContent; create table csms_ps_genericContent ( id char(32) not null, --ID categoryId varchar2(60) not null, --类别ID featureId varchar2(60) null, --专题ID title varchar2(150) not null, --标题 titlePicPath varchar2(500) null, --标题图片路径 publishTime date not null, --发布时间 content clob not null, --内容 keyword varchar2(255) null, --关键字 isChar char(1) default '1', --是否是文字内容 primary key (id) ); drop table csms_ps_genericContent; create table csms_ps_genericContent ( id char(32) not null, --ID categoryId varchar2(60) not null, --类别ID featureId varchar2(60) null, --专题ID title varchar2(150) not null, --标题 titlePicPath varchar2(500) null, --标题图片路径 publishTime date not null, --发布时间 content clob not null, --内容 keyword varchar2(255) null, --关键字 isChar char(1) default '1', --是否是文字内容 primary key (id) ); 使用HIbernateTemplate的实现方法是: Java代码 @SuppressWarnings("unchecked") public List fullTextSearch(final String queryContent) throws Exception { final String queryString = "select * from CSMS_PS_GENERICCONTENT gc " + "where dbms_lob.instr(gc.content, :queryContent, 1, 1) > 0 or gc.title like :title"; return (List)super.execute(new HibernateCallback() { public Object doInHibernate(Session session) { SQLQuery query = session.createSQLQuery(queryString); query.addEntity("gc", GenericContentModel.class); query.setString("queryContent", queryContent); query.setString("title", new StringBuffer("%").append(queryContent).append("%").toString()); return query.list(); } }); } @SuppressWarnings("unchecked") public List fullTextSearch(final String queryContent) throws Exception { final String queryString = "select * from CSMS_PS_GENERICCONTENT gc " + "where dbms_lob.instr(gc.content, :queryContent, 1, 1) > 0 or gc.title like :title"; return (List)super.execute(new HibernateCallback() { public Object doInHibernate(Session session) { SQLQuery query = session.createSQLQuery(queryString); query.addEntity("gc", GenericContentModel.class); query.setString("queryContent", queryContent); query.setString("title", new StringBuffer("%").append(queryContent).append("%").toString()); return query.list(); } }); }
使用HibernateTemplate查询Clob内的内容
最新推荐文章于 2023-06-16 18:27:18 发布