Delphi 字符串,单引号, 执行SQL语句问题?

','''+Trim(edtBeiZhu.Text)+''''+')';上面的字符串,会出现两个单引号,这是什么问题?头都大了!!... ',''' + Trim(edtBeiZhu.Text) + '''' + ')';
上面的字符串,会出现两个单引号,这是什么问题?头都大了!!
展开
 我来答
windblast
2018-05-08 · 知道合伙人软件行家
windblast
知道合伙人软件行家
采纳数:5633 获赞数:13622
毕业于空军第一航空学院电子专业,1991年开始接触电脑,从事多年计算机编程,具有较丰富的经验。

向TA提问 私信TA
展开全部

在 delphi 语言中,用单引号来表示字符串,如果遇到字符串含有单引号的情况下,使用两个单引号来表示。

下面的代码:

',''' + Trim(edtBeiZhu.Text) + '''' + ')

最终生成的字符串如:

这种字符串的写法,视觉上不太好,针对这种情况,delphi 其实提供了一个专门的函数 QuotedStr。上面的代码可以写成:

',' + QuotedStr(Trim(edtBeiZhu.Text))+ ')'

两者效果一样。

追问
我遇到的问题很奇怪,明明是一输入的是一个单引号,却变成了两个单引号
QuotedStr使用这个函数也是在字符串左右各出现两个单引号
HJ_3000
2018-05-08 · TA获得超过563个赞
知道小有建树答主
回答量:1264
采纳率:78%
帮助的人:57.4万
展开全部
  //方法1
  With ADOQuery1 Do
  Begin
    Close;
    SQL.Text := Format('SELECT * FROM sys.tables where name=%s', [QuotedStr(Edit1.Text)]);
    Open;
  End;

  //方法2
  With ADOQuery1 Do
  Begin
    Close;
    SQL.Text := 'SELECT * FROM sys.tables where name=:p1;';
    Parameters.Clear;
    Parameters.CreateParameter(':p1', ftString, pdinput, 32, Edit1.Text);
    Open;
  End;
追问
ftString, pdinput 这两个提示没有定义,该引用哪个单元吗?
追答
uses DB
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式