Car*_*nez 3 postgresql ruby-on-rails pg-search
我正在使用 pg_search gem 将全文搜索添加到我的应用程序中的表中。
我的问题是在尝试创建触发器以在任何更改后使 tsv 列保持最新时,这是我的迁移:
class AddStoreItemsIndex < ActiveRecord::Migration[5.0]
def up
add_column :store_items, :tsv, :tsvector
add_index :store_items, :tsv, using: "gin"
execute <<-SQL
CREATE TRIGGER tsvectorupdate BEFORE INSERT OR UPDATE
ON store_items FOR EACH ROW EXECUTE PROCEDURE
tsvector_update_trigger(
tsv, 'pg_catalog.english', title, full_description, recommended_age, related_intelligences
);
SQL
end
...
end
Run Code Online (Sandbox Code Playgroud)
在这种情况下,该related_intelligences列是一个数组,因此在尝试查询时出现以下错误:
ActiveRecord::StatementInvalid:
PG::DatatypeMismatch: ERROR: column "related_intelligences" is not of a character type
Run Code Online (Sandbox Code Playgroud)
如何在此 tsv 向量列中包含数组?
我是这样做的:
class AddStoreItemsIndex < ActiveRecord::Migration[5.0]
def up
add_column :store_items, :tsv, :tsvector
add_index :store_items, :tsv, using: 'gin'
execute <<-SQL
CREATE FUNCTION update_tsv() RETURNS trigger AS $$
BEGIN
new.tsv :=
to_tsvector('pg_catalog.english', coalesce(new.title,'')) ||
to_tsvector('pg_catalog.english', coalesce(new.full_description,'')) ||
to_tsvector('pg_catalog.english', coalesce(new.recommended_age,'')) ||
to_tsvector('pg_catalog.english', coalesce(array_to_string(new.related_intelligences, ' '),''));
return new;
END
$$ LANGUAGE plpgsql;
CREATE TRIGGER tsvectorupdate BEFORE INSERT OR UPDATE
ON store_items FOR EACH ROW EXECUTE PROCEDURE update_tsv();
SQL
end
def down
execute <<-SQL
DROP TRIGGER tsvectorupdate
ON store_items;
DROP FUNCTION update_tsv();
SQL
remove_index :store_items, :tsv
remove_column :store_items, :tsv
end
end
Run Code Online (Sandbox Code Playgroud)
将tsvector_update_trigger不能用于阵列列,而不是我创建了一个基于从代码示例自定义函数PostgreSQL的搜索功能页面。
我曾经array_to_string将数组元素转换为文本。
| 归档时间: |
|
| 查看次数: |
1050 次 |
| 最近记录: |