我的ms access sql查询有问题。 我想从报告获取每个 ReportPosition 。在每个 ReportPosition 中,已故的Pknr的名字和姓氏及其类型均已过世。以及匹配的养老金领取者的pknr名和姓
我有以下表格:
ReportPosition
+-----------------------+---------------+----------+
| ReportPositionId(PK1) | ReportId(PK1) | Pknr(FK) |
+-----------------------+---------------+----------+
| 1 | 1 | 123121 |
| 2 | 1 | 456451 |
| 3 | 1 | 789782 |
+-----------------------+---------------+----------+
养老金领取者
+----------+-----------+------------+--------------+--------------+
| PKNR(PK) | LastName | FirstName | PKNRdeceased | deceasedType |
+----------+-----------+------------+--------------+--------------+
| 123121 | Lastname1 | Firstname1 | 123120 | 1 |
| 456451 | Lastname2 | Firstname2 | 456450 | 1 |
| 789782 | Lastname3 | Firstname3 | 789780 | 2 |
| 123120 | Lastname4 | Firstname4 | 0 | 0 |
| 456450 | Lastname5 | Firstname5 | 0 | 0 |
| 789780 | Lastname6 | Firstname6 | 0 | 0 |
+----------+-----------+------------+--------------+--------------+
deceasedType
+--------+-------------+
| TypeId | Bez |
+--------+-------------+
| 0 | Pensioner |
| 1 | Widow |
| 2 | first Child |
+--------+-------------+
我需要以下输出:
+----------------+----------+--------+-----------+------------+---
| ReportPosition | ReportId | PKNR | lastname | firstname |
+----------------+----------+--------+-----------+------------+---
| 1 | 1 | 123121 | lastname1 | firstname1 |
| 2 | 1 | 456451 | lastname2 | firstname2 |
| 3 | 1 | 789782 | lastname3 | firstname3 |
+----------------+----------+--------+-----------+------------+---
--+--------------+--------------+---------------------+--------------------+
| deceasedtype | PKNRdeceased | lasttname deaceased | firstname deceased |
--+--------------+--------------+---------------------+--------------------+
| 1 | 123120 | lastname4 | firstname4 |
| 1 | 456450 | lastname5 | firstname5 |
| 2 | 789780 | lastname6 | firstname6 |
--+--------------+--------------+---------------------+--------------------+
我已经尝试过了,但是没有得到想要的结果: 我使用了Access中的自动查询创建功能,因为手动编写查询对我来说很难。
SELECT ReportPosition.ReportPositionId, ReportPosition.ReportId, ReportPosition.PKNR, deceased.lastname, deceased.firstname, PensionerType.Bez, Pensioner.PKNR, Pensioner.lastname, Pensioner.firstname
FROM (PensionerType INNER JOIN (ReportPosition INNER JOIN Pensioner AS deceased ON ReportPosition.PKNR = deceased.PKNR) ON PensionerType.TypeId = deceased.PensionerType) INNER JOIN Pensioner ON deceased.PKNR = Pensioner.pknrdeceased
WHERE ReportPosition.ReportId=1;
我需要类似selfjoin之类的东西,因为我必须与养老金领取者一起加入养老金领取者,对吗?
目前,我什至没有得到我需要的所有列。也不是我想要的每个数据集。
答案 0 :(得分:2)
只要不需要已故类型的Bez
,只需添加ReportPosition
和Pensioner
表,并在其中添加Pensioner
表两次:
然后,添加您想返回的字段,您将Pensioner_1
视为“已故”。结果查询的SQL看起来应与此类似:
SELECT ReportPosition.ReportPositionId, ReportPosition.ReportId,
Pensioner.PKNR, Pensioner.LastName, Pensioner.FirstName, Pensioner.deceasedType, Pensioner.PKNRdeceased,
Pensioner_1.LastName AS [Lastname deceased], Pensioner_1.FirstName AS [Firstname deceased]
FROM Pensioner AS Pensioner_1 INNER JOIN
(Pensioner INNER JOIN ReportPosition ON Pensioner.PKNR = ReportPosition.Pknr)
ON Pensioner_1.PKNR = Pensioner.PKNRdeceased;
当然,您可以将别名从Pensioner_1
更改为deceased
。
已添加
:如果要显示Bez
字段(而不是TypeId
),则必须添加deceasedType
表:
然后可以从新添加的表中的deceasedType
字段交换Bez
字段。编辑后的查询的SQL看起来类似于:
SELECT ReportPosition.ReportPositionId, ReportPosition.ReportId,
Pensioner.PKNR, Pensioner.LastName, Pensioner.FirstName, deceasedType.Bez, Pensioner.PKNRdeceased,
Pensioner_1.LastName AS [Lastname deceased], Pensioner_1.FirstName AS [Firstname deceased]
FROM deceasedType INNER JOIN
((Pensioner AS Pensioner_1 INNER JOIN Pensioner
ON Pensioner_1.PKNR = Pensioner.PKNRdeceased) INNER JOIN
ReportPosition ON Pensioner.PKNR = ReportPosition.Pknr)
ON deceasedType.TypeId = Pensioner.deceasedType;
答案 1 :(得分:0)
我没有找到您的确切错误,但是Access中的查询生成器创建了一个非常混乱的联接符号,这对我来说很难理解。
据我所知,以下方法应该起作用:
SELECT ReportPosition.ReportPositionId, ReportPosition.ReportId, ReportPosition.PKNR, deceased.lastname, deceased.firstname, PensionerType.Bez, Pensioner.PKNR, Pensioner.lastname, Pensioner.firstname
FROM (((Pensioner
INNER JOIN Pensioner AS deceased ON deceased.PKNR = Pensioner.pknrdeceased)
INNER JOIN PensionerType ON PensionerType.TypeId = deceased.PensionerType)
INNER JOIN ReportPosition ON ReportPosition.PKNR = deceased.PKNR)
WHERE ReportPosition.ReportId=1;