首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何根据列中的字数过滤MySQL结果?

如何根据列中的字数过滤MySQL结果?
EN

Stack Overflow用户
提问于 2011-03-28 22:47:51
回答 2查看 1.1K关注 0票数 3

我正在尝试根据表列中包含的单词数来过滤MySQL查询的结果。

例如,我有10封推荐信,列为id、name、url、testimonial,其中5行有一封超过100个单词的推荐信来组成推荐信。

如何使用查询来仅返回该证明列中少于100个单词的行?

谢谢,

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-03-28 22:52:02

我并不是说他们的做法很棒,但是...

http://www.mwasif.com/2008/12/count-number-of-words-in-a-mysql-column/

代码语言:javascript
复制
SELECT *
FROM table
WHERE LENGTH(field) - LENGTH(REPLACE(field, ' ', '')) + 1 < 100

它实际上计算的是空格...但这对你来说可能已经足够近了。

票数 5
EN

Stack Overflow用户

发布于 2011-03-28 22:53:36

MySQL实际上没有任何“单词”计数函数,但是您可以通过计算文本字段中的空格数来粗略估计一下。当然,这里没有“一个字符串函数中有多少个字符'x‘),所以你必须绕着它走一圈:

代码语言:javascript
复制
SELECT  LENGTH(textfield) - LENGTH(REPLACE(textfield, ' ', '') AS words
FROM ...
HAVING words < 100

基本上,得到文本字段的长度,然后减去相同文本字段的长度,去掉空格,得到空格的数量。

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

https://stackoverflow.com/questions/5460740

复制
相关文章

相似问题

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