导航:
论坛 -> DELPHI技术
斑竹:liumazi,sephil
作者:
2019/3/16 19:17:43
标题:
firedac的 incorrect syntax near @p1错误
浏览:937
加入我的收藏
楼主:
请教各位一个问题, 代码如下 ; procedure TForm1.test ; LQuery : TFDQuery ; begin try LQuery := TFDQuery.Create(nil); with LQuery do begin con := con //已经connected close; sql.clear; sql.text = 'create database :db' ; parambyname('db').asstring = 'test'; execsql ; end; finally freeandnil(LQuery) end end 一直出错,提示incorrect syntax near @p1错误,什么原因?
----------------------------------------------
-把学习当信仰
作者:
2019/3/16 19:21:06
1楼:
什么数据库
----------------------------------------------
-
作者:
2019/3/16 19:33:22
2楼:
sql server
----------------------------------------------
-把学习当信仰
作者:
2019/3/16 20:03:01
3楼:
蛋碎
----------------------------------------------
-把学习当信仰
作者:
2019/3/16 22:46:27
4楼:
sql 语句 符合 SQL server 创建数据库的语法
----------------------------------------------
-
作者:
2019/3/17 6:09:00
5楼:
try; sql.text = Format('create database %s' , [ sDBstringname ]); Question: IF the database already exist? is not better test it before? https://docs.microsoft.com/en-us/sql/t-sql/statements/create-database-transact-sql?view=sql-server-2017 hug
----------------------------------------------
The higher the degree, the greater the respect given to the humblest!RAD 11.3
作者:
2019/3/17 15:54:13
6楼:
如果用format来格式化,是没有问题的。我是好奇为会么这个parambyname不起作用?
----------------------------------------------
-把学习当信仰
作者:
2019/3/17 18:33:44
7楼:
parambyname 是 做 参数化查询用的。 不能替换 数据库名,表名 这样的 内容。 如果要 实现 类似 参数的效果,要用 MarcobyName,要在 sql 语句中 定义 宏 (Marco) 用 &做前缀。参数化查询 是用 冒号 : 做前缀。
----------------------------------------------
-
作者:
2019/3/18 8:51:58
8楼:
楼上正解,记得以前用D7+ADO的时代也遇到这个问题。
----------------------------------------------
Delphi4Linux Delphi三层/FireDAC 技术群:734515869 http://www.cnblogs.com/rtcmw
作者:
2019/3/18 15:31:51
9楼:
用MarcobyName是可以的,原来如此,谢谢!
----------------------------------------------
-把学习当信仰
作者:
2019/3/18 17:55:34
10楼:
这是说你的SQL语法错误, 不是parambyname的问题, 数据库名要用双引号, parambyname('db').asstring = 'test'; 改为: parambyname('db').asstring = '"test"';
----------------------------------------------
-