SQL Server 隨機求和

來源:互聯網
上載者:User

需求:隨機取表中3條資料,要求3條資料中欄位Price的和在範圍600-700之間。

CREATE DATABASE db_Test
GO
USE db_Test
GO
CREATE TABLE tb_Test
(
[Id] int IDENTITY(1,1),
[Price] decimal(10,2)
)
GO
INSERT INTO tb_Test VALUES(200)
INSERT INTO tb_Test VALUES(300)
INSERT INTO tb_Test VALUES(400)
INSERT INTO tb_Test VALUES(500)
INSERT INTO tb_Test VALUES(600)
INSERT INTO tb_Test VALUES(700)
INSERT INTO tb_Test VALUES(800)
INSERT INTO tb_Test VALUES(80)
INSERT INTO tb_Test VALUES(10)
INSERT INTO tb_Test VALUES(20)
INSERT INTO tb_Test VALUES(50)
INSERT INTO tb_Test VALUES(90)
INSERT INTO tb_Test VALUES(30)
INSERT INTO tb_Test VALUES(40)
INSERT INTO tb_Test VALUES(60)
INSERT INTO tb_Test VALUES(70)
INSERT INTO tb_Test VALUES(100)
INSERT INTO tb_Test VALUES(330)
INSERT INTO tb_Test VALUES(520)
INSERT INTO tb_Test VALUES(180)
GO

SELECT * FROM tb_Test WHERE EXISTS
(
SELECT * FROM
(
SELECT TOP 1 id1,id2,id3 FROM
(
SELECT a.Id AS id1,b.Id AS id2,c.Id AS id3
FROM tb_Test a,tb_Test b,tb_Test c
WHERE a.Id<b.Id and b.Id<c.Id
AND (a.Price+b.Price+c.Price) >= 600
AND (a.Price+b.Price+c.Price) <= 700
) t ORDER BY NEWID()
) j
WHERE tb_Test.Id = j.id1 OR tb_Test.Id = j.id2 OR tb_Test.Id = j.id3
)

若有疑問或不正之處,歡迎提出指正和討論。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.