目录

创建工程

普通的java web工程即可,我采用的是spring mvc!

@Autowired
private SolrServer solrServer; @Override
public void addInterForProduct() throws Exception
{
// 构造一篇文档
SolrInputDocument document = new SolrInputDocument();
//往doc中添加字段,在客户端这边添加的字段必须在服务端的配置文件中有定义
document.addField("id", "num002");
document.addField("title_ik", "113333");
document.addField("content_ik", "11"); solrServer.add(document);
UpdateResponse response = solrServer.commit();
System.out.println("---UpdateResponse-"+response);
}

请求后,返回值为

---UpdateResponse-{responseHeader={status=0,QTime=288}}

status = 0 为成功!失败的情况还没测出来,不知道返回值是什么。知道的童鞋,请告知。

用solr界面查询一下,新增加的已经填入索引库!

{
"responseHeader": {
"status": 0,
"QTime": 2,
"params": {
"q": "id:num002",
"indent": "true",
"wt": "json",
"_": "1457489330978"
}
},
"response": {
"numFound": 1,
"start": 0,
"docs": [
{
"id": "num002",
"title_ik": "113333",
"content_ik": [
"11"
],
"_version_": 1528288311726047200
}
]
}
}

    @Override
public void deleteInterForProduct() throws Exception {
// 删除id域中有num002关键字的文档
solrServer.deleteByQuery("id:num002"); // 删除solr服务端索引库中所有的文档
//solrServer.deleteByQuery("*:*"); UpdateResponse response =solrServer.commit();
System.out.println("---deleteInterForProduct-"+response);
}

删除了id=num002的文档,可以删除库中的所有文档。

返回值

---deleteInterForProduct-{responseHeader={status=0,QTime=54}}

再次查询websolr,结果已经不存在了。

所谓solr的更新操作,就是就是对相同id的文档重新添加一次。

        SolrQuery query = new SolrQuery();

        // 给query设置一个主查询条件:关键词
query.set("q", "id:num001"); QueryResponse response = solrClient.query(query); SolrDocumentList docs = response.getResults(); long numFound = docs.getNumFound(); System.out.println("总共查询到的文档数量: " + numFound); for (SolrDocument doc : docs) { System.out.println(doc.get("id"));
System.out.println(doc.get("title_ik"));
System.out.println(doc.get("content_ik")); }

高量查询

SolrQuery query = new SolrQuery();

        // 给query设置一个主查询条件:关键词
query.set("q", "台灯"); // 给query增加范围过滤查询条件
// query.addFilterQuery("product_price:[0 TO 200]"); // 给query增加布尔过滤条件
// query.addFilterQuery("-product_name:台灯"); /**
* 这一句等价于上面两句过滤条件设置
*/
// query.set("fq", "product_price:[0 TO 200] -product_name:台灯"); // 给query设置默认搜索域
query.set("df", "product_keywords"); // 设置返回结果的排序规则
query.setSort("product_price", ORDER.desc); // 设置分页参数
query.setStart(0);
query.setRows(20); QueryResponse response = solrClient.query(query); SolrDocumentList docs = response.getResults(); long numFound = docs.getNumFound(); System.out.println("总共查询到的文档数量: " + numFound); for (SolrDocument doc : docs) { System.out.println(doc.get("id"));
System.out.println(doc.get("product_price"));
System.out.println(doc.get("product_name"));
System.out.println(doc.get("product_catalog_name")); }

【Solr】solr的增删改查的更多相关文章

  1. 一个Solr搜索实例,增删改查+高亮+分页

    今天个人coding的模块测试,所以闲暇之余继续研究solr,然后顺带写了一个实例,随便搞的,solr真心不熟,期待认识热爱搜索的朋友,共同进步. 1.配置schema.xml文件[solr\coll ...

  2. 自己写的一个Solr搜索实例,增删改查+高亮+分页

    今天个人coding的模块测试,所以闲暇之余继续研究solr,然后顺带写了一个实例,随便搞的,solr真心不熟,期待认识热爱搜索的朋友,共同进步. 1.配置schema.xml文件[solr\coll ...

  3. Java solr 索引数据增删改查

    具体代码如下: import java.io.IOException; import java.util.*; import org.apache.solr.client.solrj.SolrClie ...

  4. 【ES】ElasticSearch初体验之使用Java进行最基本的增删改查~

    好久没写博文了, 最近项目中使用到了ElaticSearch相关的一些内容, 刚好自己也来做个总结. 现在自己也只能算得上入门, 总结下自己在工作中使用Java操作ES的一些小经验吧. 本文总共分为三 ...

  5. Dapper逆天入门~强类型,动态类型,多映射,多返回值,增删改查+存储过程+事物案例演示

    Dapper的牛逼就不扯蛋了,答应群友做个入门Demo的,现有园友需要,那么公开分享一下: 完整Demo:http://pan.baidu.com/s/1i3TcEzj 注 意 事 项:http:// ...

  6. ASP.NET从零开始学习EF的增删改查

           ASP.NET从零开始学习EF的增删改查           最近辞职了,但是离真正的离职还有一段时间,趁着这段空档期,总想着写些东西,想来想去,也不是很明确到底想写个啥,但是闲着也是够 ...

  7. 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(9)-MVC与EasyUI结合增删改查

    系列目录 文章于2016-12-17日重写 在第八讲中,我们已经做到了怎么样分页.这一讲主要讲增删改查.第六讲的代码已经给出,里面包含了增删改,大家可以下载下来看下. 这讲主要是,制作漂亮的工具栏,虽 ...

  8. 通过Java代码实现对数据库的数据进行操作:增删改查

    在写代码之前,依然是引用mysql数据库的jar包文件:右键项目-构建路径-设置构建路径-库-添加外部JAR 在数据库中我们已经建立好一个表xs :分别有xuehao  xingming    xue ...

  9. Hibernate全套增删改查+分页

    1.创建一个web工程 2.导入jar包 3.创建Student表 4.创建实体类 package com.entity; public class Student { private Integer ...

  10. 使用 Json.Net 对Json文本进行 增删改查

    JSON 已经成为当前主流交互格式, 如何在C#中使用 Json.Net 对Json文本进行 增删改查呢?见如下代码 #region Create (从零创建) public static strin ...

随机推荐

  1. JSP_通过表格显示数据库的信息

    在本篇文章中,小编将介绍在jsp页面中通过表格显示数据库的实现:下面我们以“新闻发布系统”中显示一级标题的信息为例进行讲述,在新闻发布系统中存在一二级标题,在后台可以对标题进行管理,可查询标题等信息 ...

  2. poj3502 恶心题

    巨恶心的一个题::>_<:: 题意:给出航班航线和大陆,找航线上距离大陆最远的某一点距离大陆边缘的距离 标准算法:二分答案,从大陆边界向外扩展,扩展出来的面积会覆盖航线.找出航线上最后被覆 ...

  3. Bzoj2683 简单题

    Time Limit: 50 Sec  Memory Limit: 128 MBSubmit: 1071  Solved: 428 Description 你有一个N*N的棋盘,每个格子内有一个整数, ...

  4. MVC5-7 ValueProvider

    统一的数据获取 在WebForm时代,我们是怎么获取值的呢? HttpContext.Request.QueryString HttpContext.Request.Form HttpContext. ...

  5. 【Alpha版本】冲刺-Day2

    队伍:606notconnected 会议时间:11月10日 会议总结 张斯巍(433) 今天安排:把昨天没完成的做好,主界面图标的修改,侧边栏背景设计 完成度:85% 明天计划:个人信息界面设计.优 ...

  6. css属性设置

    css在线编辑工具地址:http://tool.chinaz.com/Tools/CssDesigner.aspx 案例详情: http://dongtianee.sinaapp.com/index. ...

  7. SQL Server编程(01)流程控制

    批处理 应用程序向SqlServer发送的一组命令,Sql Server会将其编译成一个可执行单元,称为执行计划,执行计划中的语句每次执行一条. 每个不同的批处理用GO命令分割.GO命令不是SQL语句 ...

  8. 转:在VS2010下编译、调试和生成mex文件

    最近帮人调了一个程序,是网上公开的代码,利用matlab与c++混合编程做三维模型关键点检测,发现他们可以用VS2010编译.调试.生成mexw32文件,因此觉得之前在Matlab上利用mex命令真是 ...

  9. 最近在 OS-10.9下配置opencv, cgal, latex, qt, pillow

    其实我之前使用的Mac os的版本是10.8的雪豹,可是最近想体验一下Mac os10.9新版本,于是就开始更新Mac os,经过10多个小时的下载和成功安装后,发现之前的配置全乱了,首先是发现lat ...

  10. 9-slice-scaling

    9-slice-scaling http://rwillustrator.blogspot.com/2007/04/understanding-9-slice-scaling.html