| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2734 人关注过本帖
标题:空值如何处理
只看楼主 加入收藏
zhulei666
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2018-5-19
结帖率:50%
收藏
已结贴  问题点数:20 回复次数:4 
空值如何处理
   SQLStmt = "INSERT INTO zdrun (numbername,hm,score1,shijian) VALUES ('" + Trim(Text8) + "','" + Str(Trim(Text9)) + "'," & 1 & ",'" + Trim(Label37) + "')"
                    SQLExt (SQLStmt)
                    DBDisconnect
                   SQLStmt = "select ifnull(sum(score1),0) ,ifnull(sum(score2),0), ifnull(sum(score3),0) from zdrun   where ( hm = '" + Str(Trim(Text9)) + "')"
                       运行到上面一句,提示  ifnull 不是定义的函数,换成isnull提示参数数量不对,如何处理?想要的结果:如果sum统计的结果是空值,用0代替
                    Set rs = SQLQuery(SQLStmt)
                    Label17 = Text8 & "比赛得分:" & rs.Fields(0) + rs.Fields(1) + rs.Fields(2)
                    Label17.BackColor = vbBlack
                    Label17.Visible = False
                    Timer2.Enabled = True
                    Label4 = Label4 + 1
                    Text9 = ""
                    Text1.SetFocus
                    Text7 = ""
                    Exit Sub
搜索更多相关主题的帖子: 空值 处理 Trim sum Fields 
2018-05-23 17:45
ZHRXJR
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:125
帖 子:1034
专家分:5519
注 册:2016-5-10
收藏
得分:10 
IsNull函数是返回一个变量的布尔值,只有真与假,函数中只有一个变量(参数),判断这个变量的值是否是Unll,如果是返回True,否则返回False
你在SQL语句中使用这个函数,并且函数中有二个参数,当然参数不正确。
这样的SQL语句好像不对吧,我认为是否可以使用判断语句比较好?

请不要选我!!!
2018-05-24 09:29
zhulei666
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2018-5-19
收藏
得分:0 
回复 2楼 ZHRXJR
版主好!使用以下语句是通过的。
    SQLStmt = "select sum(score1) ,sum(score2), sum(score3)  from kdrun   where ( hm = '" + Str(Trim(Text9)) + "')"
                    Set rs = SQLQuery(SQLStmt)
                    If IsNull(rs.Fields(0)) Then
                       a1 = 0
                    Else
                        a1 = rs.Fields(0)
                    End If
                     Set rs = SQLQuery(SQLStmt)
                    If IsNull(rs.Fields(1)) Then
                          a2 = 0
                       Else
                        a2 = rs.Fields(1)
                    End If
                     Set rs = SQLQuery(SQLStmt)
                    If IsNull(rs.Fields(2)) Then
                        a3 = 0
                       Else
                        a3 = rs.Fields(2)
                    End If
                    Label19 = Text8 & "比赛得分:" & a1 + a2 + a3
             ifnull(a,b)这个函数到底有没有。他的作用是 如果a是空值,就返回b,如果a不为空,则返回a。网上介绍的很多。。是没有这个函数还是我的系统有问题。想搞明白。
2018-05-24 10:53
wmf2014
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:216
帖 子:2039
专家分:11273
注 册:2014-12-6
收藏
得分:10 
IFNULL()函数是MySQL常用自带函数,其他SQL里没有这个函数。

能编个毛线衣吗?
2018-05-24 11:20
ZHRXJR
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:125
帖 子:1034
专家分:5519
注 册:2016-5-10
收藏
得分:0 
IfNull函数是MySQL数据库比较重要的函数之一,好像其他数据库中没有这个函数,如果你使用的是MySQL数据库就应该没有问题,否则是不能使用这个函数的。
MySQL IfNull(expr1,expr2)         
如果expr1不是Null,IfNull()返回expr1,否则它返回expr2。IfNull()返回一个数字或字符串值,取决于它被使用的上下文环境。
4楼 wmf2014 的回答是正确的。

请不要选我!!!
2018-05-24 18:40
快速回复:空值如何处理
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.013036 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved