問一個問題關于用vb 6.0對sql sever資料庫進行洗掉的問題~~~
剛剛開始自學,這一個小操作怎么也不對TT
條件是:開始Student表和Score表里的學生,學號手動輸入,就是這一句DELETE FROM Student,Score WHERE Student.StudentID=Score.StudentID AND Student.StudentID=" + Text1.Text
adodc1的RecordSourse是Student表,DataGrid1的DataSourse是adodc1
adodc2的RecordSourse是Score表,DataGrid2的DataSourse是adodc2
代碼如下:
Private Sub Command1_Click()
Set stu = New ADODB.Connection
stu.ConnectionString = "Provider=SQLOLEDB.1;Integrated Security=SSPI;Persist Security Info=False;Initial Catalog=學生成績管理;Data Source=MIKI\SQLEXPRESS"
stu.Open
Dim strSQL As String
strSQL = "DELETE FROM Student,Score WHERE Student.StudentID=Score.StudentID AND Student.StudentID=" + Text1.Text
stu.Execute strSQL //顯示這里有錯誤!變成黃色!!
MsgBox "開除完畢!"
Adodc1.Refresh
DataGrid1.Refresh
Adodc2.Refresh
DataGrid2.Refresh
End Sub
uj5u.com熱心網友回復:
一個DELETE 陳述句只能對一個表進行洗掉。兩個表都刪要分成兩個陳述句。uj5u.com熱心網友回復:
Transact-SQL 參考
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 Products
ON (Suppliers.SupplierID = Products.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
請參見
CREATE TABLE
CREATE TRIGGER
游標
DROP TABLE
INSERT
SELECT
TRUNCATE TABLE
UPDATE
?1988-2000 Microsoft Corporation。保留所有權利。
uj5u.com熱心網友回復:
#1說的對啊,一次只能洗掉一個表中的記錄。二樓給的是標準幫助吧,看著真累,不過如果要深入使用這個還是得耐著性子看的uj5u.com熱心網友回復:
你還不了解我的惡習之一就是好貼聯機幫助原文到CSDN論壇帖子里嗎?
uj5u.com熱心網友回復:
sql 陳述句錯誤uj5u.com熱心網友回復:
Set stu = New ADODB.Connection你這里的stu是Connection物件,當然不能執行Execute這種命令
之用Adodb.Command物件可以執行這個操作。
uj5u.com熱心網友回復:
1.洗掉操作只能針對一個表,不能針對兩個表的.你的操作要分成兩句執行.strSQL = "delete from score where studentid=" + Text1.Text
stu.Execute strSQL
strSQL = "delete from Student where studentid=" + Text1.Text
stu.Execute strSQL
2.開除學生,一般不會從資料庫中將學生的所有資訊都洗掉掉,而是在學生表中打上一個開除標記,其余資訊都得保留,否則以后人家找上門來,說我在你這兒學了兩年,這兩年的資訊呢?你不傻眼了么?
3.不要用ADODC,用ADODB,在工程中添加一個Data Environment 就可以直接用了.然后學會用SQL陳述句操作資料庫.
uj5u.com熱心網友回復:
使用adodb而不要使用Adodc這個控制元件轉載請註明出處,本文鏈接:https://www.uj5u.com/gongcheng/103767.html
標籤:VB基礎類
上一篇:ShellExecute 執行一個網頁 但不打開這個網頁怎么處理
下一篇:求助VB編程問題
