delphi2010中使用sqlitesimpledelphi连接sqlite数据库并解决中

作者:小涵 | 来源:互联网 | 2014-05-28 16:21

阅读: 6469

应女朋友的要求,要写一款销售管理的软件。用于管理服装店每天的销售记录,已及管理服装店的客户,并对客户进行生日提醒因为之前使用C#写过一款家庭管理软件,主要是自己用,所以使用了服务器型数据库MySQL,积攒了一些数据库软件的开发经验。针对这次的软

应女朋友的要求,要写一款销售管理的软件。用于管理服装店每天的销售记录,已及管理服装店的客户,并对客户进行生日提醒

因为之前使用C#写过一款家庭管理软件,主要是自己用,所以使用了服务器型数据库MySQL,积攒了一些数据库软件的开发经验。

针对这次的软件需求决定采用SQLite,因为本人比较鄙视Access,主要是因为不能跨平台,而且在实际需求上SQLite更适合。

因为女朋友要求尽快,那就必须得要快了。。。

这次采用了Delphi+SQLite的结构来写的,之前一直喜欢Delphi,但是没有深入涉足,最重要的原因就是不支持Unicode,Delphi易主之后,开发很活跃,而且全面引进Unicode支持,所以决定重拾Delphi。

首先简单说说SQLite在Delphi中的应用,SQLite是使用纯C写的,本身所有涉及字符串的地方都使用了UTF8(Unicode编码的一种存储传输格式),足可以看出作者的先见之明。如果使用VC(本人的主要开发工具),Unicode的问题几乎不存在,但是因为Delphi引入Unicode不久,很多控件暂时没有Unicode版的,就比如这里的sqlitesimpledelphi,原作者一直没有添加Unicode支持。

刚开始搜集Delphi封装SQLite的控件的时候,因为sqlitesimpledelphi使用比较方便,封装也比较合理,用起来很舒服,但是直到软件Beta版都写出来了,乱码问题才暴露出来。。。所以只能自己改了。

下面就进入正题说说sqlitesimpledelphi在Delphi 2010中的应用

简单说sqlitesimpledelphi最重要的两个类是TSQLiteDatabase和TSQLiteTable

TSQLiteDatabase负责连接数据库,和执行SQL语句。TSQLiteTable负责获取SQL的执行结果。

(先引入SQLiteTable3单元)

1.连接数据库

要连接SQLite数据库,首先创建TSQLiteDatabase实例,在调用构造函数时传入数据库文件名,要使用UTF8Encode函数将文件名字符串编码为UTF8,尤其当数据库名中存在非ASCII码时

例如:database:=TSQLiteDatabase.Create(datafile);

2.执行SQL语句

SQL语句可以简单分为两种:有结果和没结果

对于没有结果的比如UPDATE,INSERT等,调用TSQLiteDatabase实例的ExeSQL函数,传入SQL。这里也要用UTF8Encode将SQL语句编码为UTF8编码

会返回结果的,比如SELECT等,调用TSQLiteDataBase实例的GetTable函数,获得TSQLiteTable实例,通过该实例可以获取数据库的返回结果。一样的,SQL语句要用UTF8Encode进行编码

例如:

strsql:='insert into users(name,adddate)

values('''+user.name+''','''+user.adddate+''')';

database.ExecSQL(UTF8Encode(strsql));

strsql:='select * from users where

name='''+user.name+'''';

table:=database.GetTable(UTF8Encode(strsql));

3.获取SQLite数据库返回的结果

获取结果由GetTable函数返回的TSQLiteTable实例得到

主要使用如下子函数:

Count函数可以获得数据行的行数,FieldIsNull函数可以判断对应的的字段是否为空。Next和Previous函数移动当前的数据行指针。

获取数据字段:

FieldAsString

FieldAsInteger

FieldAsBlob

FieldAsDouble

FieldAsBlobText

上述函数的参数都是对应字段的序号,如果不能确定字段的序号,可以使用函数TSQLiteTable实例的FieldIndex属性获得,属性的参数为字段名字符串,一样的最好用UTF8Encode进行编码。

如果对应的字段值为字符串类型,也可以使用FieldByName属性,传入字段名即可直接获得。

在这里,如果对应的字段为字符串类型,则需要将其使用UTF8Decode进行解码,否则会出现乱码问题,因为SQLite返回的字符串为UTF8编码的,但是sqlitesimpledelphi在封装SQLite函数时将其声明为AnsiString,所以必须手动进行解码。

最后一点重要提示,当使用完GetTable返回的TSQLiteTable实例之后,需要由调用方调用Free函数进行释放,否则会内存泄露,一定要注意。

例如:

table:=database.GetTable(UTF8Encode(strsql));

try

for i:= 1 to table.Count do

begin

// 对每一行检索信息

New(pinfo);

pinfo^.name:=UTF8Decode(table.FieldAsString(table.FieldIndex['name']));

pinfo^.size:=UTF8Decode(table.FieldByName['size']);

。。。。

// 插入到链表中

infolist.Add(pinfo);

table.Next;

end;

finally

table.Free;

end;

3.断开数据库连接,销毁TSQLiteDatabase实例即可

例如:database.Free;

#################################################################################################

如果使用原版的sqlitesimpledelphi,当使用UTF8Decode函数之后,可能依然存在乱码问题,一个表现就是,最后一个汉字显示为框,后面跟一个问号,其他的汉字解码正常。

后来跟踪了一下sqlitesimpledelpi的源代码,从SQLite获取的字符串数据是正确的,但是因为TSQLiteTable的构造函数在读取SQLite返回的UTF8字符串时使用了setstring函数,强行将数据字段进行了转换,引起字符串长度出现错误,所以在UTF8Decode解码时出现了漏解码的问题。

我这里给出一种解决方案,基本修复了该Bug。

1.将TSQLiteTable的构造函数Create中的setstring行注释掉。将thisStringValue的生命从pstring改为PRawByteString。将临时数据ptrValue直接赋值给thisStringValue。

2.相关函数/属性声明修改如下:

function GetFields(I: cardinal): string; 改为function GetFields(I:

cardinal): RawByteString;

function GetFieldByName(FieldName: string): string; 改为function

GetFieldByName(FieldName: string): RawByteString;

function FieldAsString(I: cardinal): string;改为function

FieldAsString(I: cardinal): RawByteString;

property Fields[I: cardinal]: string read GetFields;改为property

Fields[I: cardinal]: RawByteString read GetFields;

property FieldByName[FieldName: string]: string read

GetFieldByName;改为property FieldByName[FieldName: string]:

RawByteString read GetFieldByName;

下面提供的是最新的sqlitesimpledelphi原版和修正版。

原版网盘下载1(UUSHARE)

原版网盘下载2(115网盘)

修正版网盘下载1(UUSHARE)

修正版玩盘下载2(115网盘)

截几张图上来看看:

吐了个 "CAO" !

吐个槽吧,看都看了

delphi通过php连接数据库,delphi2010中使用sqlitesimpledelphi连接sqlite数据库并解决中...相关推荐

  1. 在Android中查看和管理sqlite数据库

    在Android中查看和管理sqlite数据库 在Android中可以使用Eclipse插件DDMS来查看,也可以使用Android工具包中的adb工具来查看.android项目中的sqlite数据库 ...

  2. Xamarin中VS无法连接Mac系统的解决办法

    Xamarin中VS无法连接Mac系统的解决办法 按照以下步骤排查: (1)确认Mac系统中安装Xamarin.iOS开发必备的组件,如Mono.Xamarin.iOS. (2)将Windows和Ma ...

  3. 在java中使用JDBC连接mysql数据库时的服务器时区值无法识别或表示多个时区的问题解决方案

    项目场景: 在java中使用JDBC连接mysql数据库时,报以下的错:Exception in thread "main" java.sql.SQLException: The ...

  4. pycharm中django框架连接mysql数据库

    1.首先下载安装pymysql模块. pip install pymysql 如果出现 timeout 超时可以使用其他的资源下载: pip install 模块名 -i https://pypi.d ...

  5. 【python】取txt文件中的单词存到SQLite数据库,并且从bing词典爬取单词详情

    自己做一个单词词典,打算从bing词典爬单词. 单词怎么来? 取一些英文文本的txt文件,写一个py文件取txt中的单词存到SQLite数据库中. py文件的功能是: 选择出txt文本中的所有单词,正 ...

  6. delphi xe mysql_Delphi XE中使用dbExpress连接MySQL数据库疑难问题解决(对三层的例子配置有帮助)...

    标签: Delphi IDE中包含一个Data Explorer的组件,如下图所示: 该组件基于dbExpress(包含TSQLConnection.TSQLDataSet.TSQLQuery.TSQ ...

  7. delphi xe mysql_Delphi XE中使用dbExpress连接MySQL数据库疑难问题解决

    [用户在使用FineReport报表时,客户端连接SQLSever.Oracle.Informix时常常会出现一些错误,笔者整理了一些疑难问题的解决方案.1. SQLServer数据库连接失败常见解决 ...

  8. java中class.forname连接mysql数据库_数据库链接与 Class.forName()用法详解

    主要功能 Class.forName(xxx.xx.xx)返回的是一个类 Class.forName(xxx.xx.xx)的作用是要求JVM查找并加载指定的类, 也就是说JVM会执行该类的静态代码段 ...

  9. c3p0 0.9.1.2 配套mysql_连接数据库,使用c3p0技术连接MySQL数据库

    读取配置文件连接MySQL数据库 先确认已经导入了 mysql 的驱动包 db.properties driver=com.mysql.jdbc.Driver url=jdbc:mysql://loc ...

最新文章

  1. Zookeeper和Redis实现分布式锁,附我的可靠性分析
  2. 交叉验证的意义和目的_干货:详解原料药的工艺验证
  3. Win10隐藏硬盘分区
  4. 奶粉运营,跑数据三个模板。
  5. 【Java】StopWatch任务执行时间监视器
  6. php curl拉取远程图片
  7. SpringMVC常用的视图接口分类及实现类
  8. ae toolbarcontrol运行时没有_想办法让AE跑起来
  9. JDBC防止SQL注入
  10. 三人表决器逻辑表达式与非_数电实验 | 组合逻辑电路(半加器全加器及逻辑运算)...
  11. 3343:热血格斗场
  12. 项目管理之项目成本管理
  13. gradle7打包libs目录中的jar生成fat jar
  14. 点线面平面设计的概念是什么,分享点线结合构成设计图
  15. wifi找不到路由器可能的排查
  16. C++ 运算符重载与类型转换
  17. C语言中预编译/预处理的使用
  18. win2003下php环境搭建,win2003下搭建PHP环境教程(上) | 网络菜鸟学习园地
  19. mysql输出学生和考试信息_mysql练习题-查询同时参加计算机和英语考试的学生的信息-遁地龙卷风...
  20. 思维之道:管理何必那么虚

热门文章

  1. 世界主要的大半岛有哪些?
  2. aiohttp实战(路飞学城IT)和Event loop is closed问题解决
  3. 苹果WWDC 2020 笔记及广告洞察
  4. java计算机毕业设计研究生推免系统源码+数据库+系统+lw文档+部署
  5. itchat实现微信聊天机器人,定时发送微信消息,消息防撤回,消息监控,自定义回复消息
  6. TFTLCD 液晶界面设计
  7. 【Git】使用手册02--在本地玩转代码
  8. SEO做外链Outreach邮件回复低,怎么办?
  9. Leetcode刷题——每日一题题目汇总
  10. 2020考研数学视频