[Delphi]Delphi中dbexpress连接3.0以上高版本mysql的问题

项目进行中要用dbexpress连接Mysql,测试数据的时候连接的是RedHat Linux9.0自带的Mysql3.x版本,用Delphi7自带的dbexpress可以连接,没有问题,但是当连接Windows下Mysql4.2时出现,invalid user/password的提示,原先怀疑是libmysql.dll的版本是3.x版本的不适用4.x版本的,换成Mysql自带的libmysql.dll,Delphi提示不能找到libmysql.dll,怀疑dbexpress的DLL:dbexpmysql.dll调用的libmysql.dll的接口高低版本不同造成的,只能用老版本的libmysql.dll。后来查找资料找出下面的解决办法:

1、libmysql.dll仍旧用3.x版本的,并且放在Delphi安装目录的bin下,应用程序发布的时候要打包进去放在程序exe同目录下或系统目录下。

2、由于Mysql4.x以上版本改变了密码认证方式,在用3.x的客户端设置密码的时候、访问的时候出现了密码认证不过的错误,解决这个问题可以用old_password函数把数据库的用户密码修改一下,如:

SET PASSWORD FOR 'user'@'host' = OLD_PASSWORD('newpassword');

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值