我想以这种方式过滤一个表中的项目,该表包含一个带有串联整数的列:
3|7|2|10|11
我只想获得包含特定范围的结果,例如:
[0 - 10] return result for 3|7|2|10|9
[0 - 10] don't return result for 13|7|2|10|9
未定义分隔项的长度。
最佳答案
首先,Juergen D. 是完全正确的:您首先通过在单个列中引入多个值来引入这个问题,从而给数据库戴上手铐。
也就是说,除了简单的讲课之外,我还想在短期内提供帮助。 :) 我们开始吧。
我们将利用出色的 user-defined SPLIT_STR() function by Luis Rodriguez ,具体如下:
CREATE FUNCTION SPLIT_STR(
x VARCHAR(255),
delim VARCHAR(12),
pos INT
)
RETURNS VARCHAR(255)
RETURN REPLACE(SUBSTRING(SUBSTRING_INDEX(x, delim, pos),
LENGTH(SUBSTRING_INDEX(x, delim, pos -1)) + 1),
delim, '');
现在,我编写了另一个函数,它将遍历表中每个字符串的分隔值,沿途调用 SPLIT_STR(),并检查每个值是否低于指定的最小值(在您的示例中为 0)或高于最大值(在您的示例中为 10):
CREATE FUNCTION check_vals (
x varchar(255),
delim varchar(12),
mini int,
maxi int
)
RETURNS bool
BEGIN
declare len, pos int;
declare val int;
set len = length(x) - length(replace(x,'|',''));
set pos = 1;
WHILE pos <= len DO
set val = split_str(x, delim, pos);
IF val < mini or val > maxi THEN
return false;
END IF;
set pos = pos + 1;
END WHILE;
RETURN true;
END //
让我为您分解一下。您传入有问题的分隔字符串 (x)、分隔符 (|)、最小允许值 (mini) 和最大值允许值(maxi)。
set len = length(x) - length(replace(x,'|',''));
这会获取给定字符串 x 中的标记总数或分隔值。这告诉我们的 while 循环要绕圈多少圈。
set val = split_str(x, delim, pos);
这会获取每个标记的实际值(在您的示例中:3、7、2、10、9,对于第一条记录)。
IF val < mini or val > maxi THEN
return false;
END IF;
如果给定值低于最小值或高于最大允许值,我们将退出函数并返回 FALSE。
END WHILE;
RETURN true;
如果我们到达 RETURN true,这意味着每个值都通过了测试,并且记录总体上符合您的标准。
因此,对于检查最小值 0 和最大值 10 的示例,您可以调用如下内容:
select str, check_vals(str,'|',0,10) `result` from t;
你会得到什么
| str | result |
|-------------|--------|
| 3|7|2|10|9 | true |
| 13|7|2|10|9 | false |
关于MySQL过滤一个范围内的分隔项目列表的col,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33090178/
如何在buildr项目中使用Ruby?我在很多不同的项目中使用过Ruby、JRuby、Java和Clojure。我目前正在使用我的标准Ruby开发一个模拟应用程序,我想尝试使用Clojure后端(我确实喜欢功能代码)以及JRubygui和测试套件。我还可以看到在未来的不同项目中使用Scala作为后端。我想我要为我的项目尝试一下buildr(http://buildr.apache.org/),但我注意到buildr似乎没有设置为在项目中使用JRuby代码本身!这看起来有点傻,因为该工具旨在统一通用的JVM语言并且是在ruby中构建的。除了将输出的jar包含在一个独特的、仅限ruby
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta
我需要从一个View访问多个模型。以前,我的links_controller仅用于提供以不同方式排序的链接资源。现在我想包括一个部分(我假设)显示按分数排序的顶级用户(@users=User.all.sort_by(&:score))我知道我可以将此代码插入每个链接操作并从View访问它,但这似乎不是“ruby方式”,我将需要在不久的将来访问更多模型。这可能会变得很脏,是否有针对这种情况的任何技术?注意事项:我认为我的应用程序正朝着单一格式和动态页面内容的方向发展,本质上是一个典型的网络应用程序。我知道before_filter但考虑到我希望应用程序进入的方向,这似乎很麻烦。最终从任何
我想要做的是有2个不同的Controller,client和test_client。客户端Controller已经构建,我想创建一个test_clientController,我可以使用它来玩弄客户端的UI并根据需要进行调整。我主要是想绕过我在客户端中内置的验证及其对加载数据的管理Controller的依赖。所以我希望test_clientController加载示例数据集,然后呈现客户端Controller的索引View,以便我可以调整客户端UI。就是这样。我在test_clients索引方法中试过这个:classTestClientdefindexrender:template=>
是否有类似“RVMuse1”或“RVMuselist[0]”之类的内容而不是键入整个版本号。在任何时候,我们都会看到一个可能包含5个或更多ruby的列表,我们可以轻松地键入一个数字而不是X.X.X。这也有助于rvmgemset。 最佳答案 这在RVM2.0中是可能的=>https://docs.google.com/document/d/1xW9GeEpLOWPcddDg_hOPvK4oeLxJmU3Q5FiCNT7nTAc/edit?usp=sharing-知道链接的任何人都可以发表评论
我在我的Rails项目中使用Pow和powifygem。现在我尝试升级我的ruby版本(从1.9.3到2.0.0,我使用RVM)当我切换ruby版本、安装所有gem依赖项时,我通过运行railss并访问localhost:3000确保该应用程序正常运行以前,我通过使用pow访问http://my_app.dev来浏览我的应用程序。升级后,由于错误Bundler::RubyVersionMismatch:YourRubyversionis1.9.3,butyourGemfilespecified2.0.0,此url不起作用我尝试过的:重新创建pow应用程序重启pow服务器更新战俘
如果您尝试在Ruby中的nil对象上调用方法,则会出现NoMethodError异常并显示消息:"undefinedmethod‘...’fornil:NilClass"然而,有一个tryRails中的方法,如果它被发送到一个nil对象,它只返回nil:require'rubygems'require'active_support/all'nil.try(:nonexisting_method)#noNoMethodErrorexceptionanymore那么try如何在内部工作以防止该异常? 最佳答案 像Ruby中的所有其他对象
关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion为什么SecureRandom.uuid创建一个唯一的字符串?SecureRandom.uuid#=>"35cb4e30-54e1-49f9-b5ce-4134799eb2c0"SecureRandom.uuid方法创建的字符串从不重复?
我已经像这样安装了一个新的Rails项目:$railsnewsite它执行并到达:bundleinstall但是当它似乎尝试安装依赖项时我得到了这个错误Gem::Ext::BuildError:ERROR:Failedtobuildgemnativeextension./System/Library/Frameworks/Ruby.framework/Versions/2.0/usr/bin/rubyextconf.rbcheckingforlibkern/OSAtomic.h...yescreatingMakefilemake"DESTDIR="cleanmake"DESTDIR="
请帮助我理解范围运算符...和..之间的区别,作为Ruby中使用的“触发器”。这是PragmaticProgrammersguidetoRuby中的一个示例:a=(11..20).collect{|i|(i%4==0)..(i%3==0)?i:nil}返回:[nil,12,nil,nil,nil,16,17,18,nil,20]还有:a=(11..20).collect{|i|(i%4==0)...(i%3==0)?i:nil}返回:[nil,12,13,14,15,16,17,18,nil,20] 最佳答案 触发器(又名f/f)是