SQL Server与 Access在SQL语法上的差异

引:SQL Server、Microsoft Access都是微软的产品。前者用于中型企业级应用,后者是小型数据库的代表,初学者易于掌握。在开发一般信息系统时,尤其是单机版,大都采用Access。虽然SQL Server也有个人桌面版,但是运行时需占用较多的系统资源。
在局域网广泛应用的形势下,网络版软件大行其道,不少软件从单机版过渡到C/S模式的网络应用,通过SQL语句从服务端获取数据集,将查询结果返回给客户端。
Access中提供查询对象,在设计时可以采用设计视图和SQL视图,非常方便,SQL视图中的SQL语句可以在SQL SERVER中使用,但是否完全可用呢?答案是否定的,表1中总结了 Microsoft Access 和 Microsoft SQL Servers 的 SQL 语法的重要区别。
表1

SQL 语法元素

Microsoft
Access

Microsoft SQL
Server

标识符
限制不超过 64 个字符。
允许使用关键字和特殊字符。
可以用任何字符开头。
SQL Server 6.5:
    限制不超过 30 个字符。 不允许使用关键字和特殊字符。
  • 必须用字母字符开头。
    SQL Server 7.0 的标识符与 Access 完全兼容。
    输出字段
    允许多个输出字段具有相同名称。
    在视图中不支持多个相同输出字段名。
    日期分隔符号
    英镑符(#)
    撇号(')
    Boolean 常量
    True、False;On、Off;Yes、No。
    整数:1(真)、0(假)
    字符串连接
    和号(&)
    加号(+)
    通配符
    星号(*)与零个或更多字符匹配。
    问号(?)与单个字符匹配。
    叹号(!)意味着不在列表中。
    英镑符(#)意味着单个数字。
    百分号(%)与零个或更多字符匹配。
    下划线(_)与单个字符匹配。
    上插入符(^)意味着不在列表中。
    没有与英镑符(#)对应的字符。
    TOP
    如果有一个 ORDER BY 子句,自动包含层次。
    SQL Server 6.5 不支持。
    SQL Server 7.0 需要一个明确的 WITH TIES 子句。
    CREATE INDEX
    允许创建升序和降序索引。
    允许声明主键,没有 Null 值,并且忽略 Null 值。

    DROP INDEX
    语法是:
    Drop Index <index name> ON <table name>
    语法是:
    Drop Index <table name>, <index name>
    DISTINCTROW
    支持(允许选择单个记录)。
    不支持。
    OWNERACCESS
    支持(在执行时控制许可权)。
    不支持。
    Table in UNION
    支持(允许使用下列语法指定表:
    TABLE <tablename>
    不支持。
    ORDER BY in Unions
    支持。允许通过联合查询中的子句实现多种排序。
    支持。允许通过语句末尾的子句实现一种排序。
    TRANSFORM
    支持。用于交叉表查询。
    不支持。
    PARAMETERS
    支持(在 SQL 中记录)。
    不支持。

    以northwind数据库为例,若要得到相同查询结果,SQL语句作相应变化。
    Access:
    SELECT * FROM Products where productname like 'c*';
    SELECT * FROM Products where productname like 'c?ang';
    SQL Server:
    SELECT * FROM Products WHERE productname LIKE 'c%'
    SELECT * FROM Products WHERE productname LIKE 'c_ang'
    在开发过程中尤其需要注意通配符的变化。