- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我目前正在尝试使用内存中的 HSQLDB 实例创建一个测试环境,该实例是使用 Spring 创建的,这要归功于它的嵌入式数据库支持:
为我的单元测试创建“数据源”:
db = new EmbeddedDatabaseBuilder()
.addDefaultScripts()
.addScript("stored_procedure.sql")
.build();
“stored_procedure.sql”的内容:
-- Mock of a more complex stored procedure in production environment
CREATE PROCEDURE GetFooById(IN fooId VARCHAR(12))
READS SQL DATA DYNAMIC RESULT SETS 1
BEGIN ATOMIC
DECLARE resultSet CURSOR WITHOUT HOLD WITH RETURN FOR SELECT name, value FROM Foos WHERE id = fooId;
OPEN resultSet;
END
我能够初始化我的架构并从“默认脚本”插入我的测试数据,没有任何问题。
但是,在创建过程时,我看到类似下面的错误,即使在上述 SQL 的不同版本之后,有/没有分隔符,以及在不同位置有分隔符:
java.sql.SQLSyntaxErrorException: unexpected end of statement: required: ;
at org.hsqldb.jdbc.Util.sqlException(Unknown Source)
at org.hsqldb.jdbc.Util.sqlException(Unknown Source)
at org.hsqldb.jdbc.JDBCStatement.fetchResult(Unknown Source)
at org.hsqldb.jdbc.JDBCStatement.executeUpdate(Unknown Source)
at org.springframework.jdbc.datasource.init.ResourceDatabasePopulator.executeSqlScript(ResourceDatabasePopulator.java:169)
我使用的是提供 HSQLDB 2.2.4 的 Spring 3.1.1,根据文档,我认为我做的是正确的。
但是,像这样的讨论:
让我觉得这可能是 HSQLDB 和 Spring 之间的不兼容/由处理分隔符的方式引起的错误。
但我是 Spring 和 HSQLDB 的初学者,因此我有以下问题。
以前有人见过吗?并提出了解决方案?
如果最终的存储过程是使用 {call GetFooById ?} 调用的,那么在 HSQLDB 中是否有使用 select-from-where 查询返回结果集的等效方法?
这会因为 ResourceDatabasePopulator 而有效地发生吗? ResourceDatabasePopulator 还在 Spring 3.1.1 中造成问题吗?
还有其他指针/提示吗?
非常感谢您的帮助。
M.
编辑:
问题:
ResourceDatabasePopulator 将分号作为查询分隔符处理,不符合 HSQLDB 的语法。
{call GetFooById ?} 是 Sybase(我的生产数据库)的有效语法,但不适用于 HSQLDB,它需要 {call GetFooById(?)} .当然,HSQLDB 语法也不兼容 Sybase 的语法。此外,Spring 的 JdbcTemplate 并没有抽象出这些差异。
解决方案:
使用 Java 存储过程而不是 SQL 存储过程可能是一种解决方法,因为查询是在 Java 端编写的,并且不涉及分号分隔符。或者,我猜 ResourceDatabasePopulator 的逻辑可以更改并用于设置嵌入式数据库,但我到目前为止还没有尝试过。
Spring 的 StoredProcedure 类似乎更便携,可以与 Sybase 和 HSQLDB 一起使用,即使它比 JdbcTemplate 更冗长。
源代码:可在 my GitHub repository 获得.
最佳答案
对于存储过程和对象类型,您需要注意数据库的 JDBC 驱动程序。对于存储过程,也用于测试或其他,在您的数据库中创建一个包,并在未来的测试阶段调用它。
我使用存储过程和自定义输入/输出对象,仅使用 Java SQL 存储过程 API,并在需要时进行自定义。
如果您想解释您的背景和案例,我们可以帮助您找到最佳解决方案:-)。
关于database - 使用 Spring 嵌入式数据库 API 在 HSQLDB 中创建存储过程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10338044/
这个问题困扰了我几天。 这是我的相关 Storyboard布局: 我已经将阳光下的每个布局都设置为所有三个 View Controller ,并且仍然得到一个在横幅 View 上方有一个“间隙”的结果
我正在我的 C++ 程序中嵌入一个网页。我遇到的问题是,在嵌入式页面的 javascript 中,我可以捕获 onkeypress,但不会触发 onkeydown 和 onkeyup。 如果我在非嵌入
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 5年前关闭。 Improve this qu
我有一个 java web 应用程序。我想创建一个嵌入式 LDAP 服务器,当 web 应用程序运行时,我将向 LDAP 插入一些记录,并且有另一个 web 应用程序将访问此 LDAP 以获取信息。可
我正在尝试通过 tomcat maven 插件将 war 部署到嵌入式 tomcat 服务器。控制台显示服务器启动正常。 看来 war 还没有展开。当我访问 http://localhost:9090
假设我有如下函数: bigrams=[(k,v) for (k,v) in dict_bigrams.items() if k[:pos_qu]==selection[:pos_qu
我读过一些关于 python 嵌入式 C++ 的教程。我曾引用过 python 对象。 https://docs.python.org/3/c-api/function.html Python 脚本:
我正在使用嵌入式应用程序,在调试期间,调试器无法解析宏符号(我的理论:因为宏在预处理中丢失了)。我最终不得不先在源代码中找到宏,然后使用定义来监视变量。 我的问题是:有没有办法将宏定义合并到 elf
首先我要说的是我开发的是基于cortex m4的嵌入式设备应用。 我有引导加载程序和主应用程序通用的功能。现在我为引导加载程序和应用程序编译源文件 2 次。但是我的双库 dfu 空间不足,我想在 RO
作为嵌入式 C 编程的初学者,我很好奇每个(根据我的经验)程序执行是如何从 main() 函数开始的?这就像链接器识别 main() 并将那个“特殊” 函数的地址放入重置 vector 指向的地址。
在我的实时嵌入式处理器固件中,我需要十进制数字的格式化打印。标准 printf/sprintf 在工具链中不可用,所以我需要自己实现它。 我使用了除以十并取余的天真方法。但是我的目标处理器本身不支持除
我有编程经验,但在软件开发方面了解不多。我目前正在为我工作的公司编写一个软件,我开始挑战自己代码的可读性。 我想知道这是否是嵌入式 if 语句的“有效”替代方案,或者我是否可以使用更好的方法。 假
我有一个运行嵌入式 Linux 的嵌入式目标,我想计算以下时间: 1) 高速缓存读/写时序2) uncache 内存读/写时序 Linux 中是否有任何标准测试来计算上述时间? 我已经编写了自己的测试
大多数嵌入式设备都是为了在通常资源受限或低规格的设备上执行特定任务而构建的。 因此,大多数嵌入式开发人员需要去除不必要的库和模块,并为其特定设备和用例创建自定义分发。我们先来了解一下嵌入式 Linu
我正在嵌入式处理器上编写一个简单的裸机应用程序。作为此应用程序的一部分,它必须使用 malloc 在大约 256kB 的堆上分配一些内存。注意:最初这是在 main 中静态分配的,但在一定的大小限制下
我正在尝试为我 friend 的婚礼建立一个网站。我使用的是 Bootstrap 5,嵌入的视频没有填满屏幕大小。这是一个 live test page HTML: 您还需要代码吗?我想让视频的全宽
我有一个项目,我尝试为微 Controller 构建固件并尝试更好地控制所使用的优化标志。我想,而不是使用 -O flag 分别指定不同的优化标志。不幸的是,-O 似乎发生了一些优化魔法。我无法使用单
我正在使用双核设备,并且要求核心 A 创建一个数据结构,其中包含在核心 B 上运行的函数列表的参数,定期更新它并通知核心 B。参数和类型的数量可以改变在运行期间。 我的计划如下.. 创建一个 Para
我们有一个 Microsoft.Phone.Controls.WebBrowser内嵌控件 StackPanel , 在 PivotItem 内在 Windows Phone 8 上。以简化的形式,它
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 2 年前。 Improve this ques
我是一名优秀的程序员,十分优秀!