> 데이터 베이스 > MySQL 튜토리얼 > SQLServerMASTER..spt

SQLServerMASTER..spt

WBOY
풀어 주다: 2016-06-07 15:15:20
원래의
1457명이 탐색했습니다.

常常见到这个表,人家用得天花乱坠的。 自己select一看却莫名其妙的。 花点时间学下吧。 如上, 这个表主要用来保存一些枚举, 据说是从sybase继承过来,许多函数和存储过程可以看到它的身影。也可以叫系统常量表吧。 里面的东西比较多, 但最常用的是: --0

常常见到这个表,人家用得天花乱坠的。 自己select一看却莫名其妙的。 花点时间学下吧。

SQLServerMASTER..spt

如上, 这个表主要用来保存一些枚举值, 据说是从sybase继承过来,许多函数和存储过程可以看到它的身影。也可以叫系统常量表吧。

里面的东西比较多, 但最常用的是:

--0~2047 共2048个数字
SELECT number FROM MASTER..spt_values WHERE  TYPE = 'p'
로그인 후 복사

下面举例一些应用:

1. 给定一个值, 希望得到某个日间范围的日期数据。

比如:已知今天是: 2015-01-30, 那后面连续30天的日期则为:

SELECT CONVERT(CHAR(10), DATEADD(DAY, number, GETDATE()), 120) AS [日期]
FROM MASTER..spt_values WHERE TYPE='P' AND number>0
로그인 후 복사

2.  等分数
--将一个数值以 1 来均分成多个等份,不足的显示小数
;WITH cte(past) AS(
         SELECT 2.2
     )
SELECT number,
       (
           CASE 
                WHEN past >= number THEN 1.0      --当原小数值>当前行值显示 1.0
                ELSE past -FLOOR(past)			  --否则显示为小数值
           END
       ) AS result
FROM   cte,
       MASTER..spt_values
WHERE  
	   1=1
	   AND CEILING(past) >= number	--原小数值向上取大 >= number
       AND TYPE = 'P'
       AND number > 0
/*
number      result
----------- ---------------------------------------
1           1.0
2           1.0
3           0.2
*/
로그인 후 복사

由此可见, 这个玩意还是挺灵活的, 关键看你怎么用吧。

不过也有局限, 毕竟它连续的只有 0~2047个数字



관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿