zoukankan      html  css  js  c++  java
  • solr的增删改查

    solr的配置请查看:http://www.cnblogs.com/byteworld/p/5898651.html

    创建Core:(可以复制模版到solrhome estconf文件夹中)

    简化了(schema.xml配置文件)

    <?xml version="1.0" encoding="UTF-8" ?>
    <schema name="test_solr" version="1.5"> 
        <!--版本这个也需要加-->
        <field name="_version_" type="long" indexed="true" stored="true"/>
        <field name="_root_" type="string" indexed="true" stored="false"/>
    	<field name="id" type="string" stored="true" indexed="true"/>
    	<field name="name" type="string" stored="true" indexed="true" omitNorms="false"/>
    	<field name="price" type="string" stored="true" indexed="true"/>  
    	<fieldType name="string" class="solr.StrField" sortMissingLast="true" />
    	<!-- 这个主键必须加不然报错 -->
    	<uniqueKey>id</uniqueKey>
        <!-- boolean type: "true" or "false" -->
        <fieldType name="boolean" class="solr.BoolField" sortMissingLast="true"/>   
        <fieldType name="int" class="solr.TrieIntField" precisionStep="0" positionIncrementGap="0"/>
        <fieldType name="float" class="solr.TrieFloatField" precisionStep="0" positionIncrementGap="0"/>
        <fieldType name="long" class="solr.TrieLongField" precisionStep="0" positionIncrementGap="0"/>
        <fieldType name="double" class="solr.TrieDoubleField" precisionStep="0" positionIncrementGap="0"/>
    </schema>
    

     java代码:

    jar包下载:链接: http://pan.baidu.com/s/1kUIRWRt 密码: xvtu

    package demo;
    
    import java.io.IOException;
    import java.util.ArrayList;
    
    import org.apache.solr.client.solrj.SolrServerException;
    import org.apache.solr.client.solrj.impl.HttpSolrClient;
    import org.apache.solr.client.solrj.impl.HttpSolrServer;
    import org.apache.solr.common.SolrInputDocument;
    
    /**
     * @Description:solr添加
     * @author byte-zbs 
     * @date 2016年12月19日 下午2:28:33
     */
    public class AddDemo
    {
        public static final String SOLR_URL = "http://localhost:8090/solr/test_solr";
        public static void main(String[] args)
        {
            addDoc();
        }
        
        public static void addDoc()
        {
            String[] words = {"Document是Solr索引(动词,indexing)和搜索的最基本单元","它类似于关系数据库表中的一条记录","可以包含一个或多个字段(Field","每个字段包含一个name和文本值","字段在被索引的同时可以存储在索引中","搜索时就能返回该字段的值"};
            
            long start = System.currentTimeMillis();
            ArrayList<SolrInputDocument> docs = new ArrayList<SolrInputDocument>();
            for(int i = 0;i < 300; i++)
            {
                SolrInputDocument input = new SolrInputDocument();
                
                input.addField("id", "id"+i,1.0f);
                input.addField("name",words[i % 21], 1.0f);
                input.addField("price",10*i);
                docs.add(input);
            }
            @SuppressWarnings("resource")
            HttpSolrClient client = new HttpSolrClient(SOLR_URL);
            try
            {
                client.add(docs.iterator());
            }
            catch (SolrServerException e)
            {
                e.printStackTrace();
            }
            catch (IOException e)
            {
                e.printStackTrace();
            }
            System.out.println(System.currentTimeMillis() - start);
        }
    }
    

      

    /**
         * @Description:查询
         * @param   
         * @return void 返回类型
         */
        public static void query()
        {
            HttpSolrClient client = new HttpSolrClient(SOLR_URL);
            client.setMaxRetries(1);
            client.setConnectionTimeout(60*1000);
            client.setSoTimeout(60*1000);
            client.setDefaultMaxConnectionsPerHost(100);
            client.setMaxTotalConnections(1000);
            client.setFollowRedirects(false);
            client.setAllowCompression(true);
            client.setRequestWriter(new BinaryRequestWriter());
            SolrQuery query = new SolrQuery();
            query.setQuery("id:id*");
            query.setFields("name","id","price");
            query.setSort("price", ORDER.asc);
            query.setStart(0);
            query.setRows(20);
            try
            {
                QueryResponse res = client.query(query);
                SolrDocumentList DocumentList = res.getResults();
                for (SolrDocument document:DocumentList)
                {
                    String value = document.getFieldValue("id").toString();
                    String price = document.getFieldValue("price").toString();
                    System.out.println(value + "====" +price);
                }
                
                
                
            }
            catch (SolrServerException e)
            {
                e.printStackTrace();
            }
            catch (IOException e)
            {
                e.printStackTrace();
            }
        }
        /**
         * @Description:集合插入对象
         * @param   
         * @return void 返回类型
         */
        public static void pojoDocAll()
        {
            Goods good1 = new Goods("pojo_commit1", "苹果", 12.0);
            Goods good2 = new Goods("pojo_commit2", "橘子", 12.0);
            Goods good3 = new Goods("pojo_commit3", "香蕉", 12.0);
            ArrayList<Goods> list = new ArrayList<Goods>();
            list.add(good1);
            list.add(good2);
            list.add(good3);
            HttpSolrClient client = new HttpSolrClient(SOLR_URL);
            try
            {
                client.addBeans(list);
                client.commit();
            }
            catch (SolrServerException e)
            {
                e.printStackTrace();
            }
            catch (IOException e)
            {
                e.printStackTrace();
            }
        }
        
        /**
         * @Description:插入对象
         * @param   
         * @return void 返回类型
         */
        public static void pojoDoc()
        {
            Goods good = new Goods("pojo_commit", "苹果", 12.0);
            HttpSolrClient Client = new HttpSolrClient(SOLR_URL);
            Client.setRequestWriter(new RequestWriter());
            try
            {
                Client.addBean(good);
                //Client.optimize();
                Client.commit();
            }
            catch (IOException e)
            {
                e.printStackTrace();
            }
            catch (SolrServerException e)
            {
                e.printStackTrace();
            }
        }
        
        
        
        
        
        /**
         * @Description:删除文档
         * @param   
         * @return void 返回类型
         */
        public static void delDoc()
        {
            HttpSolrClient client = new HttpSolrClient(SOLR_URL);
            try
            {
                client.deleteById("id_update");
                client.commit();
            }
            catch (SolrServerException e)
            {
                e.printStackTrace();
            }
            catch (IOException e)
            {
                e.printStackTrace();
            }
            
        }
        
        
        
        
        /**
         * @Description:添加的第一种方式
         * @param   
         * @return void 返回类型
         */
        public static void addone()
        {
            SolrInputDocument doc = new SolrInputDocument();
            doc.addField("id", "id_double");
            doc.addField("name", "呵呵呵呵");
            doc.addField("price", 100.0);
            HttpSolrClient client = new HttpSolrClient(SOLR_URL);
            try
            {
                client.add(doc);
                client.commit();
            }
            catch (SolrServerException e)
            {
                e.printStackTrace();
            }
            catch (IOException e)
            {
                e.printStackTrace();
            }
            
            
        }
        
        /**
         * @Description:添加第二种方式
         * @param   
         * @return void 返回类型
         */
        public static void addoneOther()
        {
            SolrInputDocument doc = new SolrInputDocument();
            doc.addField("id", "id_update");
            doc.addField("name", "来个测试");
            doc.addField("price", 100.0);
            
            UpdateRequest request = new UpdateRequest();
            
            request.setAction(ACTION.COMMIT,false, false);
            request.add(doc);
            HttpSolrClient client = new HttpSolrClient(SOLR_URL);
            
            
            try
            {
                UpdateResponse resp = request.process(client);
                System.out.println(resp);
            }
            catch (SolrServerException e)
            {
                e.printStackTrace();
            }
            catch (IOException e)
            {
                e.printStackTrace();
            }
            
            
        }
    package demo.dao;
    import org.apache.solr.client.solrj.beans.Field;
    
    public class Goods
    {
        @Field
        private String id;
        @Field(value = "name")
        private String goodsname;
        @Field
        private double price;
        public Goods(String id, String name, double price)
        {
            super();
            this.id = id;
            this.goodsname = name;
            this.price = price;
        }
        public String getId()
        {
            return id;
        }
        public void setId(String id)
        {
            this.id = id;
        }
        public String getName()
        {
            return goodsname;
        }
        public void setName(String name)
        {
            this.goodsname = name;
        }
        public double getPrice()
        {
            return price;
        }
        public void setPrice(double price)
        {
            this.price = price;
        }
        
    }

    项目完整:链接: http://pan.baidu.com/s/1pLq9Kdt 密码: f558

     

  • 相关阅读:
    Android仿qq聊天记录长按删除功能效果
    charles工具抓包教程(http跟https)
    瀑布流StaggeredGridView 下拉刷新
    Android微信分享图片大于32k进行压缩
    Android使用TextureView播放视频
    ViewPager+RadioGroup实现标题栏切换,Fragment切换
    android:theme决定AlertDialog的背景颜色
    实现本地音乐选择,播放,带可拖动进度条
    android图片透明度跟缩放大小动画事件
    Android中实现双击事件
  • 原文地址:https://www.cnblogs.com/byteworld/p/6198426.html
Copyright © 2011-2022 走看看