Access911.net   |   a9BBS   |   OTaA System  
  搜索文章:  
Access911欢迎您光临  
   主页      上传      繁體版       论坛     
设为首页  |  加入收藏   
  
你现在的位置:文章索引 -> 文章分类 -> ADP  
 首页|  近日更新|  下载  |  文章索引  |  搜索|  术语|  承接工程|  
 
系统正在加载内容,请耐心等待...
 
 查询
 窗体
 报表
 
 
 VBA
 函数
 ADO/DAO/ADO.NET
 API
 ADP
 安全
 发布
 OA
 ASP/ASP.NET
 其他语言
 控件
 DELPHI
 C#/.Net
 本站
 其他
 小例程
 常用软件
 参考文档
 业主作品
 网友大作
 
 
友情链接
 access911.net
 
访问人次
 1701983
 
站长 E-Mail
 net911@sina.com
 access911@gmail.com
 
RSS 订阅

显示附加信息 >>>

新手来看:除函数以外JET SQL与T-SQL的一些明显区别

作者:cg1  摘自:access911.net  :cg1  更新日期:2006-9-20  浏览人次:

 

函数有什么调整可以看
    access升级到SQLServer如何调整字段类型及函数。JET SQL T-SQL同义词《ADP...
    http://access911.net/index.asp?u1=a&u2=73FAB11E14DC

1、JET SQL 对日期的撰写两边用 # 号,T-SQL 用 ' 号
Jet SQL 示例:
select * from [table] where [date field] >=#2006-1-1#
T-SQL 示例:
select * from [table] where [date field] >='2006-1-1'

2、多层套嵌时 JET SQL 必须将 SELECT 子句用括号 ( ) 一层一层包含起来,而 T-SQL 没有此规定
Jet SQL 示例:
select [table1].[field1],[table2].[field4],[table3].[field3],[table4].[field4] 
from ((([table1] left join [table2] on [table1].[field1]=[table2].[field1]) 
    left join [table3] on [table1].[field1]=[table3].[field1]) 
    left join [table4] on [table1].[field1]=[table4].[field1])

T-SQL 示例:
select [table1].[field1],
       [table2].[field4],
       [table3].[field3],
       [table4].[field4] 
from [table1] left join [table2] on [table1].[field1]=[table2].[field1] 
              left join [table3] on [table1].[field1]=[table3].[field1]
              left join [table4] on [table1].[field1]=[table4].[field1]

3、JET SQL 只允许单句的 SQL 语句出现,";"分号是JET SQL 语句的最后一个字符,后面不允许再出现其他字符;而 T-SQL 查询分析器或用ADO执行T-SQL语句时可以连续执行两句,两句之间可以用分号间隔。

4、T-SQL 支持用 "--" 两个连字符在 T-SQL 语句中进行注释;JET SQL 语句不支持注释

5、T-SQL 的 UPDATE set 子句中允许用括号中的select 语句的返回值;在JET SQL 不支持,但可以用域函数
T-SQL 示例:
update [table] set [field] = (select top 1 [field2] from [table2] order by [field3])

JET-SQL 示例:
update [table] set [field] = dmax("field2","table2")

在多个环境中 T-SQL 中都允许用 () 括号中返回单一值的 SELECT 语句代替某个固定值,而JET SQL 语句中一般都使用域函数解决

T-SQL 示例:
select [field1],(select top 1 [field3] from [table3] where [field2]=15) as newfield from [table1]

jet-sql 示例:
select [field1],dlookup("field3","table3","field2=15") as newfield from [table1]


未完待续,继续修正总结中 ....

本站文章旨在为该问题提供解决思路及关键性代码,并不能完成应该由网友自己完成的所有工作,请网友在仔细看文章并理解思路的基础上举一反三、灵活运用。

access911.net 原创文章,作者本人对文章保留一切权利。
如需转载必须征得作者同意并注明本站链接


 

 
相关文章
     没有手动相关文章
     Q&A回答XML与HTML的区别
     SQL 与 JET SQL 有什么区别
     VBA与T-SQL之间的函数比较;SQL Server的SQL语句如何在ACCESS中使用?
 
评论
     查看或发表更多的评论,请单击这里。
 
 
 
 
 
   
  Access911.net   |   a9BBS   |   OTaA System   |
建站日期:2000年4月2日  |  设计施工:陈格 ( access911 & cg1 )
 Copyright © 2000 - 2003 COMET, 陈格 保留所有权利