a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 數據庫 > Oracle > 正文

如何在sqlserver2000中實現oracle的序列

2024-08-29 13:51:43
字體:
來源:轉載
供稿:網友
Oracle中的序列蠻好用的,但是在sqlserver中卻沒有,您也許會說我可以用IDENTITY來代替啊!當然可以,但是一個表中只能有一個IDENTITY字段!我要是想在一個表里使用多個類似IDENTITY的字段呢?如是oracle,用序列就可以實現,只要給該字段指定一個序列就可以了!在SQLSERVER中如何實現呢?SQL2000可以有自定義函數,我們可以自定義一個函數,來產生一個序列,然后在給需要使用該序列的字段指定該函數即可!下面是一個例子:
假設:
存在表
CREATE    TABLE    tmp
(
    identityID    INT identity(1,1) PRIMARY KEY,
    iID        INT,
    sName        CHAR(2)
)
GO
其中identityID是一個IDENTITY字段,
我們創建以下函數:
CREATE    FUNCTION    sqlSequence()
RETURNS    INT
AS
BEGIN
    DECLARE    @MINNUM    INT
    DECLARE    @MAXNUM    INT
    SET    @MINNUM=2   
    SET    @MAXNUM=99
/*
    您可以設置該函數答應的最大(99)、小(2)值,代表從取2-99,超過此最大值返回0(您可以加上自己的處理),
    仿oracle的sequence中的設置
*/
    RETURN(    SELECT CASE   
            WHEN    ISNULL(MAX(iID),@MINNUM-1)+1 >@MAXNUM THEN    0
            ELSE    ISNULL(MAX(iID),@MINNUM-1)+1
               END
        FROM TMP)
END
GO
然后給表tmp的字段iID的默認值指定為dbo.sqlSequence(),
然后再插入時使用如下語句即可
insert into tmp(sname) values('1');
插入一些記錄后看看效果吧!
其實還可以給該函數加上更多的功能,如可以返回一個降序的序列,
也可以返回一個字符串的序列。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 久久成人在线 | 97视频在线 | 国产精品久久久久久久久久久免费看 | 久久久久久久久久一本门道91 | 国产精品国产 | 日韩在线欧美 | 在线免费观看色视频 | 91视频播放 | 精品视频久久 | 国产精品久久久久免费视频 | 夜夜躁狠狠躁夜躁2021鲁大师 | 日韩一区二区三区在线 | 香蕉久久网 | 日本精品一区二区三区视频 | 国产精品久久久久久久久福交 | 国产精品免费av | 日韩一区二区三区在线观看 | 一区二区久久 | 一区二区三区四区国产 | 日韩欧美国产成人一区二区 | 国产精品久久久久久久久久久久冷 | 日av在线播放 | 欧美第一色 | 亚洲欧美一区二区三区 | 成人精品久久 | 国产精品一区二区欧美 | 国产探花在线观看 | 国产免费拔擦拔擦8x高清 | 国产极品美女高潮抽搐免费网站 | 男女精品| 国产在线一区二区 | 成人国产精品免费观看 | 超碰人人艹 | 色橹橹欧美在线观看视频高清 | 亚洲福利小视频 | 国产成人精品亚洲男人的天堂 | 久久久久久久av | 久久这里只有精品23 | 中文av在线免费观看 | 羞羞视频免费在线观看 | 国产精品中文字幕一区二区 |