- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
正在使用的 liquibase 版本 - org.liquibase:liquibase-core:3.8.2。 (不是专业版)
Liquibase 文档(1 和 2)在下面说明了 splitStatements
(默认为 true)
Set to false to not have Liquibase split statements on ;'s and GO's.Defaults to true if not set
和
Removes Liquibase split statements on ;'s and GO's when it is set tofalse. Default value is: true.
我发现的另一个有用的 sof 帖子 - In Liquibase is it OK to have an empty line on splitstatements?
我明白 - 当 splitStatements 为真时,liquibase 会拆分 ;
和 GO
splitStatements
有什么好处 - 即如果 SQL 语句在 ;
(结束分隔符)上拆分,它会有什么不同 - 即如果语句在单个查询或多个查询中执行 - 数据库不会处理“;”无论如何基于的东西。这似乎是理解的必要条件。 --有人能举个例子吗。splitStatements:false
。我们通过禁用 splitStatements 获得了哪些优势。 -任何例子将不胜感激。------------------------@user13579 回答后扩展了问题
下面是 liquibase 变更日志文件的摘录。这就是让我想到这个问题的原因。它在脚本中有 splitStatements:false
和一个 ;
,并且可以正常工作。使用 splitStatements:false
我希望在这种情况下出现错误,我想答案在这种情况下也会提示错误。以下是生产代码,所以我不确定它是如何工作的,后端是 POSTGRE。谁能解释一下。
--liquibase formatted sql
--changeset adam:001-users-001 failOnError:true splitStatements:false logicalFilePath:001-users.sql
CREATE TABLE sys_users
(
user_id SERIAL,
first_name character varying(64) NOT NULL,
last_name character varying(64) NOT NULL,
email character varying(255) NOT NULL
)
WITH (
OIDS=FALSE
);
CREATE TABLE user_role
(
role_id SERIAL,
role_name character varying(255) NOT NULL,
description character varying(255) NOT NULL,
created_on timestamp(6) with time zone NOT NULL,
created_by character varying(64) NOT NULL,
)
WITH (
OIDS=FALSE
);
最佳答案
数据库引擎通常不会自行拆分语句。使用 SQL Management Studio、MySQL Workbench 等 SQL 编辑器时,您可能会有不同的印象。他们拆分您的脚本并将单独的 SQL 语句发送到数据库引擎,例如使用 JDBC。它是自动发生的,因此您可能认为数据库会这样做。
这将因 splitStatements = true 而失败:
<changeSet id="it fails" author="DBA presents">
<sql splitStatements="true">
create procedure some_proc (out title int)
begin
select count(1) into title from titles
where emp_no = 123;
end
</sql>
</changeSet>
Liquibase 会在遇到分号时尝试拆分语句,这显然是一个错误,因为分号是更大语句(创建过程)的一部分。 Change splitStatement to false to allow semicolons in Liquibase SQL tag .
另一方面,在大多数情况下将 splitStatements 设置为 true 是很有用的。例如,当您想在单个 SQL 标记中提供多个语句时。使用 splitStatement=false,它将失败:
<changeSet id="it works" author="DBA presents">
<sql splitStatements="false">
update titles
set title = 'abc'
where emp_no = 123;
update titles
set title = 'abc'
where emp_no = 234;
</sql>
</changeSet>
您的 PostgreSQL 示例
我的计算机上没有安装 Postgres,但由于 splitStatements=false,相同的脚本(在明显的语法更改之后)在 MySQL 中失败。这绝对是数据库引擎之间的众多差异之一 - 显然 Postgres 本身将脚本拆分为语句。也许对于 Postgres splitStatement 属性没有意义,但对于其他引擎它确实像 MySQL。 Liquibase 支持各种引擎,因此并非所有选项都是必需的。
总结
通常,使用默认值 (splitStatements=true),您不必为每个语句创建单独的 SQL 标记。但有时您可能想通过设置 splitStatements=false 明确地告诉 Liquibase “这是一个单独的语句,不要尝试拆分它”。例如在创建存储过程时。
关于liquibase - liquibase "splitStatements"有什么好处?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/72989797/
如果函数定义顺序不对,Jslint 将指出错误。 显然 jslint 是严格的,但我想知道将函数按顺序排列是否有任何好处。 我的意思是在调用它们之前定义它们。 最佳答案 函数定义(和 var 语句)被
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 8 年前。 Improve this ques
我注意到Flask tutorial涉及到点的使用。看起来它只是用于在本地创建一个轮子,这将使服务器上的设置变得更容易,但作为一个网络开发新手,我很好奇:是否有人真的会一路将他们的网站上传到像 PyP
我一直在阅读有关 jquery live event 的内容,但仍然有点困惑?使用它有什么好处? http://docs.jquery.com/Events/live 我知道它与绑定(bind)类似,
这是我的故事:我已将我的应用迁移到 AndroidX,因为我需要从网上找到的库中获取一些新功能。 问题:我目前遇到了一些问题,因为我现在需要为 Cordova 开发一个插件来实现该应用程序的一部分。
在使用 RAD 或一般不使用单元测试时使用依赖注入(inject)是否有任何好处? 最佳答案 是的,有以下几个好处: 减少依赖 减少依赖携带 更多可重用代码 更多可测试代码 更具可读性的代码 更多引用
我目前正在构建一个通过 MSI Windows Installer 分发的产品。我们的客户正在使用不同的形式(例如我们在他们自己的 MSI 中)集成该产品,使用 Bootstrap /链接器(如 Wi
有人声称 Scala 的类型系统是图灵完备的。我的问题是: 这有正式的证据吗? 简单的计算在 Scala 类型系统中会是什么样子? 这对 Scala 这种语言有什么好处吗?与没有图灵完备类型系统的语言
我开始尝试使用 React,我注意到我正在制作的简单应用程序全部使用 JS。我的 html 页面只是一个空的 body 标签! 所以我有几个问题,因为我是这个框架的新手。 我的整个应用程序应该基本上都
我们有一个相当大的基于 Windows 的 1.1 .NET 应用程序,我们正在考虑升级到 2.0。我们考虑更新的主要原因是我们可以利用 Visual Studio 2008 进行项目的持续开发,以及
我有一个页面,其中内置了基于 ajax 的分页。分页用于页面中的“评论”功能。根据 Google 的网站管理员博客,具有 rel="next"和 rel="prev"值有利于 SEO。 我在头部添加了
我是一名优秀的程序员,十分优秀!