十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
假设表有4个字段为FIELD1-FIELD4
同心ssl适用于网站、小程序/APP、API接口等需要进行数据传输应用场景,ssl证书未来市场广阔!成为创新互联公司的ssl证书销售渠道,可以享受市场价格4-6折优惠!如果有意向欢迎电话联系或者加微信:13518219792(备注:SSL证书合作)期待与您的合作!
只有有一个字段为空就删除
DELETE
BIAO
WHERE
FIELD1
IS
NULL
OR
FIELD2
IS
NULL
OR
FIELD3
IS
NULL
OR
FIELD4
IS
NULL
所有字段为空才删除:
DELETE
BIAO
WHERE
FIELD1
IS
NULL
and
FIELD2
IS
NULL
and
FIELD3
IS
NULL
and
FIELD4
IS
NULL
第二个问题,看不出您的日期字段格式是什么格式,也没看清您想要什么样的结果,相距的时间是什么?是天,还是月,还是年?
假设您的日期字段是DATETIME类型,我列举了您需求的多种情况:
--如果是要几年或几天或几个月,下面三行分别得到总年数或总月数或总天数(如果是一年就会得到365或366)
select
datediff(year,注册时间,getdate())--总年数(整数)
select
datediff(month,注册时间,getdate())--总月数(整数)
select
datediff(day,注册时间,getdate())--总天数(整数)
--如果是要得到几年和几个月和几天的组合结果(与上面的总数结果不同,这里日不会过31,月不会过12,年月日结果是进位关系),按下面的方法得到.
select
cast(datename(year,getdate()-注册时间)-1900
as
varchar)+'年'
+cast(datename(month,getdate()-注册时间)-1
as
varchar)+'个月'
+cast(datename(day,getdate()-注册时间)-1
as
varchar)+'日'
注意:上面两例中,注册时间是您的字段名,GETDATE()是求出的当前日期和时间,如果是别的什么时间字段,如最后登录时间,直接用登录时间替换GETDATE()就行了.
=====================
sql
server中的空值就是这样的(NULL),您说的,应该即不是空值,也不是零长度的字符串,也不是数值零.
所以,当不是空值时,您必须要告诉我们字段是什么类型的.
如果您的字段是VARCHAR,NVARCHAR或CHAR类型的,
那么可能就有三种情况,
1.是空格.
2.是零长度字串.
3.是不可显示的乱字符.
但无论哪一种情况情况,只要是字符型的,用您的语句都不会报错,就是这一句:
delete
biao
where
field1=''
除非字段或表名有错误.
建议:
如果是字符型字段(VARCHAR,NVARCHAR或CHAR类型等)
delete
biao
where
RTRIM(field1)=''
如果是数值型字段(INT,FLOAT,DECIMAL等类型,甚至日期型)都可以用下面的语句删除0值.
delete
biao
where
RTRIM(field1)=0
就是说:
如果不是空值(NULL),就必须要知道字段是什么类型才能确定语法格式.
====================
==============================
最后提醒您,我费了好长时间回答您的问题,为了使用我们下次还有这么大的积极性,最少要加到200分才行啊!
SQLSERVER NULL和空字符串的区别 使用NULL是否节省空间
对于varchar数据类型,无论是空字符串还是NULL值都不占用任何空间
对于char数据类型,无论是空字符串还是NULL值都占用空间,所占用空间大小取决于建表时候指定的char数据类型的大小
insert into ta1_sql (col1,col2) select col1,'' from ta2_oracle
如果确定这个字段都是空的,语句里直接赋值吧,别写字段名了
你先粘贴到记事本里面,保存为文本文件再导入,就可以避免执行问题
""是占用存储空间的 而且""这个是一个字符 是存储在数据库中的
只有NULL 才是不占存储空间的且没有数据