我使用的是ts版本2.0.5、rails 3.0.9和mysql2版本0.2.11。
在尝试使用rake ts:index创建我的索引时,我遇到了以下错误:
ERROR: source 'technical_core_0': unknown type 'mysql'; skipping.
我的 development.sphinx.conf 文件包含:
source technical_core_0
{
type = mysql
sql_host = localhost
sql_user = root
sql_pass =
sql_db = ps_development
sql_sock = /tmp/mysql.sock
sql_query_pre = SET NAMES utf8
sql_query_pre = SET TIME_ZONE = '+0:00'
sql_query = SELECT SQL_NO_CACHE `technicals`.`id` * CAST(1 AS SIGNED) + 0 AS `id` , `orders`.`name` AS `author`, `technicals`.`id` AS `sphinx_internal_id`, 0 AS `sphinx_deleted`, 488243725 AS `class_crc`, IFNULL(`orders`.`name`, '') AS `author_sort`, `technicals`.`order_id` AS `order_id`, UNIX_TIMESTAMP(`technicals`.`created_at`) AS `created_at`, UNIX_TIMESTAMP(`technicals`.`updated_at`) AS `updated_at` FROM `technicals` LEFT OUTER JOIN `orders` ON `orders`.`id` = `technicals`.`order_id` WHERE (`technicals`.`id` >= $start AND `technicals`.`id` <= $end) GROUP BY `technicals`.`id`, , `orders`.`name`, `technicals`.`id`, `orders`.`name`, `technicals`.`order_id`, `technicals`.`created_at`, `technicals`.`updated_at` ORDER BY NULL
sql_query_range = SELECT IFNULL(MIN(`id`), 1), IFNULL(MAX(`id`), 1) FROM `technicals`
sql_attr_uint = sphinx_internal_id
sql_attr_uint = sphinx_deleted
sql_attr_uint = class_crc
sql_attr_uint = order_id
sql_attr_timestamp = created_at
sql_attr_timestamp = updated_at
sql_attr_str2ordinal = author_sort
sql_query_info = SELECT * FROM `technicals` WHERE `id` = (($id - 0) / 1)
}
我的database.yml文件中包含mysql2和root密码,这有点奇怪。
你能帮我解决这个问题吗?我还尝试创建了一个sphinx.yml文件,其中包含:
development:
adapter: mysql2
但是这也失败了。
-- 更新 --
我将以下内容添加到开发初始化文件中:
ThinkingSphinx.database_adapter = :mysql2
这会报错,只支持 MySQL。
brew options [软件包名称]
来查看所有可用的标志,例如--mysql或--postgres。 - j_mcnallybrew reinstall sphinx --mysql
。 - RNickMcCandless