发布
社区首页 >问答首页 >MySQL比较查询长文本列

MySQL比较查询长文本列
EN

Stack Overflow用户
提问于 2012-09-20 14:10:26
回答 1查看 1.8K关注 0票数 0

我有一个用来存储文本段落的LONGTEXT列。假设在这些段落中有这样的内容:

代码语言:javascript
代码运行次数:0
复制
Text text text text
COUNT: 75  text text
 text text text text
 text text text text

是否可以对所有文本中的小字符串"COUNT: 75“进行比较查询?

我的第一个想法是这样的

代码语言:javascript
代码运行次数:0
复制
SELECT * FROM `books`
WHERE `paragraphs` LIKE '%COUNT: >0%'

这有可能吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-09-20 14:14:47

您的SELECT将只查找文本中包含通配符之间的精确位的行:您不能将LIKE与这样的比较逻辑组合在一起。

但是,您可以做的是使用正则表达式剥离文本的相关部分,然后进行分析。

但是,请记住,组合

  • large of text
  • text content logic
  • regex

一下子不会提供最好的性能!我会提出以下建议:

  1. 使用触发器剥离文本的一小部分,以便您有可管理的内容(即50个字符左右),将此子文本插入到单独的表中
  2. 使用MySql正则表达式或全文函数分析计数

所以你的触发器应该是这样的:

代码语言:javascript
代码运行次数:0
复制
select 
ltrim(rtrim(substring(paragraphs, instr(paragraphs, 'count:') + 6, 10)))
from books 
where instr(paragraphs, 'count:') > 0

这将使您获得'count:'之后的下10个字符,去掉空格。然后,您可以通过以下方式进一步提炼:

代码语言:javascript
代码运行次数:0
复制
select substring(text_snippet, 1, instr(text_snippet, ' ')) as count_value
from
(
    select 
    ltrim(rtrim(substring(paragraphs, instr(paragraphs, 'count:') + 6, 10))) 
          as text_snippet
    from books 
    where instr(paragraphs, 'count:') > 0
) x
where isnumeric(substring(text_snippet, 1, instr(text_snippet, ' '))) = 1

以获取其中数值跟在计数位之后的行。

然后,您可以提取COUNT旁边的数值,将它们保存为单独的表中的数字,然后使用如下所示的联接:

代码语言:javascript
代码运行次数:0
复制
select b.*
from books b inner join books_count_values v
on b.id = v.books_id
where v.count_value > 0

请看这里

http://dev.mysql.com/doc/refman/5.1/en/string-functions.html

你可以随意使用的功能。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12506929

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档