使用传递查询中的数据更新 Microsoft Access 2013 表

Posted

技术标签:

【中文标题】使用传递查询中的数据更新 Microsoft Access 2013 表【英文标题】:Updating a Microsoft Access 2013 table with data from a pass-through query 【发布时间】:2016-06-03 16:05:33 【问题描述】:

到目前为止,我正在尝试使用 AS400 表 (LIBRARY.TABLE) 中的数据更新 Microsoft Access 2013 表(称为 tbl_Data)中的记录,但未成功。

正如您在下面的 Access 2013 直通查询中看到的那样,我正在尝试使用前缀和数字字段将访问表与 AS400 表连接起来,然后使用来自的名称和地址信息更新访问表AS400 表。

这是我最近的尝试:

 UPDATE 
      tbl_Data
 SET
      tbl_Data.FirstName = a.NINMFR,
      tbl_Data.MiddleName = a.NINMMD,
      tbl_Data.LastName = a.NINAML,
      tbl_Data.BuildingNumber = a.NIBLNR,
      tbl_Data.StreetName = a.NISTNM,
      tbl_Data.AptSuite = a."NIAPT#",
      tbl_Data.Address2 = a.NIADR2,
      tbl_Data.City = a.NICITY,
      tbl_Data.State = a.NISTAT,
      tbl_Data.ZipCode = a.NIZIPC
 INNER JOIN
      LIBRARY.TABLE a
 ON 
      tbl_Data.Prefix = a.NIPRFX,
      tbl_Data.Number = a.NIPLNR;

当我运行此查询时,我收到一条错误消息:

 OBDC--call failed.
 [IBM][System i Access ODBC Driver][DB2 for i5/OS]SQL0199 - Keyword INNER not expected. Valid tokens: USE SKIP WAIT WITH WHERE. (#-199)

我非常感谢任何帮助,因为我没有想法。

谢谢!

【问题讨论】:

【参考方案1】:

这是 Microsoft 特定的更新语法,它不适用于 DB2。试试这个:

UPDATE 
    tbl_Data
SET
    (tbl_Data.FirstName,
    tbl_Data.MiddleName,
    tbl_Data.LastName,
    tbl_Data.BuildingNumber,
    tbl_Data.StreetName,
    tbl_Data.AptSuite,
    tbl_Data.Address2,
    tbl_Data.City,
    tbl_Data.State,
    tbl_Data.ZipCode)
    =
    (SELECT 
        a.NINMFR,
        a.NINMMD,
        a.NINAML,
        a.NIBLNR,
        a.NISTNM,
        a."NIAPT#",
        a.NIADR2,
        a.NICITY,
        a.NISTAT,
        a.NIZIPC
    FROM 
        library.table a
    WHERE
        tbl_Data.Prefix = a.NIPRFX,
        tbl_Data.Number = a.NIPLNR)
WHERE
    EXISTS (
        SELECT *
        FROM 
            library.table a
        WHERE
            tbl_Data.Prefix = a.NIPRFX,
            tbl_Data.Number = a.NIPLNR);

【讨论】:

以上是关于使用传递查询中的数据更新 Microsoft Access 2013 表的主要内容,如果未能解决你的问题,请参考以下文章

使用 LINQ 和 C# 查询 Microsoft Access MDB 数据库

Microsoft SQL - 查询与更新

将表单值传递给更新查询而不更新表中的空白字段

悖论数据库的java更新查询

Microsoft Access Make-Table 性能与传递查询

Microsoft Access 更新查询