鱼C论坛

 找回密码
 立即注册
查看: 3183|回复: 3

求包含转义字符的SQL串的写法

[复制链接]
发表于 2012-5-3 22:22:20 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 乐yi忘忧 于 2012-6-27 19:37 编辑

if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[p_ToExcel]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)
drop procedure [dbo].[p_ToExcel]
GO
SET QUOTED_IDENTIFIER OFF
GO
SET ANSI_NULLS ON
GO
CREATE  PROCEDURE p_ToExcel
AS
DECLARE @sqlstring varchar(255)
DECLARE @dirstring varchar(255)
DECLARE @selectstring varchar(255)
DECLARE @str4 varchar(255)
SET @dirstring = 'C:\Report_D.xls'
SET @selectstring = '"SELECT * FROM test..Report_S"'
SET @str4 = ' -c -S"SYL-HP" -U"sa" -P"password"'''
SET @sqlstring = 'master..xp_cmdshell ''bcp ' +@selectstring+ ' queryout '+@dirstring+@str4
EXEC @sqlstring

GO
SET QUOTED_IDENTIFIER OFF
GO
SET ANSI_NULLS ON
GO

这个存储过程执行总是出错,是字符串的拼接问题,请教该如何修改?
其实就是这么一句,想把保存路径通过savedialog写成动态的:
EXEC master..xp_cmdshell 'bcp "SELECT * FROM test..Report_S" queryout C:\Report_D.xls -c -S"SYL-HP" -U"sa" -P"password"'
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
 楼主| 发表于 2012-5-3 22:28:53 | 显示全部楼层
服务器: 消息 203,级别 16,状态 2,过程 p_ToExcel,行 16
名称 'master..xp_cmdshell 'bcp "SELECT * FROM test..Report_S" queryout C:\Report_D.xls -c -S"SYL-HP" -U"sa" -P"password"'' 不是有效的标识符。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
 楼主| 发表于 2012-5-4 10:52:26 | 显示全部楼层
自己动手,丰衣足食,搞定了。

procedure TForm1.btn2Click(Sender: TObject);
begin
  if dlgSave1.Execute then
  begin
    savedir := dlgSave1.FileName;
    sqlstring := 'EXEC master..xp_cmdshell ''bcp "SELECT * FROM test..report_s" queryout '+savedir+' -c  -q -S"10.1.8.8" -U"sa" -P"password"''';
    qry2.Close;
    qry2.SQL.Clear;
    qry2.SQL.Add(sqlstring);
    qry2.ExecSQL;
  end;
  ShowMessage('数据成功导出至:'+savedir);
end;
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2017-4-2 16:54:15 | 显示全部楼层
新手,受教了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-19 08:49

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表