- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我有两个关于 MySQL 中的复合语句和事务的问题。
首先:
MySQL手册中有两个注释:
Note
Within all stored programs, the parser treats BEGIN [WORK] as the beginning of a BEGIN ... END block. To begin a transaction in this context, use START TRANSACTION instead.
Note
Within all stored programs (stored procedures and functions, triggers, and events), the parser treats BEGIN [WORK] as the beginning of a BEGIN ... END block. Begin a transaction in this context with START TRANSACTION instead.
我不明白具体是什么意思。他们的意思是我必须放置 START TRANSACTION
而不是 BEGIN
或紧跟在 BEGIN
之后?
// 1st variant:
BEGIN
START TRANSACTION
COMMIT
END
// 2nd variant:
START TRANSACTION
COMMIT
END
第一个变体还是第二个变体,哪一个是正确的方法?
第二:
我不想创建存储过程或函数。我只想在一般流程中创建一个内部有循环的复合语句 block ,如下所示:
USE 'someDb';
START TRANSACTION
... create table statement
... insert statement
// now I want to implement some insert/select statements using loop, I do as follows:
DELIMITER $
BEGIN
SET @n = 1, @m = 2;
lab1: LOOP
... some insert, select statements here
END LOOP lab1;
END $
DELIMITER ;
END
COMMIT
这种结构有可能吗?因为我抛出了一个错误:
Query: BEGIN SET @n = 1, @m = 2; lab1: LOOP SELECT ...
Error Code: 1064
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'SET @n = 1, @m = 2;
lab1: LOOP SELECT ...
我的问题是:
BEGIN...END
而无需创建和使用存储过程或函数?是否允许在 START TRANSACTION...COMMIT
中使用 BEGIN...END
或者我必须将 START TRANSACTION.. .COMMIT
在 BEGIN...END
内?
BEGIN
START TRANSACTION
COMMIT
END
// vs.
START TRANSACTION
BEGIN
END
COMMIT
如果我只想使用 LOOP
,我一定要使用 BEGIN...END
吗?我可以只使用 LOOP
语法而不开始 BEGIN...END
吗? LOOP
手册中的唯一示例是:
CREATE PROCEDURE doiterate(p1 INT)
BEGIN
label1: LOOP
...
最佳答案
Is it allowed to use BEGIN...END just in general flow without creating and using Stored Procedures or Functions?
否:复合语句只能在存储程序的主体中使用。
Is it allowed to use
BEGIN...END
inside ofSTART TRANSACTION...COMMIT
or I have to putSTART TRANSACTION...COMMIT
inside ofBEGIN...END
?
START TRANSACTION;
和 COMMIT;
是单独的语句。如果您希望存储程序的主体包含多条语句,则需要将这些语句包含在某种复合语句 block 中,例如 BEGIN ... END
(类似于包含一个 block 类 C 语言中大括号 { ... }
中的语句)。
就是说,您可以有一个仅包含单语句START TRANSACTION;
或COMMIT;
的存储程序——这样的程序不需要任何复合语句 block ,只会分别开始新的/提交当前事务。
在不允许复合语句 block 的存储程序之外,您可以在需要时发出 START TRANSACTION;
和 COMMIT;
语句作为 &。
Do I by all means have to use
BEGIN...END
if I want to use onlyLOOP
? May I just useLOOP
syntax without startingBEGIN...END
?
LOOP
也是一个复合语句 block ,只在存储过程中有效。 没有必要将 LOOP
block 包含在 BEGIN ... END
block 中,尽管这很常见(否则很难执行任何所需的循环初始化)。
在您的情况下,您显然希望从循环构造中将数据插入表中,您将需要:
定义一个使用LOOP
的存储程序;
在外部程序中迭代一个循环,在每次迭代时执行数据库查询;或者
根据 SQL 可以直接操作的集合重新定义您的逻辑。
关于mysql - START TRANSACTION 在 BEGIN ... END 上下文或外部和 LOOP 语法中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12259675/
我刚刚注意到 align-self 属性的一些值,这是我以前从未见过的。什么是start、end、self-start、self-end,它们与有什么区别>flex-start 和 flex-end?
我见过程序员使用公式 mid = start + (end - start) / 2 而不是使用更简单的公式 mid = (start + end) / 2 用于查找数组或列表中的中间元素。 为什么他
我们已经设置了一个小型 AZURE VM(由 Microsoft 提供的普通 Windows 2012 R2 镜像),其中包含一个轻量级 DEMO 应用程序,该应用程序可以与 SQLExpress 和
我在笔记本电脑上安装了Xampp 3.2.1版,之前MySQL在它上面运行得很好,但突然MySQL停止运行,而阿帕奇和其他公司都在运行。当我点击开始MySQL时,它显示这个错误我使用Windows 1
我希望我能解释清楚。 我有自动生成的代码,我希望用 CSS 覆盖它。 这是我希望覆盖的代码示例: #u1150:hover #u1153-4 p {color: red} 重要提示:此代码中的“u”将
在我的 package.json 中,我有以下脚本 block : "scripts": { "start": "react-scripts start",
https://github.com/lodash/lodash/blob/3.7.0/lodash.src.js#L2781 此代码段 start = start == null 中的 +start
上下文 我一直在阅读有关如何将 TUMBLINGWINDOW 函数与 TIMSTAMP BY 子句一起使用的文档,但似乎找不到有关如何计算包含 TUMBLING WINDOW 和 TIMESTAMP
我正在使用 Grunt 运行 Protractor 端到端测试用例。我有以下三个任务(我使用的是 windows 7 机器) webdriver-stop webdriver-start Protra
我正在创建一个简单的Java程序,它具有在窗口生成器的帮助下构建的GUI。 GUI只包含一个按钮。 单击按钮后,启动一个线程,该线程将无限次打印到随机数,直到再次单击同一按钮将其停止为止。 这是我的代
我一直在摆弄创建一个运行渲染的线程,并且我遇到了这种实现它的方法: Class Main implements Runnable { private Thread thread; private bo
我如何在 StartButton 类中编写一个 touchesBegun 命令,它在场景中调用 start() 任何实例本身? 我知道......可能是 OOP 101。但今天我远远超出了我的范围。
关闭。这个问题需要更多 focused .它目前不接受答案。 想改进这个问题?更新问题,使其仅关注一个问题 editing this post . 8年前关闭。 Improve this questi
我的目标是运行多个进程并保存它们的 ProcessName和 Id供以后使用。这是我的代码 [System.Collections.ArrayList]$startedProcesses = @()
我在 8086 汇编方面没有太多经验,我想知道如果您不写起始标签 (start:) 和该标签的结尾,程序会发生什么 (end start)(围绕执行代码的标签)? 所以我的问题是这个标签是否是执行所必
我在 8086 汇编方面没有太多经验,我想知道如果您不写起始标签 (start:) 和该标签的结尾,程序会发生什么 (end start)(围绕执行代码的标签)? 所以我的问题是这个标签是否是执行所必
我想在另一个脚本的 Start() 之前从一个脚本运行 Start()。是否可以?您可以选择脚本的执行顺序吗? 最佳答案 我不太确定 Start() 但您可以配置 Awake 的脚本执行顺序,OnEn
我有一个来自 Unity 文档页面的示例程序,其中包含 IEnumerator Start() ,如下所示,但我想知道如何才能拥有正常的 void Start() > 在同一个脚本中? 我也尝试添加v
正如标题所说,“从机启动”和“从机启动”有什么区别?当我接受DBA面试时,他问了这个问题,我搜索了google但没有找到答案,有人知道吗? 最佳答案 没有区别.. Slave start; 已弃用,现
我有几十个未记录的表,文档说未记录的表在崩溃或不正常关机后会自动截断。 基于此,我需要在数据库启动后检查一些表,看它们是否为“空”并采取一些措施。 简而言之,我需要在数据库启动后立即执行一个过程。 最
我是一名优秀的程序员,十分优秀!