ooooh 2021-11-05 10:17 采纳率: 33.3%
浏览 19

Sqlite update如何用事务提交?

Sqlite update很慢,网上搜可以用事务提交更新,但不知在哪插入starttransaction,commit?

with FDQuery1 do
      begin
        Close;
        SQL.Clear;
        for I := 0 to stringgrid1.RowCount - 1 do
        begin
          str:=StringGrid1.Cells[1,i];
          SQL.Text:='select 资产号,更新时间 from 台账 where 资产号=''' + str + '''';
          Open();
          if RecordCount>0 then
          begin
            s:=stringgrid1.cells[28,i];    //更新时间
            if s<>FieldByName('更新时间').AsString then     //当清册更新时间有变时才更新
            begin
              SQL.Clear;
              SQL.Add('update 台账 set 实物ID=''' + stringgrid1.cells[2,i] + '''');
              for j := 3 to 32 do
                SQL.Add(',' + StringGrid1.Columns[j].Header + '=''' + StringGrid1.cells[j,i] + '''');
              SQL.Add(' where 资产号=''' + str + '''');
              ExecSQL;
            end;
          end
          else                                          //不存在添加
          begin
            SQL.Clear;
            SQL.Add('insert into 台账(资产号,实物ID,名称,规格,地址,状态,备注,成本中心,使用部门,资产管理员,资产保管员,责任人,制造商,数量,计量单位,原值,净值,资产分类,资产目录,作业成本类别,工程编号,工程名称,附属设备及附件,源资产号,老资产号,资本化日期,创建日期,更新时间,基站ID,基站名称,是否客户端资产,客户名称)');
            SQL.Add(' values(:资产号,:实物ID,:名称,:规格,:地址,:状态,:备注,:成本中心,:使用部门,:资产管理员,:资产保管员,:责任人,:制造商,:数量,:计量单位,:原值,:净值,:资产分类,:资产目录,:作业成本类别,:工程编号,:工程名称,:附属设备及附件,:源资产号,:老资产号,:资本化日期,:创建日期,:更新时间,:基站ID,:基站名称,:是否客户端资产,:客户名称)');
            for j := 1 to 32 do
              Params[j - 1].Value:=StringGrid1.cells[j,i];
            ExecSQL;
          end;
          Application.ProcessMessages;
          ProgressBar1.Value:=ProgressBar1.Value + c;
          Text3.Text:='进度:' + (i + 1).ToString;
        end;
      end;
  • 写回答

1条回答 默认 最新

  • 唯一的小彬哥 2021-11-05 15:10
    关注

    你可能没明白事务的概念,哪怕一条SQL的执行就意味着事务的开始。更新慢,所谓的通过事务的形式是解决不了的。你update慢,如果不是更新的数据特别巨大的情况。意味着着搜寻效率低效这种情况首先看看是否有合适索引。

    评论

报告相同问题?

问题事件

  • 创建了问题 11月5日

悬赏问题

  • ¥15 python变量和列表之间的相互影响
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
  • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
  • ¥15 CSAPPattacklab
  • ¥15 一直显示正在等待HID—ISP
  • ¥15 Python turtle 画图
  • ¥15 关于大棚监测的pcb板设计
  • ¥15 stm32开发clion时遇到的编译问题
  • ¥15 lna设计 源简并电感型共源放大器
  • ¥15 如何用Labview在myRIO上做LCD显示?(语言-开发语言)