gpt4 book ai didi

H2/Derby/HSQL 中的 MySQL 函数 'HEX'

转载 作者:行者123 更新时间:2023-11-29 02:12:08 28 4
gpt4 key购买 nike

我正在尝试使用内存数据库对 sql 查询进行单元测试。查询使用 MySQL 内置函数“hex”和“unhex”(因为它们将二进制数据写入数据库)。结果这 3 个内存数据库解决方案都不支持“十六进制”功能,我无法测试它们。

我的问题 - 如果不将十六进制转换移动到代码而不是直接在查询中使用“十六进制”函数,是否没有办法测试查询?

附言。我知道内存中的数据库并不代表真实的数据库行为,但查询非常简单 - 插入和选择。

最佳答案

HSQLDB 允许您定义自己的函数。如果您不测试实际的十六进制或字符串返回值,您可以创建模拟函数 HEX 和 UNHEX 来返回输入。例如:

CREATE FUNCTION UNHEX(S VARCHAR(1000)) RETURNS VARCHAR(1000) 
BEGIN ATOMIC
RETURN S;
END;

如果您希望函数返回实际转换后的值,您可以扩展函数以执行转换。在这种情况下,您可以使用内置函数提取 ASCII 代码,以及任何现有的静态 Java 方法:

更新:HSQLDB 2.4.1 版本中添加了对这两个函数的支持。

关于H2/Derby/HSQL 中的 MySQL 函数 'HEX',我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49082794/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com