- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要确定给定的字符串是否可以解释为 SQL 语句中的数字(整数或 float )。如下所示:
SELECT AVG(CASE WHEN x ~ '^[0-9]*.?[0-9]*$' THEN x::float ELSE NULL END) FROM test
我发现 Postgres 的 pattern matching 可以用于此。因此,我修改了 this place 中给出的语句以合并 float 。这是我的代码:
WITH test(x) AS (
VALUES (''), ('.'), ('.0'), ('0.'), ('0'), ('1'), ('123'),
('123.456'), ('abc'), ('1..2'), ('1.2.3.4'))
SELECT x
, x ~ '^[0-9]*.?[0-9]*$' AS isnumeric
FROM test;
输出:
x | isnumeric
---------+-----------
| t
. | t
.0 | t
0. | t
0 | t
1 | t
123 | t
123.456 | t
abc | f
1..2 | f
1.2.3.4 | f
(11 rows)
如您所见,前两项(空字符串 ''
和唯一句点 '.'
)被错误分类为数字类型(它们不是)。我现在无法更接近这一点。任何帮助表示赞赏!
更新 基于 this answer(及其评论),我将模式调整为:
WITH test(x) AS (
VALUES (''), ('.'), ('.0'), ('0.'), ('0'), ('1'), ('123'),
('123.456'), ('abc'), ('1..2'), ('1.2.3.4'), ('1x234'), ('1.234e-5'))
SELECT x
, x ~ '^([0-9]+[.]?[0-9]*|[.][0-9]+)$' AS isnumeric
FROM test;
给出:
x | isnumeric
----------+-----------
| f
. | f
.0 | t
0. | t
0 | t
1 | t
123 | t
123.456 | t
abc | f
1..2 | f
1.2.3.4 | f
1x234 | f
1.234e-5 | f
(13 rows)
正如我现在所见,科学记数法和负数仍然存在一些问题。
最佳答案
您可能已经注意到,基于正则表达式的方法几乎不可能正确执行。例如,您的测试表明 1.234e-5
不是有效数字,而实际上是这样。另外,您错过了负数。如果某些东西看起来像数字,但当您尝试存储它时会导致溢出怎么办?
相反,我建议创建尝试实际转换为 NUMERIC
(或 FLOAT
,如果您的任务需要)并返回 TRUE
或 FALSE
取决于此转换是否成功。
此代码将完全模拟函数 ISNUMERIC()
:
CREATE OR REPLACE FUNCTION isnumeric(text) RETURNS BOOLEAN AS $$
DECLARE x NUMERIC;
BEGIN
x = $1::NUMERIC;
RETURN TRUE;
EXCEPTION WHEN others THEN
RETURN FALSE;
END;
$$
STRICT
LANGUAGE plpgsql IMMUTABLE;
对您的数据调用此函数会得到以下结果:
WITH test(x) AS ( VALUES (''), ('.'), ('.0'), ('0.'), ('0'), ('1'), ('123'),
('123.456'), ('abc'), ('1..2'), ('1.2.3.4'), ('1x234'), ('1.234e-5'))
SELECT x, isnumeric(x) FROM test;
x | isnumeric
----------+-----------
| f
. | f
.0 | t
0. | t
0 | t
1 | t
123 | t
123.456 | t
abc | f
1..2 | f
1.2.3.4 | f
1x234 | f
1.234e-5 | t
(13 rows)
它不仅更正确、更易于阅读,而且如果数据实际上是一个数字,它的工作速度也会更快。
关于regex - isnumeric() 与 PostgreSQL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16195986/
我有一个 id 为 EmpNum 的文本框。我不知道如何使用 jQuery 的 isNumeric 来检查该值是否为数字。 我尝试过: ('#.EmpNum').IsNumeric 但这没有用
我编写了一个函数,它根据输入单元格生成一个“分数”(1,0,-1),该单元格应该包含一个数字。但是,有时输入字段可能不是数字,然后该函数应返回输出“0”。 Function ScoreRoE(RoE_
是否可以使用 IsNumeric() 测试字符串并使其返回 true,但是当您使用 CInt() 将同一字符串转换为整数并将其分配给整数类型的变量时,它会给出类型不匹配错误吗? 我问是因为我遇到了类型
请解释为什么下面的代码行为随机 下面的代码行返回 TRUE什么时候应该返回 FALSE?Isnumeric("555-") 还 ?Isnumeric("555-"/2)返回 TRUE 请解释 IsNu
我正在编写一个 Javascript 函数来验证用户输入。条件是,数据至少要有一个数字。 var userName = "abcde200" function isNumeric(userName){
我正在尝试创建一个包含 3 个值的表单:姓名、体重和高度。我想强制用户只输入数字而不是字母,因此使用 isNumeric 可以,但仅适用于体重,不适用于高度。 这是当前代码 function isN
保留列是 varchar,为了对其执行求和,我想将其转换为 deciaml。但是下面的 SQL 给了我一个错误 select cast(Reserve as decimal) from MyReser
SELECT IsNumeric('472369326D4') 返回1。显然,字符串中有一个字母D。为什么? 最佳答案 472369326D4 是有效的 float 类型。 D4 被翻译为添加四个 0
我包含一个像这样的 jQuery 文件: 我有这样的代码: if($.isNumeric(now)) { alert("yes"); } else { alert("n
这个问题在这里已经有了答案: Validate decimal numbers in JavaScript - IsNumeric() (52 个答案) 关闭 8 年前。 我有一个代码可以从用户那里
在 MSSQL 中,我使用如下查询,它会根据我在 $search 中的内容进行不同的查询:文本或数字。 $query=" IF (isnumeric('$search'
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: How to identify if string contain a number? 在VB中有一个IsN
我在我的代码中使用 IsNumeric() 函数来验证数字。 IsNumeric(100) - 正确,IsNumeric(-100) - 正确,IsNumeric(+100) - 真, IsNumer
我有两列数据正在使用 VBA 进行清理。如果 A 列中的值是非数字或空白,我需要删除整行。以下是我尝试使用的数据示例和代码。如果 IsNumeric 返回 false,它似乎完全跳过了删除行的代码部分
我正在使用 SQL Server 2008 R2。当我执行以下查询时,ISNUMERIC 的计算结果为 true(1),而条码内部显然有“D”。 SELECT ISNUMERIC('72103001
我在经典 asp 失败中的 IsNumeric 函数有一个非常奇怪的问题。我的代码中会发生这样的事情: Response.write Score // 79.617 Re
SQL 检测到以下字符串 ISNUMERIC : '07213E71' 我相信这是因为“E”被归类为数学符号。 但是,我需要确保只有整数值才会返回为 True。 我该怎么做? 最佳答案 07213E7
我正在使用 visual studio 2008 开发适用于 windows CE 6.0 的紧凑型框架软件。 我有这个“奇怪的?” isNumeric 方法有问题。还有其他更好的方法来完成这项工作吗
我正在使用 Jquery 来检查某些内容是否为数字。如何检查它是否不是数字? if (IsNumeric($('#Amount').val())) { ..... 我放了一个!在 IsNum
$.isNumeric 之间有什么区别吗?和 !isNaN()? 我不知道他们会在哪里返回不同的结果。 最佳答案 来自 jQuery 博客: Inside jQuery we’ve found sev
我是一名优秀的程序员,十分优秀!