DELPHI盒子
!实时搜索: 盒子论坛 | 注册用户 | 修改信息 | 退出
检举帖 | 全文检索 | 关闭广告 | 捐赠
技术论坛
 用户名
 密  码
自动登陆(30天有效)
忘了密码
≡技术区≡
DELPHI技术
lazarus/fpc/Free Pascal
移动应用开发
Web应用开发
数据库专区
报表专区
网络通讯
开源项目
论坛精华贴
≡发布区≡
发布代码
发布控件
文档资料
经典工具
≡事务区≡
网站意见
盒子之家
招聘应聘
信息交换
论坛信息
最新加入: fiscan1
今日帖子: 1
在线用户: 0
导航: 论坛 -> 数据库专区 斑竹:liumazi,waterstone  
作者:
男 chc121 ★☆☆☆☆ -
盒子活跃会员
2021/10/15 11:20:49
标题:
请教 FireDac 中的“from {id xxx}”是什么意思! 浏览:1628
加入我的收藏
楼主:     在学 firedac 示例,其中查询语句中表的位置有好多使用{id 表名},如:select * from {id Orders},上网也找不到答案,请哪位老师指教一下,谢谢!
----------------------------------------------
-
作者:
男 emailx45 (emailx45) ▲▲▲▲△ -
普通会员
2021/10/15 12:09:47
1楼: https://docwiki.embarcadero.com/RADStudio/Rio/en/Master-Detail_Relationship_(M/D)

https://docwiki.embarcadero.com/CodeExamples/Sydney/en/FireDAC.TFDQuery.Indices_Sample


The identifier substitution escape sequence allows abstracting from DBMS-specific identifier quoting rules. For more details, see "Object Names". The syntax is:

Format  Description
{id <identifier name>}  Expands to DBMS-specific quoted identifier syntax.
For example: {id Order Details} -> “Order Details” on Oracle.

https://docwiki.embarcadero.com/RADStudio/Sydney/en/Object_Names_(FireDAC)


FireDAC fully supports quoted object names, including different DBMS quoted characters. To write a quoted name in a SQL in a DBMS independent fashion use the {id <name>} syntax. For example:

 SELECT * FROM {id Order Details}
To force TFDTable to quote field names set FormatOptions.QuoteIdentifiers to True.
----------------------------------------------
The higher the degree, the greater the respect given to the humblest!RAD 11.3
作者:
男 chc121 ( ) ★☆☆☆☆ -
盒子活跃会员
2021/10/15 12:31:18
2楼: emailx45:不是太懂,但非常感谢!
----------------------------------------------
-
作者:
男 wg961423 (麦子仲肥) ★☆☆☆☆ -
盒子活跃会员
2021/10/15 14:19:32
3楼: FireDAC完全支持带引号的对象名称,包括不同DBMS的引号字符。要以独立于DBMS的方式在SQL中写一个带引号的名字,请使用{id <name>}语法。
----------------------------------------------
-
作者:
男 wg961423 (麦子仲肥) ★☆☆☆☆ -
盒子活跃会员
2021/10/15 14:27:32
4楼: 即在不同的数据库中,表名可以用不同的符号,如:SQLServer是 [表名] ,MySQL是`表名`,PG是"表名",FireDac里支持在不同的数据库中用同一个SQL,即全都是用{id 表名}来执行。
----------------------------------------------
-
作者:
男 wg961423 (麦子仲肥) ★☆☆☆☆ -
盒子活跃会员
2021/10/15 14:34:44
5楼: SELECT * FROM {id Order Details}
即在SQLServer里会变成:SELECT * FROM [Order Details]
即在MySQL里会变成:SELECT * FROM `Order Details`
即在PG里会变成:SELECT * FROM "Order Details"
----------------------------------------------
-
作者:
男 chc121 ( ) ★☆☆☆☆ -
盒子活跃会员
2021/10/15 18:37:47
6楼: wg961423 (麦子仲肥):谢谢!  理解了。
----------------------------------------------
-
信息
登陆以后才能回复
Copyright © 2CCC.Com 盒子论坛 v3.0.1 版权所有 页面执行80.07813毫秒 RSS