DELPHI盒子
!实时搜索: 盒子论坛 | 注册用户 | 修改信息 | 退出
检举帖 | 全文检索 | 关闭广告 | 捐赠
技术论坛
 用户名
 密  码
自动登陆(30天有效)
忘了密码
≡技术区≡
DELPHI技术
lazarus/fpc/Free Pascal
移动应用开发
Web应用开发
数据库专区
报表专区
网络通讯
开源项目
论坛精华贴
≡发布区≡
发布代码
发布控件
文档资料
经典工具
≡事务区≡
网站意见
盒子之家
招聘应聘
信息交换
论坛信息
最新加入: sprblck
今日帖子: 9
在线用户: 14
导航: 论坛 -> DELPHI技术 斑竹:liumazi,sephil  
作者:
男 akai1203 (w-dins) ★☆☆☆☆ -
普通会员
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错误,什么原因?
----------------------------------------------
-把学习当信仰
作者:
男 ksrsoft (cb168) ★☆☆☆☆ -
普通会员
2019/3/16 19:21:06
1楼: 什么数据库
----------------------------------------------
-
作者:
男 akai1203 (w-dins) ★☆☆☆☆ -
普通会员
2019/3/16 19:33:22
2楼: sql server
----------------------------------------------
-把学习当信仰
作者:
男 akai1203 (w-dins) ★☆☆☆☆ -
普通会员
2019/3/16 20:03:01
3楼: 蛋碎
----------------------------------------------
-把学习当信仰
作者:
男 delphiilove (乌羽玉) ★☆☆☆☆ -
普通会员
2019/3/16 22:46:27
4楼: sql 语句 符合 SQL server 创建数据库的语法
----------------------------------------------
-
作者:
男 emailx45 (emailx45) ▲▲▲▲△ -
普通会员
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
作者:
男 akai1203 (w-dins) ★☆☆☆☆ -
普通会员
2019/3/17 15:54:13
6楼: 如果用format来格式化,是没有问题的。我是好奇为会么这个parambyname不起作用?
----------------------------------------------
-把学习当信仰
作者:
男 delphiilove (乌羽玉) ★☆☆☆☆ -
普通会员
2019/3/17 18:33:44
7楼: parambyname  是 做 参数化查询用的。
不能替换 数据库名,表名 这样的 内容。
如果要 实现 类似 参数的效果,要用 MarcobyName,要在 sql 语句中 定义 宏 (Marco)
用 &做前缀。参数化查询 是用 冒号 : 做前缀。
----------------------------------------------
-
作者:
男 earthsbest (全能中间件) ▲▲▲▲△ -
普通会员
2019/3/18 8:51:58
8楼: 楼上正解,记得以前用D7+ADO的时代也遇到这个问题。
----------------------------------------------
Delphi4Linux Delphi三层/FireDAC 技术群:734515869 http://www.cnblogs.com/rtcmw
作者:
男 akai1203 (w-dins) ★☆☆☆☆ -
普通会员
2019/3/18 15:31:51
9楼: 用MarcobyName是可以的,原来如此,谢谢!
----------------------------------------------
-把学习当信仰
作者:
男 stlont (龙头老大) ★☆☆☆☆ -
盒子活跃会员
2019/3/18 17:55:34
10楼: 这是说你的SQL语法错误,
不是parambyname的问题,
数据库名要用双引号,
parambyname('db').asstring = 'test';
改为:
parambyname('db').asstring = '"test"';
----------------------------------------------
-
信息
登陆以后才能回复
Copyright © 2CCC.Com 盒子论坛 v3.0.1 版权所有 页面执行66.40625毫秒 RSS