null 值查询的问题

水煮蛙 2005-12-09 06:01:59
在我做查询时 如select * from tab where a<>''
为null的数据无法查询出!
这样的话我在做查询的时候就必须加入 a is null 或者 a is not null!
请问有没其他好的方法,说说查不出的原理也行!
...全文
251 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
fjb98 2005-12-10
  • 打赏
  • 举报
回复
select * from tab where isnull(a,'')<>''
正解.
如果字段a为null,转换为'',这样才可以使用<>''
回楼上的:因为a为null是被转换成了ascii码的0,所以是用0来进行比较。当然可以用。
if isnul('',1)=0
print 'ok'
else
print 'no'
go
zhangzs8896 2005-12-10
  • 打赏
  • 举报
回复
select * from tab where isnull(a,'')<>''
正解.
如果字段a为null,转换为'',这样才可以使用<>''
水煮蛙 2005-12-10
  • 打赏
  • 举报
回复
谢谢各位!
wfliu 2005-12-10
  • 打赏
  • 举报
回复
select * from tab where a is NULL
loveme2000ok 2005-12-10
  • 打赏
  • 举报
回复
select * from tab where isnull(a,'')<>''
正解
zhangzs8896 2005-12-10
  • 打赏
  • 举报
回复
晕,只是查询,又不会更改数据库内容
fjb98 2005-12-09
  • 打赏
  • 举报
回复
isnull(sal, 0)函数,如果sal的值为空,那么用0来替换。否则,原样sal值。
fjb98 2005-12-09
  • 打赏
  • 举报
回复
isnull()函数,如果sal的值为空,那么用0来替换。否则,原样sal值。
/*说明空值是不能进行比较的*/
if(null=null)
print 'ok'
else
print 'no'
go
所以,不能使用比较运算符。
还有 ''俩引号并不是空值,它的ascii码等于0。可以进行比较。
real_name 2005-12-09
  • 打赏
  • 举报
回复
select * from tab where a is NULL
lw1a2 2005-12-09
  • 打赏
  • 举报
回复
select * from tab where a=NULL
子陌红尘 2005-12-09
  • 打赏
  • 举报
回复
SET ANSI_NULLS
指定在对空值使用等于 (=) 和不等于 (<>) 比较运算符时,这些运算符的 SQL-92 遵从行为。

语法
SET ANSI_NULLS {ON | OFF}

注释
SQL-92 标准要求对空值的等于 (=) 或不等于 (<>) 比较取值为 FALSE。当 SET ANSI_NULLS 为 ON 时,即使 column_name 中存在空值,使用 WHERE column_name = NULL 的 SELECT 语句仍返回零行。即使 column_name 中存在非空值,使用 WHERE column_name <> NULL 的 SELECT 语句仍返回零行。



当 SET ANSI_NULLS 为 OFF 时,等于 (=) 和不等于 (<>) 比较运算符不遵从 SQL-92 标准。使用 WHERE column_name = NULL 的 SELECT 语句返回 column_name 中含有空值的行。使用 WHERE column_name <> NULL 的 SELECT 语句返回列中含有非空值的行。此外,使用 WHERE column_name <> XYZ_value 的 SELECT 语句返回所有非 XYZ 值和非 NULL的行。
子陌红尘 2005-12-09
  • 打赏
  • 举报
回复
select * from tab where isnull(a,'')<>''
PowerBI系列之Power Query专题1.  获取数据 数据源种类介绍和获取Excel数据源输入数据和拷贝数据:创建辅助表解析Json/XML数据格式获取Web网页数据和URL添加动态参数连接数据的四种模式:Import、DirectQuery、Live Connection、Dual双 属于混合模式连接数据库:Sql server、 Mysql(直连但是必须先安装一个mysql插件)DirectQuery直连查询:Sql serverODBC方式获取数据表关联或多个Sql或调用存储过程获取数据SQL中动态传参和自定义函数: sql中使用参数或数据库名称使用参数连接Sharepoint和OneDrive数据源连接Dataset和Dataflow 替换本地数据源为Sharepoint数据源并保留数据处理操作 终止当前数据刷新Loading:Cancel Query数据源设置-重置数据连接凭证PBIDS连接数据源创建和使用报表模块(输入或列表)利用报表模板和参数控制线下报表数据权限DirectQuery启用自动页面刷新和更改检测管理聚合表提高DirectQuery查询性能动态M查询参数提高DirectQuery查询性能添加数据刷新时间 DateTime.LocalNow()和Getdate()2.  数据清洗和M语言M语言和官方文档介绍PowerQuery中查阅M函数:=#shared, Ctrl+Space提示数据清洗之常用技能:提升标题、更改数据类型、保留删除错误或空行,删除重复项、选择列和删除列、填充单元格、合并列、拆分、提取、替换、条件替换、添加自定义列,添加条件列、添加索引列、分组、添加年月日列、追加和合并查询透视和逆透视以及转置合并单元格的Excel文件处理导入文件夹中多Excel文件并合并解决多文件合并中列顺序不一致使用参数和函数批量导入文件 文本中提取中文、英文、数字等处理双引号转义 列拆分详解解决列名改变错误解决列丢失错误动态显示、排序和重命名列为所有列名添加前缀列名字母大写和分隔符调整Trim标题列中的多余空格如何处理load数据错误为什么load的Excel数据有null空行为什么load的Excel数据标题在第二行灵活添加占位符规范同类相似数据数据按多列排序为分组添加Index序号分组内合并诊断工具分析数据处理过程PowerQuery小技巧分享 新冠病例活动轨迹地图标识 

34,590

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧