用 TFDSQLiteBackup 控件, 两三行代码即可完成 Sqlite 数据库的备份.
procedure TForm1.Button1Click(Sender: TObject); begin {先初始化目标} FDConnection1.DriverName := 'SQLite'; FDConnection1.Params.Add('Database=C:\Temp\FDDemo_Back.sdb'); //如果不指定这个路径, 就是备份到内存 FDConnection1.Open(); {备份 C:\Temp\FDDemo.sdb} FDSQLiteBackup1.DriverLink := FDPhysSQLiteDriverLink1; FDSQLiteBackup1.Database := 'C:\Temp\FDDemo.sdb'; //支持 Url FDSQLiteBackup1.DestDatabaseObj := FDConnection1.CliObj; FDSQLiteBackup1.Backup; end;
经过一些操作后, 数据库可能会有碎片, 这时可通过 TFDSQLiteValidate 控件的 Sweep 方法执行优化.
{常见代码} begin FDSQLiteValidate1.DriverLink := FDPhysSQLiteDriverLink1; FDSQLiteValidate1.Database := 'C:\Temp\FDDemo.sdb'; FDSQLiteValidate1.Sweep; //也可以通过连接参数 auto_vacuum = FULL; (0:NONE, 1:FULL, 2: INCREMENTAL) 指定自动清理 end;
为避免数据库操作中的失误, 可通过事务(Transaction) 来回滚; 它应该是被普遍使用的手段.
{常见代码} begin FDConnection1.StartTransaction; //开始一个事务 try {可能会出错的代码} FDConnection1.Commit; //提交 except FDConnection1.Rollback; //回滚 end; end;
分类:
数据库编程
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
2011-05-22 给 "水桶" 同学解释一下 "流" 类中的 Seek() 方法
2009-05-22 时间与相关类型(3): TFileTime、TSystemTime 及 DOS 时间
2009-05-22 时间与相关类型(2) - TDate、TTime、TTimeStamp
2009-05-22 时间与相关类型(1) - TDateTime 与 Double
2008-05-22 WinAPI: InvertRect - 翻转矩形中像素的颜色
2008-05-22 WinAPI: OffsetRect - 移动矩形
2008-05-22 WinAPI: IntersectRect、SubtractRect、UnionRect - 用两个矩形合成一个新的矩形