Replacing null with zero

2019-02-27 12:59发布

问题:

Hi I have following select command in SQL Server. I am trying to change it so if b.bId is null i want to assign it 0 value. So it displays 0 in the field.

select top 1
    a.sId
   ,b.bId  
    from tlocal a
    left outer join ts b on (b.id=a.mainId)
    where 
    a.id=@xId; 

Please let me know how to modify. Thanks

回答1:

You can use the ISNULL function like so:

ISNULL(b.bId, 0) bId


回答2:

Or you can use the COALESCE Function

COALESCE(b.bId, 0) AS bId

Performance: ISNULL vs. COALESCE



回答3:

As another alternative you could execute this sql at your ts table

update ts
set id = ''
where id is null