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

MySQL function 'HEX' in H2 / Derby / HSQL

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

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

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

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

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

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

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