【发布时间】:2008-11-11 13:14:38
【问题描述】:
我想知道是否可以从一个表中选择某些列,并从第二个表中选择另一列,这与第一个表中的未导入列有关。我必须从 access 中获取这些数据,不知道这是否可以使用 Access 或一般的 SQL。
【问题讨论】:
我想知道是否可以从一个表中选择某些列,并从第二个表中选择另一列,这与第一个表中的未导入列有关。我必须从 access 中获取这些数据,不知道这是否可以使用 Access 或一般的 SQL。
【问题讨论】:
假设如下表结构:
CREATE TABLE tbl_1 (
pk_1 int,
field_1 varchar(25),
field_2 varchar(25)
);
CREATE TABLE tbl_2 (
pk_2 int,
fk_1 int,
field_3 varchar(25),
field_4 varchar(25)
);
您可以使用以下内容:
SELECT t1.field_1, t2.field_3
FROM tbl_1 t1
INNER JOIN tbl_2 t2 ON t1.pk_1 = t2.fk_1
WHERE t2.field_3 = "Some String"
关于 Bill 的帖子,有两种方法可以在 SQL 查询中创建 JOIN:
隐式 - 连接是使用 在 FROM 子句中指定了多个表的查询的 WHERE 子句
显式 - 连接是使用 合适类型的 JOIN 子句 (内、左、右、全)
始终建议您使用显式 JOIN 语法,因为一旦查询变得更复杂,隐式连接就会出现问题。
例如,如果您稍后将显式连接添加到已使用隐式连接与 FROM 子句中引用的多个表的查询,则 FROM 子句中引用的第一个表对显式连接的表将不可见。
【讨论】:
【讨论】:
我不是 100% 确定我理解你的问题。
以下是否属实:
您的第一个表是从其他地方导入的。 您只导入一些列。 您想构建一个引用您尚未导入的列的查询。
如果这是真的,那是不可能的。就所涉及的 Access 查询引擎而言,未导入的列不存在。
为什么不直接导入它们呢?
【讨论】:
但是主键让查询更高效
【讨论】: