sql檢查表
1. sql server 如何查找最後一條插入的記錄
SCOPE_IDENTITY、IDENT_CURRENT 和 @@IDENTITY
是相似的函數,因為它們都返回插入到標識列中的值。
IDENT_CURRENT 不受作用域和會話的限制,而受限於指定的表。IDENT_CURRENT
返回為任何會話和作用域中的特定表所生成的值。有關詳細信息,請參閱IDENT_CURRENT
(Transact-SQL)。
SCOPE_IDENTITY 和 @@IDENTITY
返回在當前會話中的任何錶內所生成的最後一個標識值。但是,SCOPE_IDENTITY 只返回插入到當前作用域中的值;@@IDENTITY
不受限於特定的作用域。
例如,有兩個表 T1 和 T2,並且在 T1 上定義了 INSERT 觸發器。當將某行插入 T1 時,觸發器被激發,並在 T2
中插入一行。該方案演示了兩個作用域:在 T1 上的插入,以及在 T2 通過觸發器的插入。
假設 T1 和 T2 都有標識列,@@IDENTITY 和 SCOPE_IDENTITY 將在 T1 上的 INSERT
語句的最後返回不同的值。@@IDENTITY 將返回在當前會話中的任何作用域內插入的最後一個標識列的值。這是在 T2
中插入的值。SCOPE_IDENTITY() 將返回在 T1 中插入的 IDENTITY 值。這是在同一個作用域內發生的最後的插入。如果在任何 INSERT
語句作用於作用域中的標識列之前調用 SCOPE_IDENTITY() 函數,則該函數將返回 Null。
如果語句和事務失敗,它們會更改表的當前標識,從而使標識列中的值出現不連貫現象。即使未提交試圖向表中插入值的事務,也永遠無法回滾標識值。例如,如果因
IGNORE_DUP_KEY 沖突而導致 INSERT 語句失敗,表的當前標識值仍然會增加。
節選自sqlserver 教程 SCOPE_IDENTITY (Transact-SQL)
2. 資料庫中如何查詢表的最後一條記錄
1、首先,創建一個測試,代碼如下圖所示,然後進入下一步。
3. sql如何查某個表某個欄位的數據類型
select a.name as [column],b.name as type
from syscolumns a,systypes b
where a.id=object_id('表名') and a.xtype=b.xtype and a.name='列名'
4. 怎麼查看mysql資料庫中的表是否損壞
可以使用語句檢查表。如果結果的msg_text部分是好的,那麼你的表是健康的。反之,則表明mysql資料庫中的表有損壞。另外有些厲害的高手一額可以通過運行腳本來檢測。
MyISAM表可以採用以下方法進行修復:使用reapair table或myisamchk來修復。如果修復無效,採用備份恢復表。
階段1:檢查你的表
如果你有很多時間,運行myisamchk *.MYI或myisamchk -e *.MYI。使用-s(沉默)選項禁止不必要的信息。如果mysqld伺服器處於宕機狀態,應使用--update-state選項來告訴myisamchk將表標記為'檢查過的'。
你必須只修復那些myisamchk報告有錯誤的表。對這樣的表,繼續到階段2。如果在檢查時,你得到奇怪的錯誤(例如out of memory錯誤),或如果myisamchk崩潰,到階段3。
階段2:簡單安全的修復
注釋:如果想更快地進行修復,當運行myisamchk時,你應將sort_buffer_size和Key_buffer_size變數的值設置為可用內存的大約25%。
首先,試試myisamchk -r -q tbl_name(-r -q意味著「快速恢復模式」)。這將試圖不接觸數據文件來修復索引文件。如果數據文件包含它應有的一切內容和指向數據文件內正確地點的刪除連接,這應該管用並且表可被修復。開始修復下一張表。否則,執行下列過程:
在繼續前對數據文件進行備份。使用myisamchk -r tbl_name(-r意味著「恢復模式」)。這將從數據文件中刪除不正確的記錄和已被刪除的記錄並重建索引文件。
如果前面的步驟失敗,使用myisamchk --safe-recover tbl_name。安全恢復模式使用一個老的恢復方法,處理常規恢復模式不行的少數情況(但是更慢)。如果在修復時,你得到奇怪的錯誤(例如out of memory錯誤),或如果myisamchk崩潰,到階段3。
階段3:困難的修復
只有在索引文件的第一個16K塊被破壞,或包含不正確的信息,或如果索引文件丟失,你才應該到這個階段。在這種情況下,需要創建一個新的索引文件。按如下步驟操做:
把數據文件移到安全的地方。使用表描述文件創建新的(空)數據文件和索引文件:
shell> mysql db_name
mysql> SET AUTOCOMMIT=1;
mysql> TRUNCATE TABLE tbl_name;
mysql> quit
如果你的MySQL版本沒有TRUNCATE TABLE,則使用DELETE FROM tbl_name。將老的數據文件拷貝到新創建的數據文件之中。回到階段2。現在myisamchk -r -q應該工作了。你還可以使用REPAIR TABLE tbl_name USE_FRM,將自動執行整個程序。
階段4:非常困難的修復
只有.frm描述文件也破壞了,你才應該到達這個階段。這應該從未發生過,因為在表被創建以後,描述文件就不再改變了。
從一個備份恢復描述文件然後回到階段3。你也可以恢復索引文件然後回到階段2。對後者,你應該用myisamchk -r啟動。
如果你沒有進行備份但是確切地知道表是怎樣創建的,在另一個資料庫中創建表的一個拷貝。刪除新的數據文件,然後從其他資料庫將描述文件和索引文件移到破壞的資料庫中。這樣提供了新的描述和索引文件,但是讓.MYD數據文件獨自留下來了。回到階段2並且嘗試重建索引文件。
5. mysql資料庫檢查表經常超時,怎樣解決
對查詢中經常作為查詢條件的欄位增加索引,比如說
select*fromtable1wherenamelike'xxx'andcreate_time>'2013-06-01'
這里就可以為name 和 create_time分別創建索引;
ALTERTABLEtable1ADDINDEX`ind_CreateTime`(`create_time`);
ALTERTABLEtable1ADDINDEX`ind_name`(`name`);
2. 優化導致慢查詢的SQL語句。可以將一條查詢分解為多條小范圍的查詢,將結果union在一起。盡量減少在where 條件中使用 like or between等運算符
6. --SQL循環查詢表
單個表的循環都做出來了,多表也一樣啊。
首先,去sysobjects表裡count(*)得出有多少個符合規則的用戶表,然後用while語句控制循環次數.
同時,把所有符合規則的表,放到一個臨時表裡,比如#TEMP表了。然後就可以利用游標讀取表名到變數中了.有了表名,那麼把你上面那堆代碼復制過去,簡單改下,就可以套在while循環了。
唯一需要掌握的,就是對游標的使用。以你上面的SQL功底,應該很容易理解。
7. SQL Server 如何查詢最後一條記錄
SQL Server 查詢最後一條記錄有兩種方法,一種是使用TOP命令,一種是使用LIMIT命令,具體方法如下:
1、使用TOP
SELECT TOP 1 * FROM user;
SELECT TOP 1 * FROM user order by id desc;
(7)sql檢查表擴展閱讀:
Sqlserver一些基本命令:
1、查詢資料庫是否存在:
if DB_ID("testDB")is not null;
2、檢查表是否存在:
if OBJECT_ID(「textDB」,「U」) is not null ;其中U代表用戶表
3、創建資料庫:
create database+數據名
SQL是英文Structured Query Language的縮寫,意思為結構化查詢語言。SQL語言的主要功能就是同各種資料庫建立聯系,進行溝通。按照ANSI(美國國家標准協會)的規定,SQL被作為關系型資料庫管理系統的標准語言。
SQL Server是由Microsoft開發和推廣的關系資料庫管理系統(DBMS)。