當前位置:首頁 » 數據倉庫 » 失效資料庫表的sql
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

失效資料庫表的sql

發布時間: 2022-06-29 10:14:31

sql2000資料庫的系統表出錯,怎麼修復syscolumns和sysobjects

用dbcc
checkdb
檢查資料庫。
DBCC
CHECKDB
重啟伺服器後,在沒有進行任何操作的情況下,在SQL查詢分析器中執行以下SQL進行資料庫的修復,修復資料庫存在的一致性錯誤與分配錯誤。
use
master
declare
@databasename
varchar(255)
set
@databasename='需要修復的資料庫實體的名稱'
exec
sp_dboption
@databasename,
N'single',
N'true'
--將目標資料庫置為單用戶狀態
dbcc
checkdb(@databasename,REPAIR_ALLOW_DATA_LOSS)
dbcc
checkdb(@databasename,REPAIR_REBUILD)
exec
sp_dboption
@databasename,
N'single',
N'false'--將目標資料庫置為多用戶狀態
然後執行
DBCC
CHECKDB('需要修復的資料庫實體的名稱')
檢查資料庫是否仍舊存在錯誤。注意:修復後可能會造成部分數據的丟失。

Ⅱ SQL 為什麼我的column失效了

你的sql語句中有一列數據的列名(欄位)是在資料庫中沒有的,估計是你的列名打錯了或者資料庫中根本沒有這個欄位。仔細檢查一下吧!
希望能幫到你!

Ⅲ SQl server 的數據表無故丟失,這是為什麼呢

你的aaa資料庫已經被損壞了,原因未知(不一定是它提示的空間不足什麼的)。如果僅僅是你測試或學慣用的庫,重新建一個就好了。
如果裡面有重要數據,找找以前有沒有備份吧,沒有的話,參照下面的資料弄弄,這些資料是在網上幫你查的。

----------------------------------------
錯誤 945
嚴重級別 16
消息正文
由於文件不可訪問,或者內存或磁碟空間不足,所以無法打開資料庫 ''%1!''。詳細信息請參見 SQL Server 錯誤日誌。

解釋
當資料庫標記為 IsShutdown 時返回錯誤 945。當由於丟失文件或某些其它資源錯誤(這些錯誤的更正通常比較容易)而無法恢復資料庫時,發生該錯誤。

對策
首先,使用 DATABASEPROPERTY 驗證資料庫是否標記為 IsShutdown。

然後,通過查閱錯誤日誌確定錯誤的起因,並採取下列對策。

如果一個或多個數據或日誌文件丟失:
使這些文件可用,並使用 ALTER DATABASE 使資料庫 OFFLINE(離線)。

使用 ALTER DATABASE 以使資料庫 ONLINE(聯機)
如果日誌空間不足:
使用 sp_add_log_file_recover_suspect_db() 添加其它的日誌文件。
該過程恢復資料庫並使其聯機。

如果數據空間不足:
使用 sp_add_data_file_recover_suspect_db() 添加其它的日誌文件。
該過程恢復資料庫並使其聯機。

如果內存不足:
當同時恢復許多資料庫時可能發生內存不足錯誤。重試該操作可能修復問題:

重試操作,使用 ALTER DATABASE 以使資料庫 OFFLINE。

使用 ALTER DATABASE 以使資料庫 ONLINE。
如果重試操作不起作用,則考慮釋放內存。
---------------------------------------------------

如果確實有重要數據而上面的方法又沒有作用的話。。。樓主往寬里想吧,人生一萬來天,誰還不會遇到點兒倒霉事兒啊。。。

Ⅳ oracle資料庫中,為什麼寫了DESC 表名,執行以後是無效的SQL語句呢

在什麼地方寫的,只有在命令行模式(比如sqlplus或者pl/sql的命令模式下)才能這么寫,其他時候很少有命令模式,一般都是通過各種客戶端連接的,這些客戶端不是命令模式的,而是查詢模式,這種情況下,非sql語句的命令是不好使的。

Ⅳ 用select語句查詢sql數據表的時候,為什麼會出現數據表對象名無效

肯定是沒連接對資料庫,對象名無效,就是資料庫中沒有你查詢的表。

Ⅵ SQL刪除資料庫中的所有數據

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 清空的表的定義與其索引和其他關聯對象一起保留在資料庫中。

Ⅶ 獲取表中失效時間 小於當前時間+1天的數據 SQL怎麼寫

sqlserver:
select * from tabname where 失效時間 < DATEADD(DAY,getdate(),1)
oracle:
select * from tabname where 失效時間 < sysdate + 1

Ⅷ 為什麼打不開SQL資料庫的表

連接字元串中沒有指明使用哪個資料庫作為數據源,而使用了默認的數據源(大概是master),默認的數據源中不存在名為TABLE1的表,所以出錯了吧。怎麼不用控制項?這樣寫容易搞錯,用ADO.NET控制項,對話框里可以選擇的,包括伺服器是本地的還是網路上的,驗證模式是windows還是混合的,使用的資料庫名,然後計算機在後台就幫你把代碼寫好了。

Ⅸ 在SQL2005用SELECT語句查詢PUTS資料庫中的表,PUTS資料庫有這個表,為什麼還說表無效

你可能沒有跳轉到有puts這個表的資料庫吧!你確定有這個表,先用:
sql>use " 你要跳轉到的資料庫"
sql>select * from puts;

Ⅹ 在打開sqlservice資料庫中的每一個資料庫或者是表時總是出現目錄名無效,該怎麼解決呢

首先你看看你調用資料庫的時候表名有沒有寫錯,如果沒有寫錯,去看看你所使用的資料庫是不是你調用的那個,確保不是master