为什么mssql的数据类型和adoquery的不一致?

秋天之落叶 2024-05-27 15:09:27

根据数据类型对照关系,delphi的ftDate应该对应Mssql的Date,但我测试出的结果Date对应24也就是ftwidestring,什么原因?

又比如ftWideString 应该对应nvarchar(n),但Mssql的nvarchar(max)在delphi的结果不是ftwidestring(24)而是ftwidememo(39)。

adoquery1.fields[i].datatype显示nvarchar(n)、date的结果是ftwidestring(24),显示nvarchar(max)的结果是ftwidememo(39)。

...全文
363 6 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
葫芦老四 2024-05-29
  • 打赏
  • 举报
回复

为了避免麻烦,还是建议FireDAC,速度更快,更稳定,关键还跨平台

秋天之落叶 2024-05-30
  • 举报
回复
@葫芦老四 正准备换,以前的不愿动了
hj8090 2024-05-28
  • 打赏
  • 举报
回复

没有遇到过。
是不是和数据库版本有关系?

秋天之落叶 2024-05-28
  • 举报
回复
@hj8090 mssql2014,其他版本没有试过
秋天之落叶 2024-05-27
  • 打赏
  • 举报
回复

使用firedac和unidac控件也没有问题,看来ado已经跟不上时代了。

秋天之落叶 2024-05-27
  • 打赏
  • 举报
回复

为什么刚才的回复消失了?
果然和驱动有关。sqloledb.1不能正确对应,sqlncli11.1就可以正确对应。

5,929

社区成员

发帖
与我相关
我的任务
社区描述
Delphi 开发及应用
社区管理员
  • VCL组件开发及应用社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧