写一个sql 根据传递过来的参数 有Date类型的某年某月 格式为 01 00:00 :00 和memberId 在三张订单表里面获取数据 回显的数据要有 会员当月所有的订单金额,会员所有的当月总消费次数 用的postgresql
时间: 2024-03-14 21:44:59 浏览: 75
可以使用以下SQL语句来实现:
```
SELECT
SUM(amount) AS total_amount,
COUNT(*) AS total_count
FROM
(
SELECT
amount,
date_trunc('month', order_time) AS order_month
FROM
(
SELECT
amount,
order_time
FROM
order_table_1
WHERE
date_trunc('month', order_time) = '传递过来的日期参数'
AND member_id = '传递过来的memberId参数'
UNION ALL
SELECT
amount,
order_time
FROM
order_table_2
WHERE
date_trunc('month', order_time) = '传递过来的日期参数'
AND member_id = '传递过来的memberId参数'
UNION ALL
SELECT
amount,
order_time
FROM
order_table_3
WHERE
date_trunc('month', order_time) = '传递过来的日期参数'
AND member_id = '传递过来的memberId参数'
) AS orders
WHERE
date_trunc('month', order_time) = '传递过来的日期参数'
) AS monthly_orders;
```
其中,`order_table_1`、`order_table_2`、`order_table_3` 是三张订单表的表名,根据实际情况替换即可。`amount` 和 `order_time` 是订单表中的金额和下单时间字段,根据实际情况调整。`member_id` 是订单表中的会员ID字段,根据实际情况调整。`传递过来的日期参数` 和 `传递过来的memberId参数` 是传递过来的参数,根据实际情况替换即可。
阅读全文