当前位置:首页 » 编程语言 » sql查询多个订单
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

sql查询多个订单

发布时间: 2023-08-07 00:02:52

㈠ 订单列表查询sql,查询出订单的数量和订单详细信息(包括订单中的所有商品)。

select m.订单编号,m.订单总额 , d.商品名称 , d.商品单价

from order_t m,order_good_t d

where m.订单编号 = d.订单编号

(1)sql查询多个订单扩展阅读:

SQL中最常见的操作(查询)使用声明性SELECT语句。 SELECT从一个或多个表或表达式中检索数据。标准SELECT语句对数据库没有持久影响。 SELECT的一些非标准实现可以具有持久性效果,例如某些数据库中提供的SELECT INTO语法。

WHERE子句包含比较谓词,它限制查询返回的行。 WHERE子句从结果集中删除比较谓词未计算为True的所有行。

GROUP BY子句将具有公共值的行投影到较小的行集中。 GROUP BY通常与SQL聚合函数结合使用,或者从结果集中消除重复的行。 WHERE子句在GROUP BY子句之前应用。

㈡ SQL 子查询

所谓 SQL 子查询就是嵌套在其他查询中的查询。子查询通常用于 WHERE 子句的 IN 操作符中进行过滤,以及用来填充计算列。下面我们从这两种使用场景展开学习。

本节涉及到关系表如下:

最上方的订单表 Orders 存储了订单 ID 、订单日期以及顾客 ID ;具体的订单信息存储在 OrderItems 表中,通过 order_num 进行关联;具体的顾客信息存储在顾客表 Customers 中,通过 cust_id 字段进行关联。

下面,假设我们需要检索出购买了 RGA01 产品的所有顾客信息,应该怎么做呢?

首先,我们只列出步骤:

接下来,我们来完成第一步:

包含了产品 RGAN01 的订单编号:

有了订单编号,就可以从订单表检索出顾客 ID 了:

运行结果:

接下来,我们来合并上面的两步:把第一个查询变为子查询,放在 WHERE 语句的 IN 操作符之后:

运行结果和上述第二步获得的结果是一样的:

SELECT 语句中子查询从内向外处理:首先执行 SELECT order_num FROM OrderItems WHERE prod_id = 'RGAN01' 子查询,将返回的订单号作为 IN 操作符的参数,执行外部查询: SELECT cust_id FROM Orders WHERE order_num IN ( 20007, 20008 ); 。

最后,我们来看第三步,根据顾客 ID 检索出顾客相关信息。

运行结果:

同理,我们可以将上述的 WHERE 子句替换为子查询:

至此,我们的检索任务就完成了:查询购买了 RGAN01 商品的所有顾客姓名及联系方式。

子查询的另一个使用场景为创建计算字段。同样,我们以一个案例来学习:检索每个顾客的订单的总数。

顾客表与订单表是一对多的关系,即一个顾客对应多个订单,但一个订单只对应一个顾客。

如下的 SQL 检索出顾客 1000000001 的订单数:

要对每个顾客的订单计数,应该将其作为子查询:

运行结果:

上述 SQL Customers 表中每个顾客返回三列: cust_name cust_state 和 orders 。其中 orders 为子查询创建的计算字段,该子查询对检索出的每个顾客都执行一次,一共执行了 6 次子查询。

在子查询的条件中,我们使用了表的完全限定列名 Orders.cust_id = Customers.cust_id ,这是因为 Orders 表和 Customers 表中包含了字段名名称相同的列。

本节我们学习了在 SELECT 语句中使用子查询的两种用法:将子查询应用于 WHERE 子句的 IN 操作符中,进行条件过滤,以及用子查询创建计算字段。

子查询的检索效率不够理想,下一篇文章中小鱼将和大家展开联结表的学习~ 连接表 是数据检索的精华和重点,我们拭目以待吧!

㈢ SQL-查询上海和北京的客户在1996年订购的所有订单的订单ID,所订购的产品名称和数量

select 订单明细.数量,产品名称,订单.订单ID,城市
from 订单明细,产品,订单,客户
where 城市 IN('上海','北京')and 订购日期 ='1996'

首先 这些表需要连接么? 再是订购日期 是什么类型,他就是表示整年的么?

如果这些你都写对的话,那么

你把这条SQL分为两部分执行:

  1. select 订单明细.数量,产品名称,订单.订单ID,城市
    from 订单明细,产品,订单,客户
    where 城市 IN('上海','北京')

  2. select 订单明细.数量,产品名称,订单.订单ID,城市
    from 订单明细,产品,订单,客户
    where 订购日期 ='1996'

再分别看里面的数据是否存在!

㈣ 如何使用SQL语句在一个表中查询: 同一个人购买两个以上相同产品的记录要求显示所有符合条件的人.

select SaleID,GoodsID from Table

group by SaleID,GoodsID

例如:

select f1,f2,...,fn

from table

group by f1,f2,...,fn

having count(1)>1 查出存在相同的f1,f2,..,fn

想查找出记录则

select t1.* from table t1

(4)sql查询多个订单扩展阅读:

更新:update table1 set field1=value1 where 范围

查找:select * from table1 where field1 like ’%value1%’ (所有包含‘value1’这个模式的字符串)

排序:select * from table1 order by field1,field2 [desc]

求和:select sum(field1) as sumvalue from table1

平均:select avg(field1) as avgvalue from table1

㈤ 要查询很多个订单,每个订单里有很多个商品,应该怎么处理,查询结果是放在Map还是List里,应该怎么放

首先你的订单表是怎么设计的。
商品表肯定是商品id,商品名称等信息,绝对不会有订单id在商品表。
订单表有这样的设计方式,订单id,商品id。唯一值肯定不是订单id,可以设置为自增列。一行数据只放一个商品id。相当于一个订单id有多行数据。
那这样就很简单了。
你点击某个订单查看里面详情的时候,点击事件传的肯定是订单id。然后在订单表里面加where条件,把该订单所有数据查找出来,然后在关联商品表,例如下面sql:
select * from dingdan dd
left join shangpin sp on sp.商品id=dd.商品id
where dingdanID='订单号1'
至于你要把这个sql结果集放到什么里面,list,还是dataset,还是datatable就由你决定了。

㈥ 查询一个商品有几个订单的SQL语句

select Name, count(Name) from SP group by Name
或者
select Name, sum(订单金额字段) from SP group by Name

㈦ 怎么用sql语句查询历史订单量

selecttop(5000)substring(convert(varchar(30),TransactionTime,20),1,11)日期,count(*)as数量fromdbo.Ledger
groupbysubstring(convert(varchar(30),TransactionTime,20),1,11)

substring(convert(varchar(30),TransactionTime,20),1,10)

最后的参数11改为10

㈧ SQL的一些查询语句

--1、列出订单明细表中订单ID列表,要求去掉所有重复值。
SELECT DISTINCT 订单ID FROM 订单明细
--2、列出产品的最高库存量、最低库存量和平均库存量
SELECT MAX(库存量) 最高库存量,MIN(库存量) 最低库存量,AVG(库存量) 平均库存量 FROM 产品
--3、统计订单数量。
SELECT COUNT(*) 订单数量 FROM 订单
--4、按货主地区统计订单数量。
SELECT 货主地区,COUNT(*) 订单数量 FROM 订单 GROUP BY 货主地区
--5、列出所有订阅大米的客户名称。
SELECT 公司名称 AS 客户名称 FROM 客户 JOIN 订单 ON 客户.客户ID=订单.客户ID
JOIN 订单明细 ON 订单明细.订单ID=订单.订单ID
JOIN 产品 ON 产品.产品ID=订单明细.订单ID
WHERE 产品名称='大米'
--6、列出库中的所有订单的客户ID,产品ID和发货日期。
SELECT 客户ID,产品ID,发货日期 FROM 订单 JOIN 订单明细 ON 订单明细.订单ID=订单.订单ID
--7、按发货日期的顺序,列出所有的所有订单的客户ID,产品ID。
SELECT 客户ID,产品ID FROM 订单 JOIN 订单明细 ON 订单明细.订单ID=订单.订单ID
ORDER BY 发货日期
--8、显示供应商表中姓“徐”的联系人的地址,城市,电话,公司名称以及邮编。(用三种方法实现)
SELECT 地址,城市,电话,公司名称,邮政编码 FROM 客户 WHERE 联系人姓名 LIKE '徐%'
SELECT 地址,城市,电话,公司名称,邮政编码 FROM 客户 WHERE LEFT(联系人姓名,1)='徐'
SELECT 地址,城市,电话,公司名称,邮政编码 FROM 客户 WHERE CHARINDEX('徐',联系人姓名)>0
--9、 查找产品表中含有“米”的相关记录。
SELECT * FROM 产品 WHERE 产品名称 LIKE '%米%'
--10、在客户表中查找电话号码含有“010”的记录。(至少用两种方法实现)
SELECT * FROM 客户 WHERE 电话 LIKE '%010%'
SELECT * FROM 客户 WHERE CHARINDEX('010',电话)>0
--11、查找客户“黄雅玲”所订购的产品名称,定购量,及该客户的所在公司,职务,电话。
SELECT 产品名称,数量,公司名称,联系人职务,电话 FROM 客户 JOIN 订单 ON 客户.客户ID=订单.客户ID
JOIN 订单明细 ON 订单明细.订单ID=订单.订单ID
JOIN 产品 ON 产品.产品ID=订单明细.订单ID
WHERE 联系人姓名='黄雅玲'
--12、统计客户所订购的订单数,并显示相应的客户名,客户ID,订单数,并且根据订单数进行升序排序。
SELECT 公司名称 AS 客户名,客户ID,COUNT(*) 订单数 FROM 客户 JOIN 订单 ON 客户.客户ID=订单.客户ID
ORDER BY 3