A-A+

sphinx实现联合查询几个例子

2019年03月06日 我爱编程 暂无评论

sphinx也就是一个像mysql数据库的工具了,我们可以在linux中使用sphinx来替换mysql了,下面小编整理了几个sphinx联合查询的语句,记得以前sphinx是不支持联合查询的,第一次接触sphinx,好像2010年初的时候,当时写过一篇关于sphinx安装的文章,sphinx mmseg mysql 中文分词,下面举例说明,sphinx的联合查询用法.

一,添加二张测试表和数据,代码如下:

1,users表和数据

  1. mysql> desc users;
  2. +----------+-------------+------+-----+---------+----------------+  
  3. | Field | Type | Null | Key | Default | Extra |
  4. +----------+-------------+------+-----+---------+----------------+  
  5. | user_id | int(11) | NO | PRI | NULL | auto_increment |
  6. | username | varchar(20) | NO | | NULL | |
  7. +----------+-------------+------+-----+---------+----------------+  
  8. rows in set (0.00 sec)
  9. mysql> select * from users;
  10. +------------+------------+  
  11. | user_id | username |
  12. +------------+------------+  
  13. | 1311895262 | 张三 |
  14. | 1311895263 | tank张二 |
  15. | 1311895264 | tank张一 |
  16. | 1311895265 | tank张 |
  17. +------------+------------+  
  18. rows in set (0.00 sec)

2,orders表和数据

  1. mysql> desc orders;
  2. +--------------+-------------+------+-----+---------+----------------+  
  3. | Field | Type | Null | Key | Default | Extra |
  4. +--------------+-------------+------+-----+---------+----------------+  
  5. | id | int(11) | NO | PRI | NULL | auto_increment |
  6. | user_id | int(11) | NO | | NULL | |
  7. | create_time | datetime | NO | | NULL | |
  8. | product_name | varchar(20) | NO | | NULL | |
  9. | summary | text | NO | | NULL | |
  10. +--------------+-------------+------+-----+---------+----------------+  
  11. rows in set (0.00 sec)
  12. mysql> select * from orders;
  13. +----+------------+---------------------+----------------+--------------+  
  14. | id | user_id | create_time | product_name | summary |
  15. +----+------------+---------------------+----------------+--------------+  
  16. | 9 | 1311895262 | 2014-08-01 00:24:54 | tank is 坦克 | 技术总监 |
  17. | 10 | 1311895263 | 2014-08-01 00:24:54 | tank is 坦克 | 技术经理 |
  18. | 11 | 1311895264 | 2014-08-01 00:24:54 | tank is 坦克 | DNB经理 |
  19. | 12 | 1311895265 | 2014-08-01 00:24:54 | tank is 坦克 | 运维总监 |
  20. +----+------------+---------------------+----------------+--------------+  
  21. rows in set (0.00 sec)

二,配置sphinx.conf,代码如下:

  1. source order
  2. {
  3.  type = mysql
  4.  sql_host = localhost
  5.  sql_user = root
  6.  sql_pass =
  7.  sql_db = test
  8.  sql_query_pre = SET NAMES utf8
  9.  sql_query = \
  10.  SELECT a.id, a.user_id,b.username, UNIX_TIMESTAMP(a.create_time) AS create_time, a.product_name, a.summary \
  11.  FROM orders a left join users b on a.user_id = b.user_id
  12.  sql_attr_uint = user_id
  13.  sql_field_string = username
  14.  sql_field_string = product_name
  15.  sql_attr_timestamp = create_time
  16.  sql_ranged_throttle = 0
  17.  sql_query_info = SELECT * FROM orders WHERE id=$id
  18. }
  19. index myorder
  20. {
  21.  source = order
  22.  path = /usr/local/sphinx/var/data/myorder
  23.  docinfo = extern
  24.  mlock = 0
  25.  morphology = none
  26.  min_word_len = 1
  27.  charset_dictpath = /usr/local/mmseg3/etc/
  28.  charset_type = zh_cn.utf-8
  29.  ngram_len = 0
  30.  html_strip = 0
  31. }

注意:在这里a.user_id = b.user_id,等号二边一定要有空格,不然就会报错.

三,重启sphinx,代码如下:

  1. # pkill searchd
  2. # /usr/local/sphinx/bin/indexer --config /usr/local/sphinx/etc/sphinx.conf --all  
  3. # /usr/local/sphinx/bin/searchd --config /usr/local/sphinx/etc/sphinx.conf

四,测试sphinx,代码如下:

  1. [root@localhost etc]# mysql -h 127.0.0.1 -P 9306 //登录sphinx,9306端口,不是真实的mysql
  2. Welcome to the MySQL monitor. Commands end with ; or \g.
  3. Your MySQL connection id is 1
  4. Server version: 1.11-id64-dev (r2540)
  5. Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.
  6. Oracle is a registered trademark of Oracle Corporation and/or its
  7. affiliates. Other names may be trademarks of their respective
  8. owners.
  9. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
  10. mysql> select * from myorder where match('张');
  11. +------+--------+------------+------------+-------------+----------------+  
  12. | id | weight | user_id | username | create_time | product_name |
  13. +------+--------+------------+------------+-------------+----------------+  
  14. | 9 | 1304 | 1311895262 | 张三 | 1406823894 | tank is 坦克 |
  15. | 10 | 1304 | 1311895263 | tank张二 | 1406823894 | tank is 坦克 |
  16. | 11 | 1304 | 1311895264 | tank张一 | 1406823894 | tank is 坦克 |
  17. | 12 | 1304 | 1311895265 | tank张 | 1406823894 | tank is 坦克 |
  18. +------+--------+------------+------------+-------------+----------------+  
  19. rows in set (0.01 sec)
  20. mysql> select * from myorder where match('张三');
  21. +------+--------+------------+----------+-------------+----------------+  
  22. | id | weight | user_id | username | create_time | product_name |
  23. +------+--------+------------+----------+-------------+----------------+  
  24. | 9 | 2500 | 1311895262 | 张三 | 1406823894 | tank is 坦克 |
  25. +------+--------+------------+----------+-------------+----------------+  
  26. 1 row in set (0.00 sec)

给我留言

Copyright © 四季博客 保留所有权利.   Theme  Ality

用户登录