⑴ sql Server處理空值操作中的3大問題有哪些
轉:
不管系統計劃得有多好,空數據值的問題總是存在。
本文探討了在SQL Server中處理這些值時涉及的3個問題:計數、使用空表值以及外鍵處理。
用COUNT(*)處理空值
大多數集合函數都能在計算時消除空值;COUNT函數則屬於例外。對包含空值的一個列使用COUNT函數,空值會從計算中消除。但假如COUNT函數使用一個星號,它就計算所有行,而不管是否存在空值。
如果希望COUNT函數對給定列的所有行(包括空值)進行計數,請使用ISNULL函數。ISNULL函數會將空值替換成有效的值。
事實上,對集合函數來說,如果空值可能導致錯誤結果,ISNULL函數就非常有用。記住在使用一個星號時,COUNT函數會對所有行進行計算。下例演示了空值在AVG和COUNT集合函數中的影響:
SET NOCOUNT恰當使用空表值
SQL Server可能出現一種特殊情況:在引用父表的一個表中,因為不允許空值,所以聲明引用完整性(DRI)可能不會得到強制。即使父表不包含空值,在子表引用了父表主鍵約束或惟一約束的列中,也可能包含空值。
假如來自父表的值目前未知,就不會有任何問題。例如,父表可能是一個地址表,而子表可能包含聯系信息。由於許多原因,可能暫時不知道要傳給父表的聯系地址。這是一種基於時間的問題,空值在其中或許是合適的。
如下例所示,我們創建父表,並在其中插入兩個值。
SET NOCOUNT以下代碼則創建子表,並在引用父表的列中插入一個空值。
CREATE TABLE Child (pkey1 INT IDENTITYCONSTRAINT pkChild PRIMARY KEY,Parentpkey1 INT NULLCONSTRAINT fkChildParent FOREIGN KEYREFERENCES Parent(pkey1),col1 INT NULL) GOINSERT Child (Parentpkey1, col1) VALUES (null,2)GO
但在以下代碼中,要同時從父表和子表選擇值。雖然父表不包含空值,但在子表引用了父表的那個列中,將允許一個空值。
然後丟棄所有表,清除這個演示所用的資料庫對象。
SELECT*FROMChildGOSELECT*FROMParentGODROPTABLEChild,ParentGO
在可以為空的外鍵中檢查數據的有效性
如果由兩個列共同組成主鍵,而且一個子表將主鍵作為可為空值的外鍵來繼承,就可能得到錯誤的數據。可在一個外鍵列中插入有效的值,但在另一個外鍵列中插入空值。然後,可添加一個數據表檢查約束,在可為空的外鍵中檢查數據的有效性。
任何多列外鍵都可能遇到同樣的問題。所以,你需要添加一個檢查約束來檢測異常。最初,檢查約束將檢查構成外鍵的所有列中可能為空的值。檢查約束還要檢查這些列中不能為空的值。如兩個檢查都通過,問題就解決了。以下示範腳本展示了這樣的一個異常源碼天空
⑵ SQL資料庫的簡單操作
一 簡單查詢 簡單的Transact SQL查詢只包括選擇列表 FROM子句和WHERE子句 它們分別說明所查詢列 查詢的 表或視圖 以及搜索條件等 例如 下面的語句查詢testtable表中姓名為 張三 的nickname欄位和email欄位 SELECT nickname emailFROM testtableWHERE name= 張三 (一)選擇列表 選擇列表(select_list)指出所查詢列 它可以是一組列名列表 星號 表達式 變數(包括局部變數和全局變數)等構成 選擇所有列例如 下面語句顯示testtable表中所有列的數據 SELECT *FROM testtable 選擇部分列並指定它們的顯示次序查詢結果集合中數據的排列順序與選擇列表中所指定的列名排列順序相同 例如 SELECT nickname emailFROM testtable 更改列標題在選擇列表中 可重新指定列標題 定義格式為 列標題=列名列名 列標題如果指定的列標題不是標準的標識符格式時 應使用引號定界符 例如 下列語句使用漢字顯示列標題 SELECT 昵稱=nickname 電子郵件=emailFROM testtable 刪除重復行SELECT語句中使用ALL或DISTINCT選項來顯示表中符合條件的所有行或刪除其中重復的數據行 默認為ALL 使用DISTINCT選項時 對於所有重復的數據行在SELECT返回的結果集合中只保留一行 限制返回的行數使用TOP n [PERCENT]選項限制返回的數據行數 TOP n說明返回n行 而TOP n PERCENT時 說明n是表示一百分數 指定返回的行數等於總行數的百分之幾 例如 SELECT TOP *FROM testtable SELECT TOP PERCENT *FROM testtable(二)FROM子句 FROM子句指定SELECT語句查詢及與查詢相關的表或視圖 在FROM子句中最多可指定 個表或視圖 它們之間用逗號分隔 在FROM子句同時指定多個表或視圖時 如果選擇列表中存在同名列 這時應使用對象名限定這些列所屬的表或視圖 例如在usertable和citytable表中同時存在cityid列 在查詢兩個表中的cityid時應使用下面語句格式加以限定 SELECT username citytable cityidFROM usertable citytableWHERE usertable cityid=citytable cityid在FROM子句中可用以下兩種格式為表或視圖指定別名 表名 as 別名表名 別名例如上面語句可用表的別名格式表示為 SELECT username b cityidFROM usertable a citytable bWHERE a cityid=b cityidSELECT不僅能從表或視圖中檢索數據 它還能夠從其它查詢語句所返回的結果集合中查詢數據 例如 SELECT a au_fname+a au_lnameFROM authors a titleauthor ta(SELECT title_id titleFROM titlesWHERE ytd_sales> ) AS tWHERE a au_id=ta au_idAND ta title_id=t title_id此例中 將SELECT返回的結果集合給予一別名t 然後再從中檢索數據 (三)使用WHERE子句設置查詢條件 WHERE子句設置查詢條件 過濾掉不需要的數據行 例如下面語句查詢年齡大於 的數據 SELECT *FROM usertableWHERE age> WHERE子句可包括各種條件運算符 比較運算符(大小比較) > >= = < <= <> !> !<范圍運算符(表達式值是否在指定的范圍) BEEEN…AND…NOT BEEEN…AND…列表運算符(判斷表達式是否為列表中的指定項) IN (項 項 ……)NOT IN (項 項 ……)模式匹配符(判斷值是否與指定的字元通配格式相符):LIKE NOT LIKE空值判斷符(判斷表達式是否為空) IS NULL NOT IS NULL邏輯運算符(用於多條件的邏輯連接) NOT AND OR 范圍運算符例 age BEEEN AND 相當於age>= AND age<= 列表運算符例 country IN ( Germany China ) 模式匹配符例 常用於模糊查找 它判斷列值是否與指定的字元串格式相匹配 可用於char varchar text ntext datetime和 *** alldatetime等類型查詢 可使用以下通配字元 百分號% 可匹配任意類型和長度的字元 如果是中文 請使用兩個百分號即%% 下劃線_ 匹配單個任意字元 它常用來限製表達式的字元長度 方括弧[] 指定一個字元 字元串或范圍 要求所匹配對象為它們中的任一個 [^] 其取值也[] 相同 但它要求所匹配對象為指定字元以外的任一個字元 例如 限制以Publishing結尾 使用LIKE %Publishing 限制以A開頭 LIKE [A]% 限制以A開頭外 LIKE [^A]% 空值判斷符例WHERE age IS NULL 邏輯運算符 優先順序為NOT AND OR(四)查詢結果排序 使用ORDER BY子句對查詢返回的結果按一列或多列排序 ORDER BY子句的語法格式為 ORDER BY {column_name [ASC|DESC]} [ …n]其中ASC表示升序 為默認值 DESC為降序 ORDER BY不能按ntext text和image數據類型進行排序 例如 SELECT *FROM usertableORDER BY age desc userid ASC另外 可以根據表達式進行排序 二 聯合查詢 UNION運算符可以將兩個或兩個以上上SELECT語句的查詢結果集合合並成一個結果集合顯示 即執行聯合查詢 UNION的語法格式為 select_statementUNION [ALL] selectstatement[UNION [ALL] selectstatement][…n]其中selectstatement為待聯合的SELECT查詢語句 ALL選項表示將所有行合並到結果集合中 不指定該項時 被聯合查詢結果集合中的重復行將只保留一行 聯合查詢時 查詢結果的列標題為第一個查詢語句的列標題 因此 要定義列標題必須在第一個查詢語句中定義 要對聯合查詢結果排序時 也必須使用第一查詢語句中的列名 列標題或者列序號 在使用UNION 運算符時 應保證每個聯合查詢語句的選擇列表中有相同數量的表達式 並且每個查詢選擇表達式應具有相同的數據類型 或是可以自動將它們轉換為相同的數據類型 在自動轉換時 對於數值類型 系統將低精度的數據類型轉換為高精度的數據類型 在包括多個查詢的UNION語句中 其執行順序是自左至右 使用括弧可以改變這一執行順序 例如 查詢 UNION (查詢 UNION 查詢 )三 連接查詢 通過連接運算符可以實現多個表查詢 連接是關系資料庫模型的主要特點 也是它區別於其它類型資料庫管理系統的一個標志 在關系資料庫管理系統中 表建立時各數據之間的關系不必確定 常把一個實體的所有信息存放在一個表中 當檢索數據時 通過連接操作查詢出存放在多個表中的不同實體的信息 連接操作給用戶帶來很大的靈活性 他們可以在任何時候增加新的數據類型 為不同實體創建新的表 爾後通過連接進行查詢 連接可以在SELECT 語句的FROM子句或WHERE子句中建立 似是而非在FROM子句中指出連接時有助於將連接操作與WHERE子句中的搜索條件區分開來 所以 在Transact SQL中推薦使用這種方法 SQL 標准所定義的FROM子句的連接語法格式為 FROM join_table join_type join_table[ON (join_condition)]其中join_table指出參與連接操作的表名 連接可以對同一個表操作 也可以對多表操作 對同一個表操作的連接又稱做自連接 join_type 指出連接類型 可分為三種 內連接 外連接和交叉連接 內連接(INNER JOIN)使用比較運算符進行表間某(些)列數據的比較操作 並列出這些表中與連接條件相匹配的數據行 根據所使用的比較方式不同 內連接又分為等值連接 自然連接和不等連接三種 外連接分為左外連接(LEFT OUTER JOIN或LEFT JOIN) 右外連接(RIGHT OUTER JOIN或RIGHT JOIN)和全外連接(FULL OUTER JOIN或FULL JOIN)三種 與內連接不同的是 外連接不只列出與連接條件相匹配的行 而是列出左表(左外連接時) 右表(右外連接時)或兩個表(全外連接時)中所有符合搜索條件的數據行 交叉連接(CROSS JOIN)沒有WHERE 子句 它返回連接表中所有數據行的笛卡爾積 其結果集合中的數據行數等於第一個表中符合查詢條件的數據行數乘以第二個表中符合查詢條件的數據行數 連接操作中的ON (join_condition) 子句指出連接條件 它由被連接表中的列和比較運算符 邏輯運算符等構成 無論哪種連接都不能對text ntext和image數據類型列進行直接連接 但可以對這三種列進行間接連接 例如 SELECT p pub_id p pub_id p pr_infoFROM pub_info AS p INNER JOIN pub_info AS p ON DATALENGTH(p pr_info)=DATALENGTH(p pr_info)(一)內連接內連接查詢操作列出與連接條件匹配的數據行 它使用比較運算符比較被連接列的列值 內連接分三種 等值連接 在連接條件中使用等於號(=)運算符比較被連接列的列值 其查詢結果中列出被連接表中的所有列 包括其中的重復列 不等連接 在連接條件使用除等於運算符以外的其它比較運算符比較被連接的列的列值 這些運算符包括> >= <= < !> ! 和> 自然連接 在連接條件中使用等於(=)運算符比較被連接列 lishixin/Article/program/SQLServer/201311/21994 <!-- /和 -->
⑶ sql 查詢時有空值返回0怎麼寫
根據資料庫的不同,採用如下不同的方法:
oracle
將空值返回0用如下語句:
select nvl(欄位名,0) from 表名;sqlserver
將空值返回0用如下語句:
方法一:select isnull(欄位名,0) from 表名;
字元型:select isnull(mycol,'0') as newid from mytable
整型:select isnull(mycol,0) as newid from mytable
方法二:case ??end
case when columnName is null then 0 else columnName endmysql
將空值返回0用如下語句:
select ifnull(欄位名,0) from 表名;
拓展資料:
SQL SELECT 語句
SELECT 語句用於從表中選取數據。
結果被存儲在一個結果表中(稱為結果集)。
SQL SELECT 語法
SELECT 列名稱 FROM 表名稱。
⑷ sql插入空值
第一個是錯誤的。因為在查詢分析器里無法插入語句。
第二個是對的,第一個null是插入空的字元串,而第二個是插入的空值。
⑸ sql語句怎麼插入一條空記錄
有時候我們在寫sql語句的時候,想插入一條空記錄,怎麼插入呢,下面來分享一下方法
第一步我們在閉巧資料庫中建立一張test表,可以看到test表中有id,name,second三個欄位,id設置為自動遞增,
第二步輸入「insertintotest(name,second)values(null,null)」sql語句塌段,點擊運行,
第三步運行之後,可以看到test表插入了一條空記錄,
第四步我們也可以插入一條記錄某個欄位為空值,輸轎衫鍵入「insertintotest(name,second)values(null,88)」sql語句,點擊運行,
第五步運行之後,可以看到插入了一條記錄,name值為空,
第六步也可以通過「insertintotest(name)values('張三')」語句,插入一條記錄,除開name欄位,其它欄位值為空,
⑹ 如何往資料庫插入欄位為空值的sql語句
1、首先打開sql server管理系統工具,使用資料庫賬號登錄到數據管理系統。
⑺ sql 如何查詢 空值的欄位
sql查詢空值的欄位寫法:SELECT A.欄位 FROM student A WHERE A.欄位 LIKE'% %' (student為表名)
查詢類似空值的寫法:
1、查詢名稱有退格鍵:select * from t_bd_item_info where charindex(char(8),item_name) > 0 go
2、查詢名稱有製表符tab:select * from t_bd_item_info where charindex(char(9),item_name) > 0 go
3、查詢名稱有換行:select * from t_bd_item_info where charindex(char(10),item_name) > 0 go
4、查詢名稱有回車:select * from t_bd_item_info where charindex(char(13),item_name) > 0 go
5、查詢名稱的空格(前空格、後空格、所有空格):select * from t_bd_item_info where isnull(charindex(' ',item_name),0) > 0go
6、查詢名稱的單引號:select * from t_bd_item_info where charindex(char(39),item_name) > 0 go
7、查詢名稱的雙單引號:select * from t_bd_item_info where charindex(char(34),item_name) > 0 go
(7)sql連接有空值的操作擴展閱讀
1、處理名稱有退格鍵
update t_bd_item_info set item_name = replace(item_name,char(8),'')
where charindex(char(9),item_name) > 0 go
2、處理名稱有製表符tab
update t_bd_item_info set item_name = replace(item_name,char(9),'')
where charindex(char(9),item_name) > 0 go
3、處理名稱有換行
update t_bd_item_info set item_name = replace(item_name,char(10),'')
where charindex(char(10),item_name) > 0 go
4、處理名稱有回車
update t_bd_item_info set item_name = replace(item_name,char(13),'')
where charindex(char(13),item_name) > 0 go
5、處理名稱的空格(前空格、後空格、所有空格)
update t_bd_item_info set item_name = replace(rtrim(ltrim(item_name)),' ','')
where isnull(charindex(' ',item_name),0) > 0go
6、處理名稱的單引號
update t_bd_item_info set item_name = replace(item_name,char(39),'')
where charindex(char(39),item_name) > 0 go
7、處理名稱的雙單引號
update t_bd_item_info set item_name = replace(item_name,char(34),'')
where charindex(char(34),item_name) > 0 go
⑻ 怎樣在SQL表中插入空值
假設表 2個欄位,table1 (col1 , col2),需要 col2 為空就可以了。
⑼ sql求助 如何在資料庫中插入有空值的記錄
比如一個表有id和name欄位
但是你只想往id欄位里插入,但是你首先要保證name欄位允許為空
1
insert into 表名(id) values (1);
2
insert into 表名 values (1,null);
以上兩種情況都可以插入,你試驗一下