⑴ sql中的刪除問題
delete A WHERE department <> '總部'
看看delete語法:
DELETE
從表中刪除行。
語法
DELETE
[ FROM ]
{ table_name WITH ( < table_hint_limited > [ ...n ] )
| view_name
| rowset_function_limited
}
[ FROM { < table_source > } [ ,...n ] ]
[ WHERE
{ < search_condition >
| { [ CURRENT OF
{ { [ GLOBAL ] cursor_name }
| cursor_variable_name
}
] }
}
]
[ OPTION ( < query_hint > [ ,...n ] ) ]
< table_source > ::=
table_name [ [ AS ] table_alias ] [ WITH ( < table_hint > [ ,...n ] ) ]
| view_name [ [ AS ] table_alias ]
| rowset_function [ [ AS ] table_alias ]
| derived_table [ AS ] table_alias [ ( column_alias [ ,...n ] ) ]
| < joined_table >
< joined_table > ::=
< table_source > < join_type > < table_source > ON < search_condition >
| < table_source > CROSS JOIN < table_source >
| < joined_table >
< join_type > ::=
[ INNER | { { LEFT | RIGHT | FULL } [OUTER] } ]
[ < join_hint > ]
JOIN
< table_hint_limited > ::=
{ FASTFIRSTROW
| HOLDLOCK
| PAGLOCK
| READCOMMITTED
| REPEATABLEREAD
| ROWLOCK
| SERIALIZABLE
| TABLOCK
| TABLOCKX
| UPDLOCK
}
< table_hint > ::=
{ INDEX ( index_val [ ,...n ] )
| FASTFIRSTROW
| HOLDLOCK
| NOLOCK
| PAGLOCK
| READCOMMITTED
| READPAST
| READUNCOMMITTED
| REPEATABLEREAD
| ROWLOCK
| SERIALIZABLE
| TABLOCK
| TABLOCKX
| UPDLOCK
}
< query_hint > ::=
{ { HASH | ORDER } GROUP
| { CONCAT | HASH | MERGE } UNION
| FAST number_rows
| FORCE ORDER
| MAXDOP
| ROBUST PLAN
| KEEP PLAN
}
參數
FROM
是可選的關鍵字,可用在 DELETE 關鍵字與目標 table_name、view_name 或 rowset_function_limited 之間。
table_name
是要從其中刪除行的表的名稱。
在其作用域內的 table 變數、或是將 OPENDATASOURCE 函數作為伺服器名稱的由四部分組成的表名(或視圖名稱)還可以在 DELETE 語句中作為表源使用。
WITH (<table_hint_limited> [...n])
指定目標表所允許的一個或多個表提示。需要有 WITH 關鍵字和圓括弧。不允許有 READPAST、NOLOCK 和 READUNCOMMITTED。有關表提示的更多信息,請參見 FROM。
view_name
是視圖名稱。在視圖的 FROM 子句中,view_name 引用的視圖必須可更新且正確引用一個基表。有關可更新視圖的更多信息,請參見 CREATE VIEW。
說明 如果表或視圖存在於另一個資料庫內或有一個不同於當前用戶的所有者,則使用格式為 server_name.database.[owner].object_name 的由四部分組成的合法名稱。有關更多信息,請參見 Transact-SQL 語法規則。
rowset_function_limited
OPENQUERY 或 OPENROWSET 函數,視提供程序功能而定。有關提供程序所需功能的更多信息,請參見 OLE DB 提供程序的 UPDATE 和 DELETE 語句要求。有關行集函數的更多信息,請參見 OPENQUERY 和 OPENROWSET。
FROM < table_source >
指定附加的 FROM 子句。這個對 DELETE 的 Transact-SQL 擴展使您得以從 <table_sources> 指定數據,並從第一個 FROM 子句內的表中刪除相應的行。
這個擴展指定聯接,可在 WHERE 子句中取代子查詢來標識要刪除的行。
table_name [[AS] table_alias ]
是為刪除操作提供標准值的表名。
view_name [ [ AS ] table_alias ]
是為刪除操作提供標准值的視圖名稱。帶 INSTEAD OF UPDATE 觸發器的視圖不能是含有 FROM 子句的 UPDATE 的目標。
WITH (<table_hint>
指定一個或更多表提示。有關表提示的更多信息,請參見 FROM。
rowset_function [ [AS] table_alias ]
是行集函數名和可選別名。有關行集函數列表的更多信息,請參見行集函數。
derived_table [AS] table_alias
是從資料庫中檢索行的子查詢。derived_table 用作對外部查詢的輸入。
column_alias
替換結果集內列名的可選別名。在選擇列表中放入每個列的一個別名,並將整個列別名列表用圓括弧括起來。
<joined_table>
由兩個或更多表的積組成的結果集,例如:
SELECT *
FROM tab1 LEFT OUTER JOIN tab2 ON tab1.c3 = tab2.c3
RIGHT OUTER JOIN tab3 LEFT OUTER JOIN tab4
ON tab3.c1 = tab4.c1
ON tab2.c3 = tab4.c3
對於多個 CROSS 聯接,請使用圓括弧來更改聯接的自然順序。
<join_type>
指定聯接操作的類型。
INNER
指定返回每對匹配的行。廢棄兩個表中不匹配的行。如果未指定聯接類型,則這是默認設置。
LEFT [OUTER]
指定在結果集內包含左表中所有不滿足指定條件的行,並將右表中的輸出列設置為 NULL 以作為對內聯接所返回的所有行的補充。
RIGHT [OUTER]
指定在結果集內包含右表中所有不滿足指定條件的行,並將左表中的輸出列設置為 NULL 以作為對內聯接所返回的所有行的補充。
FULL [OUTER]
如果來自左表或右表的某行與選擇准則不匹配,則指定在結果集內包含該行,並且將與另一個表對應的輸出列設置為 NULL。除此之外,結果集中還包含通常由內聯接返回的所有行。
JOIN
是表示在刪除操作中使用 SQL-92 式聯接的關鍵字。
ON <search_condition>
指定聯接所基於的條件。盡管經常使用列和比較運算符,但此條件可指定任何謂詞,例如:
FROM Suppliers JOIN Procts
ON (Suppliers.SupplierID = Procts.SupplierID)
當條件指定列時,列不必具有相同的名稱或數據類型;但是,如果數據類型不一致,則這些列必須相互兼容或是 Microsoft® SQL Server™ 能夠隱性轉換的類型。如果數據類型不能隱性轉換,則條件必須使用 CAST 函數顯式轉換數據類型。
有關搜索條件和謂詞的更多信息,請參見搜索條件。
CROSS JOIN
指定兩個表的矢量積。這將返回相同的行,就好像在舊式的非 SQL-92 式聯接中並沒有指定 WHERE 子句。
WHERE
指定用於限制刪除行數的條件。如果沒有提供 WHERE 子句,則 DELETE 刪除表中的所有行。基於 WHERE 子句中所指定的條件,有兩種形式的刪除操作。
搜索刪除指定搜索條件限定刪除的行。
定位刪除使用 CURRENT OF 子句指定游標。刪除操作在游標的當前位置發生。這比使用 WHERE search_condition 子句限定刪除的行的搜索 DELETE 精確。如果搜索條件不唯一標識單行,則搜索 DELETE 刪除多行。
<search_condition>
指定刪除行的限定條件。對搜索條件中可以包含的謂詞數量沒有限制。有關更多信息,請參見搜索條件。
CURRENT OF
指定在指定游標的當前位置完成 DELETE。
GLOBAL
指定 cursor_name 指的是全局游標。
cursor_name
是從其中進行提取的打開游標的名稱。當全局和局部游標都以 cursor_name 作為它們的名稱存在時,如果指定 GLOBAL,則 cursor_name 引用全局游標,如果未指定 GLOBAL,則 cursor_name 引用局部游標。游標必須允許更新。
cursor_variable_name
是游標變數的名稱。游標變數必須引用允許更新的游標。
OPTION (<query_hint> [,...n] )
是表示使用優化程序提示自定義 SQL Server 的語句處理的關鍵字。
{HASH | ORDER} GROUP
指定在查詢的 GROUP BY 或 COMPUTE 子句中指定的聚合使用哈希或排列。
{MERGE | HASH | CONCAT} UNION
指定所有的 UNION 操作通過合並、哈希或串聯 UNION 集合來完成。如果指定了不止一個 UNION 提示,查詢優化器就會從這些指定的提示中選擇開銷最少的策略。
說明 如果還為 FROM 子句中的某對鏈接表指定了 <joint_hint>,則這個提示優先於 OPTION 子句中所指定的任何 <join_hint>。
FAST number_rows
指定對查詢進行優化,以便快速檢索第一個 number_rows(非負整數)。在第一個 number_rows 返回後,查詢繼續進行並生成完整的結果集。
FORCE ORDER
指定在查詢優化過程中保持由查詢語法表示的聯接順序。
MAXDOP number
只對指定了 sp_configure 的 max degree of parallelism 配置選項的查詢替代該選項。當使用 MAXDOP 查詢提示時,所有和 max degree of parallelism 配置選項一起使用的語義規則均適用。有關更多信息,請參見 max degree of parallelism 選項。
ROBUST PLAN
強制查詢優化器嘗試執行一個計劃,該計劃以性能為代價獲得最大可能的行大小。如果不能使用這樣的計劃,查詢優化器將返回錯誤而不是延遲對查詢執行的錯誤檢測。行可以包含可變長度列;SQL Server 允許將行大小定義為超過 SQL Server 處理能力的最大可能的大小。通常,應用程序存儲實際大小在 SQL Server 處理能力范圍內的行,而不管最大可能大小。如果 SQL Server 遇到過長的行,則返回執行錯誤。
KEEP PLAN
強制查詢優化器對查詢放寬估計的重新編譯閾值。當對表中索引列的更改(更新、刪除或插入)達到估計數目時查詢會自動重新編譯,該估計數目即為重新編譯閾值。指定 KEEP PLAN 將確保當表有多個更新時不會頻繁地對查詢進行重新編譯。
注釋
如果所修改的對象是 table 變數,則 DELETE 可用在用戶定義函數的正文中。
對於由四部分組成的表名(或視圖名稱),若其中的伺服器名稱使用的是 OPENDATASOURCE 函數,則該表名可以在表名能夠出現的任何位置作為表源使用。
如果 DELETE 語句違反了觸發器,或試圖刪除另一個有 FOREIGN KEY 約束的表內的數據所引用的行,則可能會失敗。如果 DELETE 刪除了多行,而在刪除的行中有任何一行違反觸發器或約束,則將取消該語句,返回錯誤且不刪除任何行。
如果在對表或視圖的 DELETE 操作上定義了 INSTEAD-OF 觸發器,該觸發器將執行 instead of DELETE 語句。SQL Server 的早期版本只支持 DELETE 上的 AFTER 觸發器和其它修改語句。
當 DELETE 語句遇到在表達式評估過程中發生的算術錯誤(溢出、被零除或域錯誤)時,SQL Server 將處理這些錯誤,就好象 SET ARITHABORT 打開一樣。將取消批處理中的其餘部分並返回錯誤信息。
對遠程表和本地及遠程分區視圖上的 DELETE 語句將忽略 SET ROWCOUNT 選項的設置。
如果要刪除在表中的所有行,則 TRUNCATE TABLE 比 DELETE 快。DELETE 以物理方式一次刪除一行,並在事務日誌中記錄每個刪除的行。TRUNCATE TABLE 則釋放所有與表關聯的頁。因此,TRUNCATE TABLE 比 DELETE 快且需要的事務日誌空間更少。TRUNCATE TABLE 在功能上與不帶 WHERE 子句的 DELETE 相當,但是 TRUNCATE TABLE 不能用於由外鍵引用的表。DELETE 和 TRUNCATE TABLE 都使刪除的行所佔用的空間可用於存儲新數據。
許可權
默認情況下,將 DELETE 許可權授予 sysadmin 固定伺服器角色成員、db_owner 和 db_datawriter 固定資料庫角色成員以及表所有者。sysadmin、db_owner 和 db_securityadmin 角色成員和表所有者可以將許可權轉讓給其他用戶。
如果語句包含 WHERE 子句,則還必須有 SELECT 許可權。
示例
A. 不帶參數使用 DELETE
下例從 authors表中刪除所有行。
USE pubs
DELETE authors
B. 在行集上使用 DELETE
因為 au_lname 可能不是唯一的,下例刪除其中的 au_lname 是 McBadden 的所有行。
USE pubs
DELETE FROM authors
WHERE au_lname = 'McBadden'
C. 在游標的當前行上使用 DELETE
下例顯示在名為 complex_join_cursor 的游標上所做的刪除。它隻影響當前從游標提取的單行。
USE pubs
DELETE FROM authors
WHERE CURRENT OF complex_join_cursor
D. 基於子查詢使用 DELETE 或使用 Transact-SQL 擴展
下例顯示基於聯接或相關子查詢從基表中刪除記錄的 Transact-SQL 擴展。第一個 DELETE 顯示與 SQL-92 兼容的子查詢解決方法,第二個 DELETE 顯示 Transact-SQL 擴展。兩個查詢都基於存儲在 titles 表中的標題從 titleauthors 表中刪除行。
/* SQL-92-Standard subquery */
USE pubs
DELETE FROM titleauthor
WHERE title_id IN
(SELECT title_id
FROM titles
WHERE title LIKE '%computers%')
/* Transact-SQL extension */
USE pubs
DELETE titleauthor
FROM titleauthor INNER JOIN titles
ON titleauthor.title_id = titles.title_id
WHERE titles.title LIKE '%computers%'
E. 在 DELETE 和 SELECT 中使用 TOP 子句
由於可以在 DELETE 語句中指定 SELECT 語句,因此還可以在 SELECT 語句中使用 TOP 子句。例如,下例從 authors 表中刪除前 10 個作者。
DELETE authors
FROM (SELECT TOP 10 * FROM authors) AS t1
WHERE authors.au_id = t1.au_id
⑵ 為什麼SQL的部分數據刪不掉呢顯示未刪除任何行
因為表中此條信息不是唯一的,表中存在多條相同信息造成的,如果想刪除,可以設計表,在表中增加一列設為自增長列進行保存,然後再進行刪除就可以了。
⑶ sql怎麼刪除一個表中的所有數據
刪除表數據有兩種方法:delete和truncate。具體語句如下:
一、RUNCATE TABLE name :
刪除表中的所有行,而不記錄單個行刪除操作。在這個指令之下,表格中的資料會完全消失,可是表格本身會繼續存在。
TRUNCATE TABLE 的語法:TRUNCATE TABLE name ,參數 name 是要截斷的表的名稱或要刪除其全部行的表的名稱。
二、Delete from tablename where 1=1
1、delete語法:
DELETE FROM 表名稱 WHERE 列名稱 = 值。
2、刪除所有行:
可以在不刪除表的情況下刪除所有的行。這意味著表的結構、屬性和索引都是完整的:DELETE FROM table_name。
(3)sql未刪除任何行擴展閱讀:
truncate和delete的共同點及區別:
1、 truncate和 delete只刪除數據不刪除表的結構(定義) 。
2、delete語句是dml,這個操作會放到rollback segement中,事務提交之後才生效;如果有相應的trigger,執行的時候將被觸發。
truncate是ddl, 操作立即生效,原數據不放到rollback segment中,不能回滾. 操作不觸發trigger。
3、delete語句不影響表所佔用的extent, 高水線(high watermark)保持原位置不動 。truncate 語句預設情況下見空間釋放到 minextents個 extent,除非使用reuse storage; truncate會將高水線復位(回到最開始)。
4、速度,一般來說: truncate >delete 。
⑷ 刪除數據時出錯。提示,未刪除任何行。試圖刪除行時發生問題。錯誤源:.net sqlclient data provider。
sql 錯了,一般這樣的 「錯誤信息:將截斷字元串或二進制數據。語句已終止」,都是sql不對。 基本都是where 條件里邊有錯。
⑸ SQL刪除資料庫中的所有數據
Sql Server中清空所有數據表中的記錄
清空所有數據表中的記錄:
復制代碼 代碼如下:
exec sp_msforeachtable @Command1 ='truncate table ?'
刪除所有數據表:
復制代碼 代碼如下:
exec sp_msforeachtable 'delete N''?'''
清空SQL Server資料庫中所有表數據的方法(有約束的情況)
其實刪除資料庫中數據的方法並不復雜,為什麼我還要多此一舉呢,一是我這里介紹的是刪除資料庫的所有數據,因為數據之間可能形成相互約束關系,刪除操作可能陷入死循環,二是這里使用了微軟未正式公開的sp_MSForEachTable存儲過程。
也許很多讀者朋友都經歷過這樣的事情:要在開發資料庫基礎上清理一個空庫,但由於對資料庫結構缺乏整體了解,在刪除一個表的記錄時,刪除不了,因為可能有外鍵約束,一個常見的資料庫結構是一個主表,一個子表,這種情況下一般都得先刪除子表記錄,再刪除主表記錄。
說道刪除數據記錄,往往馬上會想到的是delete和truncate語句,但在遇到在兩個或多個表之間存在約束的話,這兩個語句可能都會失效,而且最要命的是這兩個命令都只能一次操作一個表。那麼真正遇到要刪除SQL Server資料庫中所有記錄時,該怎麼辦呢?有兩個選擇:
1.按照先後順序逐個刪除,這個方法在表非常多的情況下顯得很不現實,即便是表數量不多,但約束比較多時,你還是要花費大量的時間和精力去研究其間的約束關系,然後找出先刪哪個表,再刪哪個表,最後又刪哪個表。
2.禁用所有約束,刪除所有數據,最後再啟用約束,這樣就不用花時間和精力去研究什麼約束了,只需要編寫一個簡單的存儲過程就可以自動完成這個任務。
復制代碼 代碼如下:
CREATE PROCEDURE sp_DeleteAllData
AS
EXEC sp_MSForEachTable 'ALTER TABLE ? NOCHECK CONSTRAINT ALL'
EXEC sp_MSForEachTable 'ALTER TABLE ? DISABLE TRIGGER ALL'
EXEC sp_MSForEachTable 'DELETE FROM ?'
EXEC sp_MSForEachTable 'ALTER TABLE ? CHECK CONSTRAINT ALL'
EXEC sp_MSForEachTable 'ALTER TABLE ? ENABLE TRIGGER ALL'
EXEC sp_MSFOREACHTABLE 'SELECT * FROM ?'
GO
從這兩個選擇中不難看出第二個選擇是最簡單有效的了,那麼在使用第二個選擇時,具體該怎麼實施呢?
首先得編寫代碼循環檢查所有的表,這里我推薦一個存儲過程sp_MSForEachTable,因為在微軟的官方文檔中沒有對這個存儲過程有描述,很多開發人員也許都還未曾聽說,所以你在互聯網上搜索得到的解決辦法大多很復雜,也許有的人會認為,既然沒有官方文檔,這個存儲過程可能會不穩定,打心理上會排斥它,但事實並非如此。下面來先看一個完整的腳本:
這個腳本創建了一個命名為sp_DeleteAllData的存儲過程,前面兩行語句分別禁用約束和觸發器,第三條語句才是真正地刪除所有數據,接下里的語句分別還原約束和觸發器,最後一條語句是顯示每個表中的記錄,當然這條語句也可以不要,我只是想確認一下是否清空了所有表而已。
你可以在任何資料庫上運行這個存儲過程,當然不要在生成資料庫上運行,可別怪我沒告訴你!不管怎樣,還是先備份一下資料庫,使用備份資料庫還原,然後再運行該存儲過程,呵呵,即使是一個大型資料庫,也要不多長時間,你的資料庫就成一個空庫了
第三種方法:TRUNCATE TABLE
在sql server資料庫中快速刪除記錄,清空表若要刪除表中的所有行,則 TRUNCATE TABLE 語句是一種快速、無日誌記錄的方法。TRUNCATE TABLE 與不含有 WHERE 子句的 DELETE 語句在功能上相同。但是,TRUNCATE TABLE 速度更快,並且使用更少的系統資源和事務日誌資源。
與 DELETE 語句相比,TRUNCATE TABLE 具有以下優點:
所用的事務日誌空間較少。
DELETE 語句每次刪除一行,並在事務日誌中為所刪除的每行記錄一項。TRUNCATE TABLE 通過釋放用於存儲表數據的數據頁來刪除數據,並且在事務日誌中只記錄頁釋放。
使用的鎖通常較少。
當使用行鎖執行 DELETE 語句時,將鎖定表中各行以便刪除。TRUNCATE TABLE 始終鎖定表和頁,而不是鎖定各行。
如無例外,在表中不會留有任何頁。
執行 DELETE 語句後,表仍會包含空頁。例如,必須至少使用一個排他 (LCK_M_X) 表鎖,才能釋放堆中的空表。如果執行刪除操作時沒有使用表鎖,表(堆)中將包含許多空頁。對於索引,刪除操作會留下一些空頁,盡管這些頁會通過後台清除進程迅速釋放。
與 DELETE 語句相同,使用 TRUNCATE TABLE 清空的表的定義與其索引和其他關聯對象一起保留在資料庫中。
⑹ 求助sql 未刪除任何行 不能使改行成為唯一行
問題出在你的sql server資料庫的表中有重復的記錄
你現在使用sql的管理工具刪除重復記錄中的一條,這樣的話,管理工具生成刪除sql語句的時候,不知道你要刪除那一條,所以報這個錯誤。
方法是你在你的表中建立一個唯一的欄位,可以說自增的主鍵,然後再刪除
⑺ SQL Server 與應用程序對象的連接失敗,請確保未刪除任何程序模塊。
開始-運行對話框輸入:mmc 調出控制台
控制台 -- 文件 -- 添加 / 刪除管理單元 -- 添加 -- 找到 MicrosoftSQL 企業管理器 -- 添加 -- 關閉 -- 確定
回到控制台
下一步,控制台 -- 文件 -- 選項 -- 控制台模式選擇「用戶模式完全訪問」-- 將下面的選項打對勾的全部去掉,然後再:控制台 -- 另存為 -- 存儲為:C:\ProgramFiles\MicrosoftSQLServer\80\Tools\BINN\SQLServerEnterpriseManager.MSC
如果還不行的話,請繼續
重啟企業管理器
程序注冊控制項
開始 -- 運行中輸入 regsvr32 semsfc.dll /s
完成!
⑻ 資料庫提示 未更新任何行,請問是什麼問題,怎麼辦
1、首先打開運行界面,在輸入框中輸入CMD命令
⑼ 為什麼SQL中不能無法刪除普通的一列呢沒有設任何約束,我用SQL server2005
刪除列要加關鍵字column
alter table Student drop column 列名
alter table語句默認添加的是列,刪除的則是約束
alter table Student drop 約束名,這樣是正確的
⑽ SQL Server修改表的時候出現錯誤:未更新任何行
當對sql資料庫中的表進行編輯時,會出現「未更新任何行」的錯誤,這是可能是因為插入了一條與之前相同的記錄或者不滿足某種約束類型,這時資料庫當然不能更新任何行了。
此時應該檢查一下是否輸入了錯誤的數據,並與之前已輸入的數據記錄進行比較,確定正確之後再錄入數據。若仍有「未更新任何行」的錯誤並且保存不了這個表,也退不出去,這時就需要用sql語句來刪除已錄入的錯誤數據。
(10)sql未刪除任何行擴展閱讀
Sql 修改表結構的操作
1、添加表欄位
alter table 表名 add 欄位名 類型(值)
示例:alter table user add name varchar(40);
2、刪除表欄位
alter table 表名 drop 欄位名
示例: alter table user drop name;
3、欄位名更名
alter table 表名 rename 老欄位名 to 新欄位名
示例:alter table user rename oldname to newname;
4、更改欄位類型
alter table 表名 alter 欄位 類型;
示例:alter table user alter name varchar(50);