刪除資料庫代碼
⑴ 如何刪除資料庫中所有數據
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 清空的表的定義與其索引和其他關聯對象一起保留在資料庫中。
⑵ 如何用javascript代碼刪除資料庫里的數據
IE 瀏覽器可以使用ActiveX adodb
function connection()
{
var i=2;
var dbname=name;
var url = "property.xml";
var xmldoc = new ActiveXObject("Microsoft.XMLDOM");
xmldoc.load(url);
var property=xmldoc.getElementsByTagName("provider");
var dbpath=property[i].getElementsByTagName("dbpath")[0].firstChild.data;
var dbprovider=property[i].getElementsByTagName("dbprovider")[0].firstChild.data;
var dbuser=property[i].getElementsByTagName("dbuser")[0].firstChild.data;
var dbpassword=property[i].getElementsByTagName("dbpassword")[0].firstChild.data;
try{
var conn = new ActiveXObject("ADODB.Connection");
//var constr="Provider="+dbprovider+";Data Source="+dbpath+";User ID="+dbuser+";Jet OLEDB:Database Password="+dbpassword+";";
var constr="Provider="+dbprovider+";Data Source="+dbpath+";User ID="+dbuser+";Jet OLEDB:Database Password="+dbpassword+";";
conn.open(constr);
return conn;
}
catch(e){
alert("can not be connectting!");
conn.close;
return null;
}
finally{
}
}
function dbreadresult(strsql)
{
var strsql=strsql;
var i=0;
var result="";
try{
var conn=connection();
var rs = new ActiveXObject("ADODB.Recordset");
rs.open(strsql,conn,1,1);
var rowcount=rs.RecordCount;
var colcount=rs.Fields.Count;
while(!rs.eof)
{
result=result+rs.Fields(0);
for(j=1;j<colcount;j++)
if(rs.Fields(j).Type==7){
dbdate=new Date(rs.Fields(j));
if((dbdate==null)||(dbdate=="null")||(dbdate < new Date(2001,1,1))||(dbdate=="")){result=result+"\\t"+" ";}
else{result=result+"\\t"+datetostring(dbdate);}
}
else{
var dbdatastr=rs.Fields(j)+" ";
dbdatastr=dbdatastr.trim();
if((dbdatastr==null)||(dbdatastr=="null")||(dbdatastr=="")||(dbdatastr==" ")){result=result+"\\t"+" ";}
else{result=result+"\\t"+rs.Fields(j);}
}
result=result+"\
";
rs.moveNext();
}
return result;
}
catch(e){
alert(e.message);
return null;
}
finally{
rs.close;
conn.close;
}
}
⑶ .net刪除資料庫記錄代碼
寫一個操作資料庫的類,類中包括對資料庫的增、刪、改、查操作。然後在要用到的地方調用寫的資料庫操作類中的方法。 在執行操作時,將所要執行的SQL語句傳入寫的資料庫操作類中,調用就可以了。 private static string conStr = 「」;//資料庫連接字元串//獲得資料庫連接
private static SqlConnection connection;
public static SqlConnection Connection
{
get
{
if (connection == null)
{
connection = new SqlConnection(conStr);
connection.Open();
}
else if (connection.State == System.Data.ConnectionState.Closed)
{
connection.Open();
}
else if (connection.State == System.Data.ConnectionState.Broken)
{
connection.Close();
connection.Open();
}
return connection;
}
} //執行增,刪,改,返回影響行數 sql 執行的刪除語句 type 命令的類型 如果是語句則用 Command.text 如果是存儲過程 則用 CommandType.StoredProcere params 是傳入的參數
public static int ExecuteNonQuery(string sql, CommandType type, SqlParameter[] parms)
{
SqlCommand com = new SqlCommand(sql, Connection);
com.CommandType = type;
Parms(com, parms);
return com.ExecuteNonQuery();
} private static void Parms(SqlCommand com, SqlParameter[] param)
{
if (param != null)
{
foreach (SqlParameter p in param)
{
com.Parameters.Add(p);
}
}
} 在類中調用上面地方法string sql = 「delete from 資料庫表名 where 條件=@Id「; SqlParameter[] parm = new SqlParameter[]
{
new SqlParameter("@Id",傳入的參數值 };
SqlHelper.ExecuteNonQuery(sql.ToString(), CommandType.Text, parm);
} 這樣就可以了
⑷ 各位大哥,求在datagridview中刪除選中行,並刪除資料庫中數據的代碼!
你是選中行,能獲取到該行的id號吧,然後你直接就執行刪除資料庫記錄就行了
,你可以把刪除寫個存儲過程,傳進去id刪除該記錄,然後你重新對datagridview進行數據綁定就可以了
⑸ 在C#程序中如何刪除資料庫
是SQL
Server的話
我知道資料庫如果要手動刪除的話需要
停止或暫停資料庫服務、或者先分離資料庫
再刪除物理文件~
我只做過刪除資料庫數據的(用T-Sql語句)
並沒用刪除過資料庫文件、
如果C#代碼能執行此操作的話、那C#肯定有個類能夠訪問資料庫服務並能夠對服務做操作
而我做的時候只訪問過數據並沒有操作過資料庫引擎
所以具體是什麼類我就不清楚了
⑹ 求使用sql語句創建和刪除資料庫的代碼
1、使用create
database創建資料庫test
create
database
test
on
primary
(
name
=
'test',
filename='c:\program
files\microsoft
sql
server\mssql\data\test.mdf',
size=10240kb,
maxsize
=
unlimited,
filegrowth
=
10%)
log
on
(
name='test_log',
filename='c:\program
files\microsoft
sql
server\mssql\data\test_log.ldf',
size=1024kb,
maxsize
=
5120kb,
filegrowth
=
1024kb
)
go
2.
使用alter
database語句修改資料庫
例4-3將兩個數據文件和一個事務日誌文件添加到test資料庫中。
程序清單如下:
alter
database
test
add
file
(name
=
test1,
filename='c:\program
files\microsoft
sql
server\mssql\data\test1.ndf',
size
=
5mb,
maxsize
=
100mb,
filegrowth
=
5mb),
(name
=
test2,
filename='c:\program
files\microsoft
sql
server\mssql\data\test2.ndf',
size
=
3mb,
maxsize
=
10mb,
filegrowth
=
1mb)
go
alter
database
test
add
log
file
(
name
=
testlog1,
filename='c:\program
files\microsoft
sql
server\mssql\data\testlog1.ldf',
size
=
5mb,
maxsize
=
100mb,
filegrowth
=
5mb)
go
3、重命名test為demo
sp_renamedb
'test','demo'
4、刪除資料庫
drop
database
demo