當前位置:首頁 » 編程語言 » sql刪除問題
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

sql刪除問題

發布時間: 2022-11-18 01:55:24

1. sql中刪除的問題

存儲過程貼出來看一下
如果這樣寫
declare @name as varchar(20)
declare @sql as varchar(200)
set @sql='delete from userinformation where 姓名='+@name
exec(@sql)
這樣是錯誤的,執行時會變成
delete from userinformation where 姓名=張三
可以改成下面的樣子
set @sql='delete from userinformation where 姓名='+char(39)+@name+char(39)
exec(@sql)
或者
delete from userinformation where 姓名=@name
如果還不正確,最好貼出代碼

----------------------
應該和主鍵沒關系,你的主鍵是標識列
----------------------------
(@姓名_1 [char])
改成
@姓名_1 char(50)
試試

2. sql語句刪除行的問題

顯示的話用select就好了,刪除用delete就好了,重點是確定你的表的主鍵,從這里看來這個表的主鍵應當是bh,
所以你可以使用select
*
from
table-name
where
bh
=
E10...(這里是567行的那個bh項).
如果要刪除的話使用delete
from
table-name
where
bh=
E10...(同上)
希望能夠幫助到你,如還有什麼問題,請留言。

3. SQL對數據進行修改、刪除時需要注意哪些問題

情況分析:

1、少量數據修改、刪除

2、多數據修改、刪除

解題思路:

為了保證正確的執行命令,需要對修改/刪除前的數據進行查看,篩選出相關數據之後,再進行操作

解題方法:

1、少量數據:可先用SELECT命令,根據WHERE條件,將信息先查詢出來,判斷這些數據是否是要修改的數據

2、多數據:

同第一種方式一樣,先用SELECT命令查詢出來,記錄下條件信息

然後用利用存儲過程、事物兩種技術。用存儲過程封存,裡面加上@@ERROR等一系列判斷,出現問題,則回滾事物,否則提交事物

4. SQL刪除數據的問題

有兩種辦法
1、TRUNCATE TABLE 刪除表中的所有行,而不記錄單個行刪除操作。
語法 TRUNCATE TABLE name
參數 name 是要截斷的表的名稱或要刪除其全部行的表的名稱。
2、Delete from tablename where 1=1

5. 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

6. sql刪除表格失敗

建議你這樣試試看:

  1. 看下是不是有外鍵約束,如果有外鍵約束的話,需要先刪除才能刪除數據表

  2. 查看執行SQL語句後的錯誤信息,分析問題所在

7. sql刪除語句的問題

方法1:在多些一條delete的sql語句,刪除其他表的相應欄位方法2:給student創建delete觸發器方法3:既然stuid是arrange的外鍵,那麼可以對arrange表創建外鍵約束,在刪除student的時候會自動將arrange表相應欄位給刪除掉(sql外鍵約束自帶功能,就看你有沒設置了)

8. 資料庫的SQL刪除語句問題

restrict: 確保只有不存在相關視圖和 完整性約束的表才能刪除
cascade: 任何相關視圖和完整性約束一並被刪除
orop是清楚表格

9. sql語句多表刪除問題

原則上,同意youyuan1688和ytbelwxg的方法. 5個表,如果每個表都和lm_company表的comid欄位有直接主外鍵關系.那麼ytbelwxg的方法是最佳方案; 仔細看了你的連接條件,猜想,並不是每個表都和lm_company表的comid欄位有直接主外鍵關系.所以通過主外鍵級聯刪除的方案就不可行,那麼就必須逐個表來刪除,而且刪除的順序也有講究,先刪子表,再刪主表. 本例中,刪除的順序應該是e,d,c,b,a; --1.刪除e; sql1="delete from lm_newsinfo from lm_newsinfo as e, lm_company as a where a.comid=e.news_comid and a.comid=" + lblid.Text +";" --2.刪除d; sql2="delete from lm_message from lm_company as a ,lm_Yuzhan as b ,lm_Bookinfo as c ,lm_message as d where a.comid=b.yuzhan_comid and b.yuzhan_id=c.Bkinfo_yuzhanid and c.Bkinfo_id=d.message_bookid and a.comid=" + lblid.Text +";" --刪除c; sql3="delete from lm_Bookinfo from lm_company as a ,lm_Yuzhan as b ,lm_Bookinfo as c where a.comid=b.yuzhan_comid and b.yuzhan_id=c.Bkinfo_yuzhanid and a.comid=" + lblid.Text + ";" --刪除b; sql4="delete from lm_Yuzhan where yuzhan_comid=" + lblid.Text + ";" --刪除a; sql5="delete from lm_company where comid=" + lblid.Text + ";" --合並sql1,sql2,sql3,sql4,sql5 sql=sql1+sql2+sql3+sql4+sql5 --在你的客戶端執行sql命令串即可

10. SQL 刪除問題

建議你使用兩個步驟來完成這個功能,這樣可以避免誤刪除,畢竟你的時間只精確到秒,但是伺服器時間中是精確到毫秒的,所以你這樣查詢中用「=」來做判斷是不正確的,可能根本無法查詢到結果,你可以參考下面的步驟
1、根據『2013-04-02 09:19:43』作為條件來查詢出數據iD,根據ID來刪除,這樣可以確保不會誤刪其他的數據,畢竟如果站在伺服器角度,同一秒產生多條數據是很平常的事情,因此你可能會獲得多個ID。
2、使用日期函數來處理時間比較,而不要直接用=來比較,如果你更喜歡用運算符的話,你要考慮如果同一秒有多條數據你如何取捨,是全部刪除嗎?還有毫秒數的對比,很多時候你並非DBA的情況下並無法看到數據的實際內容。
3、如果不考慮同一秒多條數據的情況,或者同一秒的數據都不要的情況下,建議將「=」改成begin and來處理時間。啰嗦一句,begin and使用中begin是包含的,不包含end所述時間。也可以用>= and <來解決