Hibernate3中可以直接通過面向?qū)ο蟮男问竭M行條件刪除,或者是直接sql的形式進行批量刪除。
創(chuàng)新互聯(lián)公司網(wǎng)站建設(shè)提供從項目策劃、軟件開發(fā),軟件安全維護、網(wǎng)站優(yōu)化(SEO)、網(wǎng)站分析、效果評估等整套的建站服務(wù),主營業(yè)務(wù)為網(wǎng)站建設(shè)、成都做網(wǎng)站,成都app軟件開發(fā)以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。創(chuàng)新互聯(lián)公司深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!
Sql代碼:
Session session=HibernateUtil.getSessionFactory().getCurrentSession();
session.beginTransaction();
String strSQL=" delete from Classes as a where a.classno like :name";
Query query = session.createQuery(strSQL);
query.setString("name", "%"+OId+"%");
Session session=HibernateUtil.getSessionFactory().getCurrentSession();
session.beginTransaction();
String strSQL="from Classes as a where a.classno like :name";
Query query = session.createQuery(strSQL);
HQL代碼:
Session session = HibernateUtil.getSessionFactory().getCurrentSession();
session.beginTransaction();
List result=session.createQuery("delete from Classes as a where a.classno
like " '%"+OId+"%'").list();
[sql] view plaincopyprint?
Session session = HibernateUtil.getSessionFactory().getCurrentSession();
session.beginTransaction();
List result=session.createQuery("from Classes as a where a.classno like " '%"+OId+"%'").list();
Session session = HibernateUtil.getSessionFactory().getCurrentSession();
session.beginTransaction();
String result=session.createQuery("delete from Classes as a where a.classno like " '%"+OId+"%'").list();
您好,1000名工號不是連續(xù)的是吧,還有請問你這張人員表有建立分區(qū)么,你完全可以按照時間為維度來建表,每個月的數(shù)據(jù)存放在一個分區(qū)表中,以后要刪除一個月的數(shù)據(jù),直接truncate table即可,不記錄日志,速度很快。
如果沒有建立分區(qū),只能在IN 條件里寫1000條 員工號了,用UE編輯下,給每個員工中間加個 ','
delete from 員工表 where 離職工號 in (1000條ID 逗號分隔) 你可以刪除時加NO LOGGING選項,不寫日志加快刪除速度;
一句SQL就搞定了.
update A set c=substring(c, 0,charindex('br/',c))
這條語句不能執(zhí)行多次,否則會造成清空c字段.請用下面的.
update A set c=substring(c, 0,charindex('br/',c)) where c like '%br/%'
如果不修改數(shù)據(jù)表值只要查詢的話,只用下面:
select substring(c, 0,charindex('br/',c)) c from A 就行了.
Sql Server中清空所有數(shù)據(jù)表中的記錄
清空所有數(shù)據(jù)表中的記錄:
復(fù)制代碼 代碼如下:
exec sp_msforeachtable @Command1 ='truncate table ?'
刪除所有數(shù)據(jù)表:
復(fù)制代碼 代碼如下:
exec sp_msforeachtable 'delete N''?'''
清空SQL Server數(shù)據(jù)庫中所有表數(shù)據(jù)的方法(有約束的情況)
其實刪除數(shù)據(jù)庫中數(shù)據(jù)的方法并不復(fù)雜,為什么我還要多此一舉呢,一是我這里介紹的是刪除數(shù)據(jù)庫的所有數(shù)據(jù),因為數(shù)據(jù)之間可能形成相互約束關(guān)系,刪除操作可能陷入死循環(huán),二是這里使用了微軟未正式公開的sp_MSForEachTable存儲過程。
也許很多讀者朋友都經(jīng)歷過這樣的事情:要在開發(fā)數(shù)據(jù)庫基礎(chǔ)上清理一個空庫,但由于對數(shù)據(jù)庫結(jié)構(gòu)缺乏整體了解,在刪除一個表的記錄時,刪除不了,因為可能有外鍵約束,一個常見的數(shù)據(jù)庫結(jié)構(gòu)是一個主表,一個子表,這種情況下一般都得先刪除子表記錄,再刪除主表記錄。
說道刪除數(shù)據(jù)記錄,往往馬上會想到的是delete和truncate語句,但在遇到在兩個或多個表之間存在約束的話,這兩個語句可能都會失效,而且最要命的是這兩個命令都只能一次操作一個表。那么真正遇到要刪除SQL Server數(shù)據(jù)庫中所有記錄時,該怎么辦呢?有兩個選擇:
1.按照先后順序逐個刪除,這個方法在表非常多的情況下顯得很不現(xiàn)實,即便是表數(shù)量不多,但約束比較多時,你還是要花費大量的時間和精力去研究其間的約束關(guān)系,然后找出先刪哪個表,再刪哪個表,最后又刪哪個表。
2.禁用所有約束,刪除所有數(shù)據(jù),最后再啟用約束,這樣就不用花時間和精力去研究什么約束了,只需要編寫一個簡單的存儲過程就可以自動完成這個任務(wù)。
復(fù)制代碼 代碼如下:
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
從這兩個選擇中不難看出第二個選擇是最簡單有效的了,那么在使用第二個選擇時,具體該怎么實施呢?
首先得編寫代碼循環(huán)檢查所有的表,這里我推薦一個存儲過程sp_MSForEachTable,因為在微軟的官方文檔中沒有對這個存儲過程有描述,很多開發(fā)人員也許都還未曾聽說,所以你在互聯(lián)網(wǎng)上搜索得到的解決辦法大多很復(fù)雜,也許有的人會認為,既然沒有官方文檔,這個存儲過程可能會不穩(wěn)定,打心理上會排斥它,但事實并非如此。下面來先看一個完整的腳本:
這個腳本創(chuàng)建了一個命名為sp_DeleteAllData的存儲過程,前面兩行語句分別禁用約束和觸發(fā)器,第三條語句才是真正地刪除所有數(shù)據(jù),接下里的語句分別還原約束和觸發(fā)器,最后一條語句是顯示每個表中的記錄,當(dāng)然這條語句也可以不要,我只是想確認一下是否清空了所有表而已。
你可以在任何數(shù)據(jù)庫上運行這個存儲過程,當(dāng)然不要在生成數(shù)據(jù)庫上運行,可別怪我沒告訴你!不管怎樣,還是先備份一下數(shù)據(jù)庫,使用備份數(shù)據(jù)庫還原,然后再運行該存儲過程,呵呵,即使是一個大型數(shù)據(jù)庫,也要不多長時間,你的數(shù)據(jù)庫就成一個空庫了
第三種方法:TRUNCATE TABLE
在sql server數(shù)據(jù)庫中快速刪除記錄,清空表若要刪除表中的所有行,則 TRUNCATE TABLE 語句是一種快速、無日志記錄的方法。TRUNCATE TABLE 與不含有 WHERE 子句的 DELETE 語句在功能上相同。但是,TRUNCATE TABLE 速度更快,并且使用更少的系統(tǒng)資源和事務(wù)日志資源。
與 DELETE 語句相比,TRUNCATE TABLE 具有以下優(yōu)點:
所用的事務(wù)日志空間較少。
DELETE 語句每次刪除一行,并在事務(wù)日志中為所刪除的每行記錄一項。TRUNCATE TABLE 通過釋放用于存儲表數(shù)據(jù)的數(shù)據(jù)頁來刪除數(shù)據(jù),并且在事務(wù)日志中只記錄頁釋放。
使用的鎖通常較少。
當(dāng)使用行鎖執(zhí)行 DELETE 語句時,將鎖定表中各行以便刪除。TRUNCATE TABLE 始終鎖定表和頁,而不是鎖定各行。
如無例外,在表中不會留有任何頁。
執(zhí)行 DELETE 語句后,表仍會包含空頁。例如,必須至少使用一個排他 (LCK_M_X) 表鎖,才能釋放堆中的空表。如果執(zhí)行刪除操作時沒有使用表鎖,表(堆)中將包含許多空頁。對于索引,刪除操作會留下一些空頁,盡管這些頁會通過后臺清除進程迅速釋放。
與 DELETE 語句相同,使用 TRUNCATE TABLE 清空的表的定義與其索引和其他關(guān)聯(lián)對象一起保留在數(shù)據(jù)庫中。