4

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

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

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

4

1 回答 1

3

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

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

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

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

于 2018-03-03T10:26:24.863 回答