SELECT 语句 (Microsoft Access SQL)
适用于: Access 2013 | Office 2013
指示 Microsoft Access 数据库引擎将数据库中的信息作为一组记录返回。
语法
SELECT [谓词] { * | table.* |[table.]field1 [AS alias1] [, [table.]field2 [AS alias2] [, ...]]} FROM tableexpression [, ...] [IN externaldatabase][ ] [ ] [ ] [ ] [WITH OWNERACCESS OPTION]
SELECT 语句包含以下部分:
部分
说明
predicate
下列谓词之一:ALL、DISTINCT、DISTINCTROW 或 TOP。 使用谓词限制返回的记录数。 如果没有指定谓词,则默认值为 ALL。
*
指定选择指定表中的所有字段。
table
表的名称,该表包含从中选择记录的字段。
field1,field2
字段名,这些字段包含了要检索的数据。 如果包括多个字段,将按它们的排列顺序对其进行检索。
alias1,alias2
要用作列标题的名称,而不是 表中的原始列名。
tableexpression
表名称,其中包含要检索的数据。
externaldatabase
包含 tableexpression 中的表(如果表不在当前数据库中)的数据库的名称。
若要执行此项操作,Microsoft Jet 数据库引擎会搜索指定的一个或多个表,提取选定的列,选择符合条件的行,然后按指定的顺序对得到的行进行排序或分组。
SELECT 语句不会更改数据库中的数据。
SELECT 通常是 SQL 语句中的第一个词。 大多数 SQL 语句都是 SELECT 或 INTO 语句。
SELECT 语句最简化的语法为:
SELECT fields FROM table
可以通过星号 (*) 来选择表中所有的字段。 以下示例选择 Employees 表中的所有字段。
SELECT * FROM Employees;
如果某个字段名称包含在 FROM 子句的多个表中,请在其前面加上表名和 . (点) 运算符。 在下面的示例中,Department 字段同时存在于 Employees 表和 Supervisors 表中。 SQL 语句从 Employees 表中选择出部门并从 Supervisors 表中选择出主管名:
SELECT Employees.Department, Supervisors.SupvName
FROM Employees INNER JOIN Supervisors
WHERE Employees.Department = Supervisors.Department;
创建 Recordset 对象时,Microsoft Jet 数据库引擎将使用表的字段名作为 Recordset 对象中的 Field 对象名。 如果需要其他字段名或者名称不适合用来生成该字段的表达式,请使用 AS 保留字。 以下示例使用标题 Birth 来命名生成的 Recordset 对象中的返回 Field 对象:
SELECT BirthDate
AS Birth FROM Employees;
只要使用的聚合函数或查询返回的是不明确的或重复的 Field 对象名称,就必须使用 AS 子句为该 Field 对象另外提供一个替代名称。 下面的示例使用标题 HeadCount 来命名在结果 Recordset 对象中的返回 Field 对象:
SELECT COUNT(EmployeeID)
AS HeadCount FROM Employees;
可以在 SELECT 语句中使用其他子句进一步约束和组织所返回的数据。 有关详细信息,请参阅相应子句的帮助主题。
链接提供方:UtterAccess 社区。 UtterAccess 是主要的 Microsoft Access Wiki 和帮助论坛。
示例
下面的一些示例假定 Employees 表中存在一个假想的 Salary 字段。 请注意,该字段实际并不存在于罗斯文数据库的 Employees 表中。
This example creates a dynaset-type Recordset based on an SQL statement that selects the LastName and FirstName fields of all records in the Employees table. 它调用 EnumFields 过程,该过程将 Recordset 对象的内容显示到调试窗口。
    Sub SelectX1()
   
        Dim dbs As Database, rst As Recordset
   
        ' Modify this line to include the path to Northwind
        ' on your puter.
        Set dbs = OpenDatabase("Northwind.mdb")
   
        ' Select the last name and first name values of all 
        ' records in the Employees table.
        Set rst = dbs.OpenRecordset("SELECT LastName, " _
            & "FirstName FROM Employees;")
   
        ' Populate the recordset.
        rst.MoveLast
   
        ' Call EnumFields to print the contents of the
        ' Recordset.
        EnumFields rst,12
   
        dbs.Close
   
    End Sub
以下示例计算 PostalCode 字段中有条目的记录数,并将返回的字段命名为 Tally。
    Sub SelectX2() truncated value
   
        Dim dbs As Database, rst As Recordset
   
        ' Modify this line to include the path to Northwind
        ' on your puter.
        Set dbs = OpenDatabase("Northwind.mdb")
   
        ' Count the number of records with a PostalCode 
        ' value and return the total in the Tally field.
        Set rst = dbs.OpenRecordset("SELECT Count " _
            & "(PostalCode) AS Tally FROM Customers;")
   
        ' Populate the Recordset.
        rst.MoveLast
   
        ' Call EnumFields to print the contents of 
        ' the Recordset. Specify field width = 12.
        EnumFields rst, 12
   
        dbs.Close
   
    End Sub
以下示例显示了雇员人数以及平均和最高工资。
    Sub SelectX3()
   
        Dim dbs As Database, rst As Recordset
   
        ' Modify this line to include the path to Northwind
        ' on your puter.
        Set dbs = OpenDatabase("Northwind.mdb")
   
        ' Count the number of employees, calculate the 
        ' average salary, and return the highest salary.
        Set rst = dbs.OpenRecordset("SELECT Count (*) " _
            & "AS TotalEmployees, Avg(Salary) " _
            & "AS AverageSalary, Max(Salary) " _
            & "AS MaximumSalary FROM Employees;")
   
        ' Populate the Recordset.
        rst.MoveLast
   
        ' Call EnumFields to print the contents of
        ' the Recordset. Pass the Recordset object and
        ' desired field width.

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。