Issue when comparing result of to_char(myDate, #39;DAY#39;) to a string(将 to_char(myDate, DAY) 的结果与字符串进行比较时出现问题)
问题描述
我一直试图找出可能是什么问题,但我只是运气不好,根本不了解这个问题.我有以下代码:
I have been trying to find what the issue might be but I am just out of luck and don't understand this problem at all.I have the following code:
CREATE OR REPLACE FUNCTION ckeckDay(dateC in date)
RETURN VARCHAR
IS
day VARCHAR(15);
checkFriday VARCHAR(1);
BEGIN
checkFriday := 'N';
day := to_char(dateC, 'DAY');
IF day = 'FRIDAY' THEN
checkFriday := 'Y';
END IF;
RETURN day;
END;
/
dateC
设置为 Friday(甚至通过返回 day
而不是 day
变量来测试它并返回 Friday.)但是IF
语句永远不会计算为真,即使 day
变量确实是星期五.任何想法如何解决这个问题.谢谢
the dateC
is set to Friday (even tested it by returning day
instead of the day
variable and it returns Friday.) However the IF
statement never evaluates to true even though the day
variable is indeed Friday.Any ideas how to go around this issue.Thanks
推荐答案
这是因为 day
变量包含一个空白填充值.使用 trim
函数去除前导和尾随空格:
It is because day
variable contains a blank padded value. Use trim
function to get rid of leading and trailing spaces:
IF trim(day) = 'FRIDAY' THEN
checkFriday := 'Y';
END IF;
并且请使用 VARCHAR2
数据类型作为字符串变量.不要使用VARCHAR
.
And please use VARCHAR2
datatype for string variables. Do not use VARCHAR
.
这篇关于将 to_char(myDate, 'DAY') 的结果与字符串进行比较时出现问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:将 to_char(myDate, 'DAY') 的结果与字符串进行比较时出现问题


- 如何将 Byte[] 插入 SQL Server VARBINARY 列 2021-01-01
- 如何将 SonarQube 6.7 从 MySQL 迁移到 postgresql 2022-01-01
- 如何使用 pip 安装 Python MySQLdb 模块? 2021-01-01
- 远程 mySQL 连接抛出“无法使用旧的不安全身份验证连接到 MySQL 4.1+"来自 XAMPP 的错误 2022-01-01
- 以一个值为轴心,但将一行上的数据按另一行分组? 2022-01-01
- 导入具有可变标题的 Excel 文件 2021-01-01
- 使用 Oracle PL/SQL developer 生成测试数据 2021-01-01
- 在SQL中,如何为每个组选择前2行 2021-01-01
- SQL 临时表问题 2022-01-01
- 更改自动增量起始编号? 2021-01-01