Start transaction not working with Revit 2014

本文提供了一个Revit2014中使用按钮点击和空闲事件处理程序来隐藏选定元素的示例代码。代码展示了如何正确地在空闲事件中启动事务,并在其中隐藏所选元素。
You're right, it's not being used correctly.

The Transaction needs to take place inside the Idling event.

The button click handler and Idling event handler should look something like this in Revit 2014:



void revitApp_Idling(object sender, Autodesk.Revit.UI.Events.IdlingEventArgs e)
{
UIApplication uiapp = sender as UIApplication;

UIDocument uidoc = uiapp.ActiveUIDocument;

ElementSet elems = uidoc.Selection.Elements;

if (elems != null)
{
label1.Text = elems.Size.ToString() + " items selected.";
}
else
{
label1.Text = "No elements selected.";
}

if (shouldRun)
{
using (Transaction trans = new Transaction(uidoc.Document, "Hide elements"))
{
trans.Start();
uidoc.Document.ActiveView.HideElements((from Element el in elems select el.Id).ToList());
uidoc.RefreshActiveView();
trans.Commit();
}

shouldRun = false;
}
}

private void button1_Click(object sender, EventArgs e)
{
shouldRun = true;
}

 

<think>好的,我现在要回答用户关于MySQL中START TRANSACTION的作用及用法的问题。首先,我需要回顾用户提供的引用资料,确保信息准确。根据引用[1]和[2],START TRANSACTION和BEGIN是等价的,用于显式开启事务。接下来,用户需要知道具体作用和用法,所以得详细解释事务的概念,比如保证数据一致性、隔离性等。 然后,我需要提到自动提交模式(autocommit),根据引用[4],不管autocommit是0还是1,使用START TRANSACTION后,必须显式提交或回滚。这部分要说明两者的区别,以及如何通过START TRANSACTION临时关闭自动提交。 接着,应该给出使用示例,比如基本用法和带有修饰符的用法,如READ WRITE或READ ONLY,根据引用[2]提到START TRANSACTION支持修饰符,而BEGIN不支持。这里需要举例说明语法结构。 还要强调事务的重要性,比如在转账操作中保证原子性,引用[3]中提到事务回滚,可以举例子说明执行失败时的回滚机制。同时,注意事项部分要提醒用户及时提交或回滚,避免长事务带来的锁竞争,引用[5]中提到的连接数问题可能与此相关,但用户的问题重点在事务本身,所以可能不需要深入这部分。 最后,总结START TRANSACTION的作用,并确保覆盖用户可能关心的点,比如与BEGIN的区别,如何控制事务的提交方式。检查是否有遗漏,比如是否需要提到保存点(SAVEPOINT),但根据引用资料中没有提到,可能暂时不需要涉及。 现在需要确保回答结构清晰,分点说明作用和用法,给出示例,并列出相关注意事项。同时,根据用户要求生成相关问题,可能需要涉及事务隔离级别、自动提交的影响、事务回滚的条件等。</think>### MySQL中`START TRANSACTION`的作用及用法详解 #### 一、`START TRANSACTION`的核心作用 1. **显式开启事务** `START TRANSACTION`用于手动开启一个事务会话,将后续的SQL操作纳入事务管理中,直到通过`COMMIT`提交或`ROLLBACK`回滚[^1][^4]。 例如,转账操作中需保证扣款和入账的原子性: ```sql START TRANSACTION; UPDATE account SET balance = balance - 100 WHERE user_id = 1; UPDATE account SET balance = balance + 100 WHERE user_id = 2; COMMIT; ``` 2. **临时关闭自动提交模式** MySQL默认启用`autocommit`(每条SQL单独提交),执行`START TRANSACTION`后,会**临时关闭**自动提交,直到事务显式结束[^4]。 例如: ```sql SHOW VARIABLES LIKE 'autocommit'; -- 假设结果为ON START TRANSACTION; -- 临时关闭autocommit INSERT INTO logs (message) VALUES ('Test'); ROLLBACK; -- 回滚后数据不生效 ``` 3. **支持事务修饰符** `START TRANSACTION`允许附加修饰符,定义事务特性(`BEGIN`不支持此功能)[^2]: - `READ WRITE`:允许读写(默认) - `READ ONLY`:只读模式(提升查询性能) ```sql START TRANSACTION READ ONLY; -- 后续操作禁止修改数据 SELECT * FROM products WHERE stock > 0; COMMIT; ``` --- #### 二、基本语法及使用示例 1. **基础用法** ```sql START TRANSACTION; -- 执行多条SQL INSERT INTO orders (user_id, amount) VALUES (1, 200); UPDATE inventory SET stock = stock - 1 WHERE product_id = 5; COMMIT; -- 或 ROLLBACK ``` 2. **与保存点结合** ```sql START TRANSACTION; SAVEPOINT sp1; DELETE FROM temp_data WHERE id < 100; ROLLBACK TO sp1; -- 回滚到保存点,继续后续操作 COMMIT; ``` --- #### 三、注意事项 1. **与`BEGIN`的区别** - `START TRANSACTION`是标准SQL语法,支持事务修饰符 - `BEGIN`是MySQL的别名,仅用于兼容性,功能与`START TRANSACTION`相同[^1] 2. **嵌套事务的限制** MySQL不支持嵌套事务。若在事务中再次执行`START TRANSACTION`,会隐式提交前一个事务[^3]。 3. **长事务风险** 未及时提交的事务会长期持有锁,可能导致阻塞。可通过监控`SHOW ENGINE INNODB STATUS`检查事务状态[^5]。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值