A. sql 語句查出的數據為空,怎麼用個if語句判斷,然後作出處理。
oracle:改為
select nvl(sum(price),0),userName
from food join diningcar on food.foodId=diningcar.foodId
join users on diningcar.userId=users.userId
where (comment=0 or comment=-1) and userName='zq'
group by userName
sqlserver改為
select isnull(sum(price),0),userName
from food join diningcar on food.foodId=diningcar.foodId
join users on diningcar.userId=users.userId
where (comment=0 or comment=-1) and userName='zq'
group by userName
B. 查看sql資料庫中對應的列是否為空值的語句
select 列名 from 表名 where 列名 is null
C. 用sql查詢某個欄位為空時,用「 IS NULL」,為何查不出結果
因為一般情況下將任何值(包括NULL本身)與NULL做比較的時候,都會返回UnKnown。
而在查詢表達式中(比如where與having中),UnKnown會視為false。所以select*from表where欄位=null查不到正確的結果。
在sql中要查詢某列值為null的所有結果集時,查詢條件應該這樣寫:select*from表where欄位isnull。
(3)sql查出數據為空用什麼語句擴展閱讀:
注意事項
並不是在所有場情下UnKnown都會視為false來處理,在check約束中,UnKnown就會視為true來處理。這就是為什麼設置某個欄位的值必須大於等於0的情況下,還可以往該欄位中插入Null值;
那是因為在check約束中null>=0的邏輯結果UnKnown會被當作true來處理。需要注意的是,在分組子句與排序子句中,sql視null是相等的,即:
1、GROUPBY會把所有NULL值分到一組。
2、ORDERBY會把所有NULL值排列在一起。
結構化查詢語言包含6個部分:
1、數據查詢語言(DQL:Data Query Language):其語句,也稱為「數據檢索語句」,用以從表中獲得數據,確定數據怎樣在應用程序給出;
保留字SELECT是DQL(也是所有SQL)用得最多的動詞,其他DQL常用的保留字有WHERE,ORDER BY,GROUP BY和HAVING。這些DQL保留字常與其它類型的SQL語句一起使用。
2、數據操作語言(DML:Data Manipulation Language):其語句包括動詞INSERT、UPDATE和DELETE。它們分別用於添加、修改和刪除。
3、事務控制語言(TCL):它的語句能確保被DML語句影響的表的所有行及時得以更新。包括COMMIT(提交)命令、SAVEPOINT(保存點)命令、ROLLBACK(回滾)命令。
4、數據控制語言(DCL):它的語句通過GRANT或REVOKE實現許可權控制,確定單個用戶和用戶組對資料庫對象的訪問。某些RDBMS可用GRANT或REVOKE控制對表單個列的訪問。
5、數據定義語言(DDL):其語句包括動詞CREATE,ALTER和DROP。在資料庫中創建新表或修改、刪除表(CREAT TABLE 或 DROP TABLE);為表加入索引等。
6、指針控制語言(CCL):它的語句,像DECLARE CURSOR,FETCH INTO和UPDATE WHERE CURRENT用於對一個或多個表單獨行的操作。
D. sql語句查出的數據為空,怎麼用個if語句判斷,然後作出處理
可以實現,以sql server為例看:
if not exists(select userName from food join diningcar on food.foodId=diningcar.foodId join users on diningcar.userId=users.userId where (comment=0 or comment=-1) and userName='zq' group by userName)
select 0,'zq'
else
select sum(price),userName from food join diningcar on food.foodId=diningcar.foodId join users on diningcar.userId=users.userId where (comment=0 or comment=-1) and userName='zq' group by userName
方法二:
select isnull(sum(price),0),userName
from food join diningcar on food.foodId=diningcar.foodId
join users on diningcar.userId=users.userId
where (comment=0 or comment=-1) and userName='zq'
group by userName
不知道是不是你想要的結果,但是我有個疑問,你為什麼不在程序里進行判斷,而是要讓sql語句判斷呢?
E. 怎麼查詢資料庫中某一個欄位為空的數據
1、打開您操作資料庫的可視化工具(我現在用的是DbVisualizer)。
2、在sql窗口中編寫查詢語句,我之前遇到這個問題的時候,找了好久都是說使用value,nvl,decode等等函數去操作,這樣用法確實可以,但是不適用於我遇到的這個情況,那些方法只適用於存在此條記錄,但是某一欄位可能為null的情況。
3、在sql窗口中可使用迂迴的方式進行查詢設定默認值。可先查詢是否含有此條記錄存在,如果不存在就給查詢的欄位設定默認值,如果存在就使用子查詢去取該欄位真正的值。
F. sql server的sql語句怎麼判斷一個欄位是否為空
使用 is null 或 is not null 來處理列的空值。
語法為:
列名 is null (欄位為空返回true ,不為空返回 false)
列名 is not null (欄位為空返回false,不為空返回 true)
例如:
select case when a is null then 1 else 0 end from aaa
語法大意:如果a列 為空顯示1,不為空顯示0。
(6)sql查出數據為空用什麼語句擴展閱讀:
注意事項
欄位內容為空有兩種情況
1.為null
2.為字元串的空''
語句如下:
select * from table where column is null or trim(column)=''
這樣就可以排除欄位內容為null、''的。
判斷某個欄位不為空
select * from table where trim(column) != ''
曾經嘗試判斷null:is not null.但是不起作用,放棄。。。直接 trim(column) != '' 就能解決。
G. sql中求表中列值為空的列,能通用的,思路和具體語句都寫出來觀摩一下,
Select * from 表名 where 列名 is null
以上的語句是查出該列為空的所有信息
H. SQL語句:如何查詢出一張表中所有欄位裡面內容為空
是mysql嗎 可以這樣 比如你有一個文本 文本里有兩列數據用逗號隔開 然後你就可以用 load data infile '文件路徑' into table tablename fields terminated by ',' lines terminated by '\n' (col1,col2) 別的欄位不管就好了,當然你的表設計時候就需要默認為null
I. sql語句模糊查詢怎麼查到空內容的數據
這個好辦啊。改成下列語句形式:
goodsname like '%' and checked like '%' 改為
nvl(goodsname,'0') like '%' and nvl(checked,'0') like '%'
J. 如何用SQL語句來判斷查詢結果為空
select count(*) from 表 where username=我輸入的帳號 and userpass=我輸入的密碼 用count(*)來實現,較簡單一些,直接取到結果,如果結果>0,就證明賬號和密碼正確服,如果=0則錯誤.