• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

SQLServer的ISNULL应用举例_sqlserver

sqlserver 搞代码 3年前 (2018-06-16) 105次浏览 已收录 0个评论

ISNULL
使用指定的替换值替换 NULL。

语法
ISNULL ( check_expression , replacement_value )

参数
check_expression

将被检查是否为 NULL的表达式。check_expression 可以是任何类型的。

replacement_value

在 check_expression 为 NULL时将返回的表达式。replacement_value 必须与 check_expresssion 具有相同的类型。

返回类型
返回与 check_expression 相同的类型。

注释
如果 check_expression 不为 NULL,那么返回该表达式的值;否则返回 replacement_value。

示例

http://www.gaodaima.com/35977.htmlsqlserver的ISNULL应用举例_sqlserver

A. 将 ISNULL 与 AVG 一起使用
下面的示例查找所有书的平均价格,用值 $10.00 替换 titles 表的 price 列中的所有 NULL 条目。

USE pubs
GO
SELECT AVG(ISNULL(price, $10.00))
FROM titles
GO

下面是结果集:

————————–
14.24                     

(1 row(s) affected)

B. 使用 ISNULL
下面的示例为 titles 表中的所有书选择书名、类型及价格。如果一个书名的价格是 NULL,那么在结果集中显示的价格为 0.00。

USE pubs
GO
SELECT SUBSTRING(title, 1, 15) AS Title, type AS Type,
   ISNULL(price, 0.00) AS Price
FROM titles
GO

C. 在Full Join情况下使用ISNULL
表A:
tid
uid
anum

表B:
tbid
uid
bnum1
bnum2
需要通过uid全连接两个表:
select a.tid,a.uid,a.anum,b.bnum1,b.bnum2 from a full join b on a.uid=b.uid
全连接会有很多为空的情况,可以使用ISNull来解决,改为:
select isnull(a.tid,b.tid),isnull(a.uid,b.uid),isnull(a.anum,0),isnull(b.bnum1,0),isnull(b.bnum2,0) from a full join b on a.uid=b.uid

再加上一种在asp.net2.0中的综合用法:

<%@ Page Language=”c#” %><!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN” “http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”><html xmlns=”http://www.w3.org/1999/xhtml&#8221; ><head runat=”server”>    <title>Showing all items in a filtered list</title></head><body>    <form id=”form1″ runat=”server”>    <div>        <asp:DropDownList AppendDataBoundItems=”True” AutoPostBack=”True” DataSourceID=”SqlDataSource2″            DataTextField=”state” DataValueField=”state” ID=”DropDownList1″ runat=”server”>            <asp:ListItem Value=””>ALL</asp:ListItem>        </asp:DropDownList><asp:SqlDataSource ConnectionString=”<%$ ConnectionStrings:Pubs %>”            ID=”SqlDataSource2″ runat=”server” SelectCommand=”SELECT DISTINCT [state] FROM [authors]”>        </asp:SqlDataSource>        <br />        <br />        <asp:GridView AutoGenerateColumns=”False” DataSourceID=”SqlDataSource1″            ID=”GridView1″ runat=”server” DataKeyNames=”au_id”>            <Columns>              <asp:BoundField DataField=”au_id” HeaderText=”au_id” ReadOnly=”True” SortExpression=”au_id” />              <asp:BoundField DataField=”au_lname” HeaderText=”au_lname” SortExpression=”au_lname” />              <asp:BoundField DataField=”au_fname” HeaderText=”au_fname” SortExpression=”au_fname” />              <asp:BoundField DataField=”state” HeaderText=”state” SortExpression=”state” />            </Columns>        </asp:GridView>        <asp:SqlDataSource ConnectionString=”<%$ ConnectionStrings:Pubs %>”            ID=”SqlDataSource1″ runat=”server” SelectCommand=”SELECT au_id, au_lname, au_fname, state FROM authors WHERE state = IsNull(@state, state)” CancelSelectOnNullParameter=”False”>            <SelectParameters>                <asp:ControlParameter ControlID=”DropDownList1″ Name=”state” PropertyName=”SelectedValue” Type=”String” />            </SelectParameters>        </asp:SqlDataSource>        </div>    </form></body></html>
 

 

欢迎大家阅读《SQLServer的ISNULL应用举例_sqlserver》,跪求各位点评,若觉得好的话请收藏本文,by 搞代码


喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址