Delphi 项目由Access升级到SQLServer2005的注意事项

本文介绍了Delphi项目从Access数据库迁移至SQLServer2005过程中需要注意的关键事项,包括字段类型调整、日期型查询处理方式、like查询语句用法及默认值字段设置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Delphi项目由Access升级SQLServer2005的过程中的注意事项如下:
1)Access中的自增字段在SQLServer2005中默认是Int型非自增字段,需要将其改为BigInt型自增字段。
    
  2)日期型查询的区别。
     Access中要加#号如:SQLStr := SQLStr +' and buyDate >= #'+FormatDateTime('yyyy-MM-dd',Dtp_BuyDateSHStart.Date)+
         '# and buyDate <= #'+FormatDateTime('yyyy-MM-dd',Dtp_BuyDateSHEnd.Date)+'#';
 SQLServer中要加""号如: SQLStr := SQLStr +' and buyDate >= '''+DateToStr(Dtp_BuyDateSHStart.Date)+
            ''' and buyDate <= '''+DateToStr(Dtp_BuyDateSHEnd.Date)+'''';
 Access中日期参数必须是字符串如:
                         SQLStr := SQLStr +' and regDate >=:a and regDate <=:b';
                          Parameters.ParamByName('a').Value := FormatDateTime('yyyy-MM-dd',Dtp_RegDateStart.Date);
                          Parameters.ParamByName('b').Value := FormatDateTime('yyyy-MM-dd',Dtp_RegDateEnd.Date);
  SQLServer中日期参数可以是字符串也可以是日期如:
                         SQLStr := SQLStr +' and regDate >=:a and regDate <=:b';
                          Parameters.ParamByName('a').Value := Dtp_RegDateStart.Date;
                          Parameters.ParamByName('b').Value := Dtp_RegDateEnd.Date;
                          //Parameters.ParamByName('a').Value := FormatDateTime('yyyy-MM-dd',Dtp_RegDateStart.Date);
                          //Parameters.ParamByName('b').Value := FormatDateTime('yyyy-MM-dd',Dtp_RegDateEnd.Date);
                              
 3)like查询语句。
      Access中like和参数后可以有空格也可以没有如:SQLStr:='select * from customertb where cardNum like:a '
      SQLServer中like和参数后必须有空格如:SQLStr:='select * from customertb where cardNum like :a '

4)对于默认值字段需要重新指定。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值