首页 > 系统相关 >内存表(FDMEMTABLE)

内存表(FDMEMTABLE)

时间:2024-08-18 10:04:42浏览次数:15  
标签:do FDQuery1 FDMemTable1 数据表 FDMEMTABLE 内存 数据

内存表的优点是快,非常快,号称比BDE的clientdataset快很多。
内存表不但快,还可以另存为XML、BIN、CSV等数据。
也可直接作为stream传送。
所以,追求速度的时候,获得数据后即解除锁定的时候,都可能需要用到内存表。
内存表也可用于把来自其他数据库管理系统的数据表存储为FIREDAC的数据表。
内存表的控件是:TFDMEMTABLE。

1、拷贝数据

内存表拷贝另一个表的数据非常简单,使用例子如下:
FDMemTable1.CloneCursor(FDQuery1, False, False);
从另一个数据集中拷贝数据的最快方法是:
FDMemTable1.CopyDataSet(DataSet1, [coStructure, coRestart, coAppend]);
三个参数分别是:包括结构,从第一个数据开始拷贝,添加在数据集的后面。
如果数据来源是firedac的数据集,则还有第三种方式:

复制代码
FDQuery1.FetchOptions.Undirectional := False;//此项应该设置为false,不然数据可能不全;
FDQuery1.Open;
FDQuery1.FetchAll;//获取所有数据
FDMemTable1.Data := FDQuery1.Data;
FDMemTable1.First;
while not FDMemTable1.Eof do begin
  FDMemTable1.Edit;
  .......
  FDMemTable1.Post;
  FDMemTable1.Next;
end;
复制代码

2、内存表操作

内存表的操作和一般表的操作一样,创建表:

复制代码
with FDMemTable1.FieldDefs do begin
  with AddFieldDef do begin
    Name := 'f1';
    DataType := ftInteger;
  end;
  with AddFieldDef do begin
    Name := 'f2';
    DataType := ftString;
    Size := 50;
  end;
end;
复制代码

添加数据:

复制代码
with FDMemTable1 do begin
  Open;
  Append;
  Fields[0].AsInteger := ...;
  Fields[1].AsString := ...;
  Post;
end;
复制代码

3、内存表有什么用?

如果你只是使用FIREDAC,则很多功能都可使用TFDQUERY或TFDSTOREDPROC来实现,除非你有例如只使用纯内存数据或防止锁定等需求时,否则TFDMEMTABLE用处确实不大。

但你可以:

  • 使用TFDMEMTABLE来克隆来自其它数据集的数据;
  • 读取CSV格式的本地数据,然后使用LOCALSQL查询此CSV数据。

4、可回滚的操作

内存表可通过TFDADAPTER连接一个数据表,然后对这个数据表进行添加删除等等操作,所有的操作都是在内存中进行的,如果要把操作写入数据库中的数据表,则只需要ApplyUpdates即可。

这样可以在误操作之间添加一层安全防护。

具体实现方法如下:

(1)、使用TFDCommand的select语句查询数据集。

(2)、使用TFDTableAdapter来连接TFDMemTable和TFDCommand,具体就是其selectcommand设置为TFDCommand,而tfdmemtable的adapter属性设置为TFDTableAdapter。

(3)、对tfdmemtable的所有修改都记录在memtable中,但只要没有提交,就不会反馈到数据集中。如果回滚,则重新从fdcommand中查询的数据替换内存表的数据。

当然,如果只是这样,其特色也不算明显。其实tfdadpter是通过记录修改LOG,并应用修改LOG来实现回滚的,因此,你可以:

在当前行执行RevertRecord来取消当前行的操作。

执行UndoLastChange 来取消最后一次的操作;

执行CancelUpdates来取消所有的操作。

标签:do,FDQuery1,FDMemTable1,数据表,FDMEMTABLE,内存,数据
From: https://www.cnblogs.com/ynmsnc/p/18365325

相关文章

  • 深入理解JVM运行时数据区(内存布局 )5大部分 | 异常讨论
    前言:    JVM运行时数据区(内存布局)是Java程序执行时用于存储各种数据的内存区域。这些区域在JVM启动时被创建,并在JVM关闭时销毁。它们的布局和管理方式对Java程序的性能和稳定性有着重要影响。  一、由以下5大部分组成1.Heap堆区(线程共享)概念:堆是JVM中最大......
  • 面试题:在Java中,JVM(Java虚拟机)的内存模型是如何设计的?请详细解释堆(Heap)、栈(Stack)、方法
    面试题:在Java中,JVM(Java虚拟机)的内存模型是如何设计的?请详细解释堆(Heap)、栈(Stack)、方法区(MethodArea)以及程序计数器(ProgramCounterRegister)的作用和它们之间的关系。更多答案在这里,手机或电脑浏览器就可以打开,面霸宝典【全拼音】.com这里可以优化简历,模拟面试,企业项......
  • 内存泄漏事故(三)
    背景:子线程中,分线程处理然后聚拢future。get但是在futureget的异常处理中,并未抛出异常,只是调用Thread.currentThread().interrupt(),因此主线程要监控这个interrup旗标,从而决定是否抛出异常 1起先 发现没什么用 2旗标的生命周期 子线程跑完后会复位flag,当然这个......
  • 坑!火山引擎云数据库 MySQL 版节点内存只增不减
    火山引擎云数据库说明文档什么是云数据库MySQL版?云数据库MySQL版是火山引擎基于开源数据库MySQL打造的弹性、可靠的在线关系型数据库服务。MySQL实例使用云原生方式部署,结合本地SSD存储类型,提供高性能读写能力;完全兼容MySQL引擎,并提供实例管理、备份恢复、日志管理......
  • C++编程:内存栅栏(Memory Barrier)详解及在多线程编程中的应用
    文章目录0.引言1.什么是内存栅栏?2.为什么需要内存栅栏?本质原因是什么?2.1编译器优化2.2CPU乱序执行3.ARM64和x86架构下的内存栅栏差异3.1x86架构3.2ARM64架构4.代码示例4.1代码解析4.2memory_order_release和memory_order_acquire解释4.3为什么是“releas......
  • C/C++内存管理
    文章目录前言C/C++内存分布C语言内存管理malloccallocreallocreallocarrayfreeC++内存管理new/delete内置类型自定义类型operatornew/operatordelete定位new内存泄漏前言        C++的内存管理是程序设计中的一个关键部分,涉及到内存的分配、使用和释......
  • C++八股文——内存管理(堆和栈的区别? C++内存分区? 内存泄漏?如何避免?什么是智能指针?有哪
    文章目录C++内存管理堆和栈的区别C++内存分区内存泄漏?如何避免?1、什么是内存泄露?2、内存泄漏的分类3、什么操作会导致内存泄露?4、如何防⽌内存泄露?5、智能指针有了解哪些?6、构造函数,析构函数要设为虚函数吗,为什么?什么是智能指针?有哪些种类?new和malloc有什么区别?d......
  • 避免内存溢出
    Redis可以通过以下几种方式来避免内存溢出:设置最大内存限制:可以使用maxmemory配置项来限制Redis的最大内存使用量。当Redis的内存占用超过了设置的最大内存限制时,Redis会根据所配置的内存策略来处理数据,例如删除最近最少使用的键或者拒绝写入请求。使用内存淘汰策略:当Redis的......
  • C++之内存四区
    目录一、内存四区二、程序运行前三、程序运行后四、new操作符一、内存四区在计算机科学中,特别是在c或c++语言编程时,内存通常大致分为四个区域,而不同的区域存放的数据赋予不同的生命周期,给我们更大的灵活编程:代码区:存储程序的可执行代码(二进制代码),也就是程序编译后的......
  • Centos 服务器系统内存故障排查
    该笔记主要记录一下如何排查指定服务器中的指定内存条是否损坏。1.内存故障排查因为68–71软SBC服务器都是Centos7系统,所以我们可以通过以下命令来排查内存是否出现损坏。grep"[0-9]"/sys/devices/system/edac/mc/mc*/csrow*/ch*_ce_count1>count不为0表示有错误2>mc......