『壹』 如何在MSsql數據表隱藏一條記錄
可以用視圖,但要想用視圖,同時你的前台應用不修改相應的表名為視圖的話,解決不了
『貳』 sql 的優化隱藏器是什麼
優化隱藏
概述
一般地,對查詢語句,查詢處理器創建了可以提高性能的執行規劃。然而,如果對某一個特定的查詢語句例如檢索、插入、刪除、修改,查詢處理器沒有創建最好的執行規劃,那麼用戶可以在查詢語句中增加優化隱藏來影響查詢處理器創建出最優的執行規劃。優化隱藏就是指在執行查詢語句、使用多表連接檢索或者指定查詢語句操作的對象表時,明確地指出應該使用的查詢方法、連接演算法或者對表的操作方式。當使用優化隱藏時,一定要認真考慮優化隱藏對性能的影響。在SQL Server 7.0中,提供了三種類型的優化隱藏,即查詢優化隱藏、連接優化隱藏和表優化隱藏。
查詢優化隱藏
查詢優化隱藏控制整個語句的執行規劃。可以通過在SQL語句的最後增加一個OPTION子句,來實現查詢優化隱藏。另外,還可以同時指定多個查詢優化隱藏,這些選項之間由逗號分割開來。使用Hash Group或者Order Group選項,可以為分組子句或者分組計運算元句產生合計數值,但是這兩個選項不能同時使用。在聯合Union運算符中,可以使用合並、散列和連接選項,這時既可以使用一個選項,也可以同時使用多個選項。當同時使用多個選項時,系統將在這幾個選項中選用成本最低的方法進行操作。當把返回查詢結果的時間作為關鍵因素時,應當使用選項Fast n,這樣可以最小化返回查詢語句所得到的前n條記錄的時間。如果需要固定在連接運算符中表的先後順序,那麼可以使用選項Force Order,該選項可以確保在連接運算符中指定的准確的表的順序。單個查詢語句可以使用多個處理器並行執行,選項MaxDop n就是為並行執行查詢語句,明確指定可以使用處理器的最大值。
連接優化隱藏
連接優化隱藏指定某一個連接運算應該如何最優地實現。連接就是把兩個或者多個表中的記錄連接起來,通常是連接兩個表中的記錄。在連接中,使用兩個表中的某些列組成連接的條件表達式。為了使用連接優化隱藏,可以在連接運算符之前使用四個關鍵字中的其中一個關鍵字,這四個關鍵字分別是Loop、Hash、Merge和Remote。使用不同的關鍵字,就是使用不同的連接演算法。當使用關鍵字Loop時,連接演算法就是在第一個表中,順序地閱讀表中的每一行。對於第一個表中的一行,順序地與第二個表中的每一行進行比較,如果滿足連接條件,那麼就得到在匹配的行。就這樣進行下去,直至得到滿足條件的全部匹配的行。當使用關鍵字Hash時,使用的連接演算法是這樣的,對於第一個表中的每一行,計算在連接中使用的該列的散列值,然後把該散列值存儲在散列表中,對於第二個表中的每一行,計算一個在連接中使用的該列的散列值,然後在散列表中尋找匹配的行。通過在散列表中尋找匹配的記錄,就可以得到滿足連接條件的記錄。如果使用關鍵字Merge,那麼可以根據連接列的順序,使用匹配和合並演算法,處理兩個表中的每一行,得到滿足連接條件的全部記錄。關鍵字Remote很少使用,只有當連接中的兩個表存儲在不同的系統中時,才可以使用。該關鍵字指定在連接運算符右端的表所在的系統,開始連接進程。
當指定連接優化隱藏時,查詢處理器強制多個連接運算符的順序和在每個連接中指定的表的順序。當沒有指定連接優化隱藏時,查詢處理器根據連接的表結構和連接條件選擇最有效的方法。另外,如果沒有指定連接優化隱藏,那麼查詢處理器可以重新安排表的順序,如果有多個連接運算符,那麼查詢處理器也可以重新安排連接運算的順序,這樣可以保證系統使用最有效的連接方法。
表優化隱藏
表優化隱藏指定在查詢語句中使用的單個基表的訪問特徵。通過在表名後面增加一個With子句,可以指定表的優化隱藏。在檢索、插入、修改和刪除等查詢語句中都可以使用表優化隱藏。對於多個優化隱藏,可以使用逗號或者空格分割開。
優化隱藏FastFirstRow最小化該查詢語句返回表中第一條記錄的時間。該選項與查優化隱藏的Fast 1完全等價。索引優化隱藏Index(IndexName)和Index(IndexID)指定在訪問該表時應該使用的索引名稱或者索引代號。0表示使用表掃描,1表示使用聚簇索引(如果有聚簇索引)。對於那些非聚簇索引,可以通過使用該索引的名稱,強制在查詢語句中使用。
行級鎖類型優化隱藏UpdLock使用修改行級鎖取代共享行級鎖。鎖度優化隱藏。這些鎖類型只能一次使用一個。選項NoLock和ReadUncommitted,表示查詢語句不能獲得共享鎖,忽略排它鎖,也就是說,即使在操作對象上有排它鎖,也可以繼續訪問該對象。這兩個關鍵字是等價的,並且只能用在SELECT語句中。選項PagLock使用共享數據頁鎖代替共享表鎖。RowLock使用共享行鎖代替共享頁鎖或者共享表鎖。TabLock獲取共享表鎖,該鎖一直保存到該語句的結束。如果指定了Holdlock或者Serializable選項,那麼鎖一直保存到該事務的結束。TabLockX獲取排它表鎖。
事務獨立等級優化隱藏。這些鎖類型只能一次使用一個。Holdlock或者Serializable佔有共享鎖,直到事務的結束,而不是在查詢語句不需要這些頁鎖或者表鎖時,就釋放它們。這兩個關鍵字等價。ReadCommitted佔有共享鎖,直到該語句的結束,但是允許其他進程修改讀過的數據,因此這種讀是不可重復的。RepeatableRead佔有鎖,防止其他進程修改在查詢語句中使用的數據。
鎖級表優化隱藏有兩種作用:提高並發性和提高在並行訪問同一個表的沖突保護。NoLock、RowLock和PagLock優化隱藏允許多個並發進程。注意,當使用NoLock時,因為它允許閱讀那些已經修改但是還沒有提交的數據,如果改變這些數據的事務被取消了,那麼該查詢語句得到的數據與資料庫中的內容是不一樣的。RowLock和PagLock可以提高系統級的性能,當並行查詢訪問同一個表中的不同數據時,他們不會放置大量的鎖。然而,在另外一些情況下,使用這些選項,由於附加的鎖開銷,會降低系統的性能。
選項TabLock和 TabLockX明確指定使用表鎖,防止並發訪問的沖突。事務獨立等級允許在單個語句中使用的鎖協議,而不管當前的事務獨立等級是什麼。ReadUncommitted、ReadCommitted、RepeatableRead和Serializable從最低的保護性和最高的並發性到最高的保護性和最低的並發性。
『叄』 sql中如何去掉一條記錄
sql中去掉一條記錄的步驟如下:
我們需要准備的材料分別是:電腦、sql查詢器。
1、首先,打開sql查詢器,連接上相應的資料庫表,例如test3表。
『肆』 sql中如何去掉一條記錄
如果所用的資料庫是
Microsoft
SQL
Server的話,對於這種所有欄位完全相同的數據記錄,是無法做到只刪除一條的,因為資料庫無法定位這些相同的記錄中的某一條!
所以,如果執行刪除的話,只有兩種可能(具體看你所使用的SQL查詢工具了):1)報錯,無法刪除,比如在SQL企業管理器中直接選中數據並做刪除操作;2)相同的記錄全部刪除,比如用SQL查詢分析器。
那麼樓主的問題要如何解決呢,思路是這樣:
1)去掉重復的:
select
distinct
*
into
#tmp
from
[tablename]
--將唯一性記錄寫入臨時表
delete
from
[tablename]
--將原表數據清空(最好先備份一下原數據表)
insert
into
[tablename]
select
*
from
#tmp
--從臨時表將數據插回
2)如果一定要數據重復,那請修改表[tablename]結構,增加一個[ID]欄位,並讓它自動增長,以便將相同記錄區分開來。然後將需要重復的記錄用如下語句重復插入:
insert
into
[tablename]
(欄位列表-不包含那個ID欄位)
select
(欄位列表-不包含那個ID欄位)from
[tablename]
where
[ID]=XXXX
(註:XXX是事先查到的需要重復的記錄ID欄位值)
GoodLuck!
希望對你能有所幫助。
『伍』 Mysql中sql查詢如何隱藏分組項的欄位名,只輸出其值
1.選擇查詢 選擇查詢是最常見的查詢類型,它從一個或多個表中檢索數據,在一定的限制條件下,還可以通過選擇查詢來更改相關表中的記錄。
2.交叉表查詢 交叉表查詢可以在一種緊湊的、類似於電子表格的格式中,顯示來源於表中某個欄位的...
3.參數查詢 參數查詢會在執行時彈出對話框,提示用戶輸入必要的信息(參數),然後按照這些信息...
4.操作查詢 操作查詢是在一個操作中更改許多記錄的查詢,操作查詢又可分為四種類型:刪除查詢...
『陸』 隱藏或者禁止查詢某一條記錄用sql語句怎麼寫
where 欄位 not in (select 欄位 from xx )
『柒』 SQL有一張表叫name,表中有個隱藏欄位openhost,select語句查不到,如何能查詢隱藏欄位openhost的記錄
設置為隱藏欄位的內容 是不能查詢也 通過alter table 修改顯示,智能通過 alter table drop column來釋放該欄位。
『捌』 如何在SQL寫select語句中過濾掉不要的記錄。
你的問題描述不是很清楚,如果第二行的e列不為空呢?怎麼處理呢?
如果第二行為空,則可以利用rownum 在where條件中進行過濾。不過,要利用rownum過濾,得知道你的排序規則是什麼。