1、SQL
站在用戶的角度思考問題,與客戶深入溝通,找到襄陽網(wǎng)站設(shè)計與襄陽網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設(shè)計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:成都網(wǎng)站建設(shè)、成都網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣、空間域名、網(wǎng)站空間、企業(yè)郵箱。業(yè)務(wù)覆蓋襄陽地區(qū)。
Server
可以在表中直接設(shè)定某個字段為自增序列字段,來得比ORACLE容易得多,具體操作參看下圖:
(當(dāng)然,也可以使用建表語句或修改表的語句來實現(xiàn)。)
相關(guān)知識點延伸:
1、MS
SQL
沒有特定的
dual
表,也沒有系統(tǒng)級的sequence。
2、Sequence是數(shù)據(jù)庫系統(tǒng)的特性,有的數(shù)據(jù)庫實現(xiàn)了Sequence,有的則沒有。比如Oracle、DB2、PostgreSQL數(shù)據(jù)庫實現(xiàn)Sequence,MySQL、SQL
Server、Sybase等數(shù)據(jù)庫沒有Sequence。
3、但這并不表明MS
SQL或ORACLE哪一個差,只是實現(xiàn)的思維方式,理念上的差別。
4、正是因為這兩個數(shù)據(jù)庫在思維、理念上有很多的差別,所以,雖然這兩個是使用得最多的大型數(shù)據(jù)庫,但針對Oracle設(shè)計的中大型數(shù)據(jù)庫非常難移植到MS
SQL上,反過來也是一樣,要想移植,其工作量往往接近于重寫。
一、序列號保存在哪
不要被ProductCode迷惑,就算只安裝了SQL Server客戶端,注冊表里也會有這個鍵值,并不是序列號,DigitalProductID才是,但經(jīng)過了Base24編碼,需要解碼才行。
可以看到,對于不同版本,注冊表的路徑不一樣,但是鍵是一致的。
Express版是免費的,沒有序列號,從而注冊表也沒DigitalProductID這個鍵。
二、如何解碼序列號
利用Powershell 解碼
以下powershell函數(shù)用于解碼/找回SQL Server序列號,在SQL Server 2008, 2008 R2實例上測試通過:
SQL Server 2012序列號里字符的格式發(fā)生了變化, data.uValue)[0..16] 不同于SQL Server 2008的 data.uValue)[52..66],同時別忘了改下注冊表路徑$regPath = "SOFTWARE\Microsoft\Microsoft SQL Server\110\Tools\Setup",修改后如下,在SQL Server 2012實例上測試通過:
調(diào)用powershell函數(shù)并輸出序列號
打開powershell,把上面的函數(shù)貼進去,回車,輸入Get-SQLServerKey 并回車;
或者把上面的函數(shù)存為.ps1文件直接引用:
輸出結(jié)果如下:
根據(jù)powershell 腳本翻譯成的Python base24 解碼函數(shù):
序列就類似于自增列,比自增列靈活
可以設(shè)置最大值,在同一個范圍內(nèi)循環(huán)
MICROSOFT SQL SERVER 2012 企業(yè)核心版激活碼序列號: FH666-Y346V-7XFQ3-V69JM-RHW28
MICROSOFT SQL SERVER 2012 商業(yè)智能版激活碼序列號: HRV7T-DVTM4-V6XG8-P36T4-MRYT6
MICROSOFT SQL SERVER 2012 開發(fā)版激活碼序列號: YQWTX-G8T4R-QW4XX-BVH62-GP68Y
MICROSOFT SQL SERVER 2012 企業(yè)服務(wù)器版/CAL版激活碼序列號: 748RB-X4T6B-MRM7V-RTVFF-CHC8H
MICROSOFT SQL SERVER 2012 標(biāo)準(zhǔn)版激活碼序列號: YFC4R-BRRWB-TVP9Y-6WJQ9-MCJQ7
MICROSOFT SQL SERVER 2012 WEB版激活碼序列號: FB3W8-YRXDP-G8F8F-C46KG-Q998F
sequence 要到 sql servler2012 的版本, 才有。
SQL Server 2000, 2005, 2008 是沒有 sequence 這樣的對象的。
如果你要實現(xiàn)一個 自動遞增列的處理
SQL Server 通過 IDENTITY 來設(shè)置
參數(shù)有2個,一個是“初始值” 一個是“增量”。
默認(rèn)情況下 INSERT 語句中,不能對 IDENTITY 的字段進行賦值。
對于 IDENTITY 的列 SQL Server 在 INSERT 的時候,會自動忽略掉。
當(dāng)IDENTITY列中間的數(shù)據(jù)被刪除,造成數(shù)據(jù)不連續(xù)的時候??梢酝ㄟ^ SET IDENTITY_INSERT 表名 ON/OFF 語句來 允許/禁止 對IDENTITY列進行顯式的插入動作。
IDENTITY只能在如下情況下建立:
在創(chuàng)建表時創(chuàng)建新的IDENTITY列
在現(xiàn)有表中創(chuàng)建新的IDENTITY列
不能 把已經(jīng)存在的列,修改為IDENTITY列
1 CREATE TABLE test_create_tab2 (
2 id INT IDENTITY(1, 1) PRIMARY KEY,
3 val VARCHAR(10)
4 );
5 go
1 INSERT INTO test_create_tab2(val) VALUES ('NO id');
2 go
(1 行受影響)
選擇開始菜單,在 Microsoft SQL Server 2008 R2 菜單下,選擇 配置工具 , 選擇 SQL Server 安裝中心(64位)。打開安裝中心后,在左邊菜單選擇 維護 , 然后選擇第一項 版本升級, 然后根據(jù)向?qū)?,在輸入序列號頁面輸入新的序列號,根?jù)向?qū)乱徊?,選擇升級的實例,就可以完成更改序列號的過程了。
在安裝的過程中,有一個界面,要求輸入序列號的。如果整個安裝過程沒有要求,可能你的軟件授權(quán)是不需要輸入序列號的那種。