【问题标题】:Can I combine SQL statements in SQLite?我可以在 SQLite 中组合 SQL 语句吗?
【发布时间】:2016-11-16 19:19:11
【问题描述】:

我的应用程序代码如下所示:

using SQLite;
using System.Collections.Generic;
using System.Linq;
using Xamarin.Forms;
using System.Diagnostics;

...
...

    db2.Execute("DELETE FROM Phrase" +
                " WHERE PhraseId NOT IN(SELECT Id FROM PhraseSource)");
    db2.Execute("DELETE FROM Phrase" +
                " WHERE Modified < (SELECT Modified FROM PhraseSource WHERE Id = Phrase.PhraseId)");
    db2.Execute("INSERT OR IGNORE INTO Phrase(CategoryId, PhraseId, English, Romaji, Kana, Kanji, Modified)" +
                " SELECT PS.CategoryId, PS.ID, PS.English, PS.Romaji, PS.Kana, PS.Kanji, PS.Modified" +
                " FROM PhraseSource AS PS");

这三个语句可以合二为一吗?如果它们中的任何一个失败,还有一种方法可以回滚吗?我是否需要在语句后面加上“;”如果它们可以组合或使用“go”或类似的东西?

【问题讨论】:

  • 您是否尝试在语句后面加上分号,然后组合字符串?

标签: sqlite xamarin xamarin.forms


【解决方案1】:

sqlite 在单独的事务中执行每个命令。您只需要一次运行它,然后在出现问题时回滚:

 try
 {
     db2.BeginTransaction();
     //executions go here
     db2.Commit();
 }
 catch (Exception ex)
 {
     db2.Rollback();
 }

关于组合查询,如果您想将它们组合起来用于回滚,那么我的示例就可以了,您可以保持代码不变。如果不是,那么只需将它们与分号组合在一个字符串中。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2011-11-16
    • 2015-09-16
    • 1970-01-01
    • 2021-07-01
    • 2012-09-19
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多