ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

关于不同数据库的SQL中比较串的形式为NULL=NULL的返回值不同

2022-06-24 18:01:30  阅读:224  来源: 互联网

标签:no tui pol ls SQL policy 返回值 NULL


Sybase 比较两个字符串的语句 当两个参数都为NULL的时候会返回true;

在SqlServer或者MySQL之类的关系型数据库里面,任一参数为NULL的时候返回值为false。

(关系型数据库的sql里面写NULL=NULL的判断一般返回的是false)

 

在做一些数据库SP迁移的时候注意判空处理

 

例子:

  将Sybase中的SP迁移到SqlServer,这里是一处条件查询语句

  Sybase中原本的写法:

select     @ls_app_declaration_eng = rtrim(app_suit_dec),
                    @ls_app_declaration_chi = rtrim(app_suit_dec)
            from     ui..tui_pol_mst 
            where     comp_no = '041' 
            and     policy_no = @ls_policy_no

  更改成符合SqlServer语法的相同逻辑:

SELECT @ls_app_declaration_eng = rtrim(dbo.tui_pol_mst.app_suit_dec), @ls_app_declaration_chi = rtrim(dbo.tui_pol_mst.app_suit_dec)
            FROM dbo.tui_pol_mst
            WHERE dbo.tui_pol_mst.comp_no = '041' AND ((dbo.tui_pol_mst.policy_no IS NULL AND @ls_policy_no IS NULL) OR (dbo.tui_pol_mst.policy_no = @ls_policy_no))

  这里把原来的

policy_no = @ls_policy_no

  改为了

(dbo.tui_pol_mst.policy_no IS NULL AND @ls_policy_no IS NULL) OR (dbo.tui_pol_mst.policy_no = @ls_policy_no)

  功能上一致同时符合语法

 

另一处涉及到字符串判空的例子:

  Sybase中原本的写法

    select @current_mothly_date = convert(datetime,str(datepart(year,@adt_cycle_date),4)+ "/" + ltrim(str(datepart(month,@adt_cycle_date),2))+"/1") 

  改为SqlServer中的写法

   SELECT @current_mothly_date = CONVERT(datetime2(7), isnull(str(datepart(year, @adt_cycle_date), 4), '') +
                     '/' + isnull(ltrim(str(datepart(month, @adt_cycle_date), 2)), '') + '/1')

  使用了isnull()做判空处理

标签:no,tui,pol,ls,SQL,policy,返回值,NULL
来源: https://www.cnblogs.com/SutsuharaYuki/p/16409808.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有