- 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/
我目前正在将 liquibase 与基于 SQL 的变更集一起使用,其中大多数都包含 INSERT 语句。根据文档,这种类型的更新操作不会产生(通过工具)自动回滚语句。 我的问题是(我可能遗漏了一些东
我刚刚开始使用 liquibase,它似乎很有用。我最大的问题是回滚。 我正在将我的 liquibase 变更日志烘焙到其中包含我的数据层的 jar 中,并且在应用程序启动时,我正在使用应用程序中的
我正在针对一个干净的 HSQLDB 实例同时运行 Liquibase 迁移,当其中一个更新成功时,另一个失败,如下所示: Exception in thread "Thread-7" liquibas
我正在尝试在雪花上开始使用 liquibase。 我想我已经快完成 liquibase.properties 文件了 driver: net.snowflake.client.jdbc.Snowfla
正在使用的 liquibase 版本 - org.liquibase:liquibase-core:3.8.2。 (不是专业版) Liquibase 文档(1 和 2)在下面说明了 splitStat
我正在使用 Liquibase 对现有数据库进行版本控制,所以我正在使用 liquibase \ --logLevel=debug \ --driver=com.mysql.jdbc.Driv
我在使用 liquibase 更改 postgres 数据库中的列长度时遇到问题。 我有一个带有字段描述 varchar(300) 的表帐户。我想把它改成 varchar(2000)。 我在同一个文件
问题:当用户被删除时,关联的记录不会从数据库中删除。相反,我设置了 user.delete列到 true .现在我需要在 user.email 上设置一个唯一约束但仅适用于事件用户(未删除)。 我怎样
我想更好地了解 Liquibase 如何执行变更集。 1) a) 例如,我有一个包含 4 个更改集的更改日志,我执行 updateDatabase ( http://www.liquibase.org
运行 liquibase --url=jdbc:oracle:thin:@localhost:1521/XE -- driver=oracle.jdbc.OracleDriver --chang
我已经看到如何重命名 DATABASECHANGELOG 表,但我想要做的是在每个服务器的一个数据库中创建它们,然后部署到该服务器上的其他数据库。我们在 MSSQL 和 Sybase 数据库上使用 L
我已经将 Liquibase 添加到我的应用程序中,这是一个在 JBoss EAP 6 上运行的 EAR。我使用 Maven 作为构建工具。我想知道运行 Liquibase 更新的首选方式是什么。目前
我需要制作一个 Liquibase 迁移脚本,仅当主键尚未添加时才将主键添加到数据库表。执行此操作的最佳方法是什么?它将是这样的: (What goes here? Should I
我在现有的变更日志文件中添加了一些新的变更集,并且只想执行新插入的变更集中的 2 个。当我在 liquibase 中给出更新命令时,它会更新所有未读的变更集并更新数据库。但是我只想执行变更日志文件中这
我发现 liquibase 使用更改日志文件的完整路径来计算校验和。 此行为限制修改更改日志文件名,并在重命名文件后尝试再次重新应用更改集。 有没有办法将 liquibase 配置为仅使用更改日志 I
我的数据库中有一个序列,是通过 Liquibase 生成的。在重构过程中,我们决定不喜欢我们给它起的名字,我们想重命名它,保留当前存在的所有数据。 alter a sequence 似乎有可能,但我没
我想更新名为“password”的列的类型。目前它有 NVARCHAR(40) 类型,我希望它是 NVARCHAR(64) 类型。这就是我所做的: 还需要做什
我正在创建一个包含 3 列的链接表; id、product_id、锦标赛id。 向“id”列添加 uniqueConstraint 是微不足道的,但我想确保任何一对 (product_id, tour
我正在尝试使用liquibase插入标签插入数据。当我在value标签中输入数字时,它可以正常工作。 但是我正在寻找一个简单的功能,即使我没有将其作为表定义的一部分,它也可以处理默认日期(数据库的当前
我正在尝试根据特定日期回滚数据库。 liquibase rollbackToDate 2013-05-14 10:13:16 它抛出以下错误: Error:Unexpected date/time f
我是一名优秀的程序员,十分优秀!