目錄
一、可重排列、排列、組合
1、創建表
2、錄入數據
3、獲取可重排列的商品名稱(有序)
4、獲取排列的商品名稱(有序)
5、獲取組合的商品名稱(無序)
6、獲取3個元素的組合商品名稱(無序)
二、?刪除重復行
1、創建表?
2、錄入數據
3、使用極值函數(保留最大ID)
4、使用非等值連接(保留最大ID)
三、排名
1、增加記錄
2、進行排名(自連接)
3、使用窗口函數進行排名
一、可重排列、排列、組合
1、創建表
CREATE TABLE `product` (`name` VARCHAR(50) NULL DEFAULT NULL COMMENT '商品名稱' COLLATE 'utf8mb4_0900_ai_ci',`price` INT(10) NULL DEFAULT NULL COMMENT '價格'
)
COMMENT='產品表'
COLLATE='utf8mb4_0900_ai_ci'
ENGINE=InnoDB
;
2、錄入數據
3、獲取可重排列的商品名稱(有序)
SELECT P1.name ,P2.name
FROM product P1,product P2
4、獲取排列的商品名稱(有序)
SELECT P1.name ,P2.name
FROM product P1,product P2
WHERE P1.name <> P2.name
5、獲取組合的商品名稱(無序)
SELECT P1.name ,P2.name
FROM product P1,product P2
WHERE P1.name > P2.name
6、獲取3個元素的組合商品名稱(無序)
SELECT P1.name ,P2.name, P3.name
FROM product P1,product P2,product P3
WHERE P1.name > P2.name
AND P2.name > P3.name
二、?刪除重復行
1、創建表?
CREATE TABLE `product` (`id` BIGINT(19) NOT NULL AUTO_INCREMENT,`name` VARCHAR(50) NULL DEFAULT NULL COMMENT '商品名稱' COLLATE 'utf8mb4_0900_ai_ci',`price` INT(10) NULL DEFAULT NULL COMMENT '價格',PRIMARY KEY (`id`) USING BTREE
)
COMMENT='產品表'
COLLATE='utf8mb4_0900_ai_ci'
ENGINE=InnoDB
AUTO_INCREMENT=4
;
2、錄入數據
3、使用極值函數(保留最大ID)
SELECT *
FROM product P1
WHERE id < (SELECT MAX(id) FROM product P2 WHERE P1.name = P2.name AND P1.price = P2.price)
4、使用非等值連接(保留最大ID)
SELECT *
FROM product P1
WHERE EXISTS (SELECT 1 FROM product P2 WHERE P1.name = P2.name AND P1.price = P2.price AND P1.id < P2.id)
三、排名
1、增加記錄
?
2、進行排名(自連接)
SELECT p1.name,p1.price,
(SELECT COUNT(p2.price) FROM product p2 WHERE p2.price > p1.price) +1 AS rank_1
FROM product p1
ORDER BY rank_1
?
3、使用窗口函數進行排名
SELECT id,NAME,price,
RANK() OVER (ORDER BY price DESC ) AS rank_1,
DENSE_RANK() OVER (ORDER BY price DESC ) AS rank_2,
ROW_NUMBER() OVER (ORDER BY price DESC ) AS row_number_1
FROM product