一、WEB 控制台界面介绍
http://127.0.0.1:8080/solr/index.html
左边方框中的菜单项选择重要的说明一下:
Dashboard: 首页,显示各种系统信息。
Core Admin: 核心管理。后面的内容有解释。
Java Properties:Java参数。因为solr是用java编写的,所以存在一些java参数。
下拉列表Core Selector : 选择当前的核心。后面的内容有讲解。
点击 Core Admin 后的界面:
红色方框中的是当前solr服务器正在管理的核心。这些核心与 E:\blog\test1\solr-6.3.0\example\example-DIH\solr 中的文件夹一一对应。绿色方框中的是用户选中的核心的详细信息。比如上面图片中,用户选择了db核心,绿色方框中就显示了db核心的startTime、instanceDir和dataDir参数。
下拉列表Core Selector中选择db后的界面:
其中 Overview是db核心的概览,Dataimport是导入数据,Query是查询。solr默认的db例子里面使用的是hsqldb。为了使用这个例子,我们要先引入数据。点击 Dataimport,页面如下:
Configuration显示db核心的数据配置。当你修改了核心配置了以后,点击Reload重新加载数据配置。每次启动solr服务器或者修改了数据配置以后,都要在左侧执行 full-import命令刷新。现在我们点击一下 Execute 按钮,就可以刷新。solr会启动一个线程进行刷新,在刷新完成前,你依然可以访问数据,不过只能访问到旧的数据。点击Refresh Status可以刷新线程的状态。点击 Raw Status-Output 就可以查看到最新的刷新线程运行的状态。当出现 Indexing completed. Added/Updated: 16 documents. Deleted 0 documents. (Duration: 02s) 的提示,说明刷新已经完成。
除了点击按钮以外,你也可以直接用Get方法访问
http://localhost:8983/solr/db/dataimport?command=full-import&wt=json
来刷新数据和配置。
用Get方法访问 http://localhost:8983/solr/db/dataimport?command=status&wt=json
来获得刷新线程的状态。
下拉列表Core Selector下方,点击Query,就来到了查询页面。等上面提到的刷新完成后,就可以查看到数据了。效果如图所示:
图中右上角的链接是一个Web api 的地址,用户可以用GET方法访问这个地址来获取数据。数据格式如右下部分json格式所示。中间栏,q文本域里面是查询参数。默认的 *:* 表示查询所有记录。 start, rows 分别表示开始的行数和显示出来的行数。start从0开始,默认start等于0,rows等于10。
name:*11* 表示查找name属性包含字符串11的记录。
name:*11* OR name:*DATA* 表示查找name属性包含11或者name属性包含DATA的记录。注意 OR 的左右都有英语空格。
NOT name:*11* 表示查找name 属性不包含11的记录。注意NOT和name之间有英语空格。
name:*le* AND price:[19 TO 10000] 表示查找name属性包含le字符串并且价格在19到10000之间的记录。注意TO和AND的左右两边有英语空格。
price:{350 TO 399] 查找价格在350到399之间的记录。{ 或 } 表示不包含边界值, [ 或 ] 表示包含边界值。
price:{350 TO *] 查找大于350的记录,不包含350。
price:{* TO 350] 查找小于等于350的记录。
(name:USB AND name:ta)OR(name:USB OR name:ta) 英文圆括号用来提高逻辑运算符的优先级。
二、连接MySQL
下面我们用连接一张表来演示如何连接MySQL。
使用solr stop -all
确保关闭solr。我们在已有例子的基础上进行修改。复制 E:\blog\test1\solr-6.3.0\example\example-DIH\solr 下的db文件夹,粘贴重命名为db2。
db2 下面的 lib 文件夹下,删除hsqldb-1.8.0.10.jar 文件,把文件 mysql-connector-java-5.1.40.jar 放到lib文件夹下面。在db2\conf文件夹下面,用编辑器打开solrconfig.xml文件,找到下面几行:
在这几行代码下面紧跟着另起一行,加一个lib标签,内容如下:
dir属性是指mysql驱动jar文件所在文件夹的硬盘路径。注意路径分隔符建议使用 / 。这个例子,所有的字符编码都使用了UTF-8。数据库也使用了UTF-8。
mysql中的数据结构如下:
CREATE DATABASE `db1` /*!40100 DEFAULT CHARACTER SET utf8 */; use db1; CREATE TABLE `t_book` ( `c_id` varchar(100) NOT NULL, `c_name` varchar(45) DEFAULT NULL, `c_isbn` varchar(45) DEFAULT NULL, `c_price` decimal(5,2) DEFAULT NULL, PRIMARY KEY (`c_id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
编辑 db-data-config.xml 文件,内容如下:
<dataConfig><dataSource type&#61;"JdbcDataSource" driver&#61;"com.mysql.jdbc.Driver" url&#61;"jdbc:mysql://127.0.0.1:3306/db1" user&#61;"test_user" encoding&#61;"UTF-8" password&#61;"123456"/> <document> <entity name&#61;"jynbook" processor&#61;"SqlEntityProcessor" pk&#61;"id" query&#61;"select c_id,c_name,c_isbn from t_book"> <field name&#61;"id" column&#61;"c_id" /> <field name&#61;"name" column&#61;"c_name" /> <field name&#61;"isbn" column&#61;"c_isbn" /> entity> document> dataConfig>
编辑 managed-schema 文件&#xff0c;换成下面的内容&#xff1a;
<schema name&#61;"example-DIH-db2" version&#61;"1.6"> <uniqueKey>iduniqueKey> <fieldType name&#61;"alphaOnlySort" class&#61;"solr.TextField" omitNorms&#61;"true" sortMissingLast&#61;"true"> <analyzer> <tokenizer class&#61;"solr.KeywordTokenizerFactory"/> <filter class&#61;"solr.LowerCaseFilterFactory"/> <filter class&#61;"solr.TrimFilterFactory"/> <filter class&#61;"solr.PatternReplaceFilterFactory" pattern&#61;"([^a-z])" replace&#61;"all" replacement&#61;""/> analyzer> fieldType> <fieldType name&#61;"ancestor_path" class&#61;"solr.TextField"> <analyzer type&#61;"index"> <tokenizer class&#61;"solr.KeywordTokenizerFactory"/> analyzer> <analyzer type&#61;"query"> <tokenizer class&#61;"solr.PathHierarchyTokenizerFactory" delimiter&#61;"/"/> analyzer> fieldType> <fieldType name&#61;"binary" class&#61;"solr.BinaryField"/> <fieldType name&#61;"boolean" class&#61;"solr.BoolField" sortMissingLast&#61;"true"/> <fieldType name&#61;"currency" class&#61;"solr.CurrencyField" currencyConfig&#61;"currency.xml" defaultCurrency&#61;"USD" precisionStep&#61;"8"/> <fieldType name&#61;"date" class&#61;"solr.TrieDateField" positionIncrementGap&#61;"0" precisionStep&#61;"0"/> <fieldType name&#61;"descendent_path" class&#61;"solr.TextField"> <analyzer type&#61;"index"> <tokenizer class&#61;"solr.PathHierarchyTokenizerFactory" delimiter&#61;"/"/> analyzer> <analyzer type&#61;"query"> <tokenizer class&#61;"solr.KeywordTokenizerFactory"/> analyzer> fieldType> <fieldType name&#61;"double" class&#61;"solr.TrieDoubleField" positionIncrementGap&#61;"0" precisionStep&#61;"0"/> <fieldType name&#61;"float" class&#61;"solr.TrieFloatField" positionIncrementGap&#61;"0" precisionStep&#61;"0"/> <fieldType name&#61;"ignored" class&#61;"solr.StrField" indexed&#61;"false" stored&#61;"false" multiValued&#61;"true"/> <fieldType name&#61;"int" class&#61;"solr.TrieIntField" positionIncrementGap&#61;"0" precisionStep&#61;"0"/> <fieldType name&#61;"location" class&#61;"solr.LatLonType" subFieldSuffix&#61;"_coordinate"/> <fieldType name&#61;"location_rpt" class&#61;"solr.SpatialRecursivePrefixTreeFieldType" geo&#61;"true" maxDistErr&#61;"0.001" distErrPct&#61;"0.025" distanceUnits&#61;"kilometers"/> <fieldType name&#61;"long" class&#61;"solr.TrieLongField" positionIncrementGap&#61;"0" precisionStep&#61;"0"/> <fieldType name&#61;"lowercase" class&#61;"solr.TextField" positionIncrementGap&#61;"100"> <analyzer> <tokenizer class&#61;"solr.KeywordTokenizerFactory"/> <filter class&#61;"solr.LowerCaseFilterFactory"/> analyzer> fieldType> <fieldType