AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi [GELÖST] Zeichenkettenverknüpfung
Thema durchsuchen
Ansicht
Themen-Optionen

[GELÖST] Zeichenkettenverknüpfung

Ein Thema von ToFaceTeKilla · begonnen am 13. Nov 2008 · letzter Beitrag vom 13. Nov 2008
Antwort Antwort
ToFaceTeKilla

Registriert seit: 17. Mai 2006
Ort: Leipzig
283 Beiträge
 
Delphi XE2 Professional
 
#1

[GELÖST] Zeichenkettenverknüpfung

  Alt 13. Nov 2008, 12:12
Datenbank: MS SQL 2005 • Zugriff über: ADO
Hi,

ich bin grad n bisschen am Verzweifeln mit der Stringkonkatenation in MS SQl. Wie in der Hilfe, in der DP und im Inet steht, hab ich die Strings mit einem "+" verknüpft. Jetzt Krieg ich aber immer die Fehlermeldung
"Zeile 15: Falsche Syntax in der Nähe von '+'."


SQL-Code:
create procedure dbo.cf_Test
@Path ntext,
@JobName varchar(80),
@StepName varchar(80),
@Subsystem varchar(80)
as

   execute msdb..sp_add_job
      @job_name = @JobName

   execute msdb..sp_add_jobstep
      @job_name = @JobName,
      @step_name = @StepName,
      @subsystem = @Subsystem,
      @command = '/FILE "'+@Path+'" /MAXCONCURRENT " -1 " /CHECKPOINTING OFF /REPORTING E'
                      // |_hier ist der Fehler
go
Ich hab @Path auch schon als varchar probiert, geht auch nicht.
Kann mir bitte wer sagen, wo mein Fehler liegt?

Thx
Billy Gerwitz
"Bei der Softwareentwicklung suchen wir nicht den richtigen Weg, sondern den am wenigsten falschen." - frei nach V. Hillmann
  Mit Zitat antworten Zitat
nahpets
(Gast)

n/a Beiträge
 
#2

Re: Zeichenkettenverknüpfung

  Alt 13. Nov 2008, 12:15
Hallo,

entweder da sind ein paar " zuviel oder ein paar + zuwenig:

    @command = '/FILE "'+@Path+'" /MAXCONCURRENT " -1 " /CHECKPOINTING OFF /REPORTING E' so
    @command = '/FILE "'+@Path+'" /MAXCONCURRENT " + -1 + " /CHECKPOINTING OFF /REPORTING E' oder so
    @command = '/FILE "'+@Path+'" /MAXCONCURRENT -1 /CHECKPOINTING OFF /REPORTING E'
  Mit Zitat antworten Zitat
ToFaceTeKilla

Registriert seit: 17. Mai 2006
Ort: Leipzig
283 Beiträge
 
Delphi XE2 Professional
 
#3

Re: Zeichenkettenverknüpfung

  Alt 13. Nov 2008, 12:24
Wertet MSSQL doppelte Anführungszeichen denn aus?

Weil, ... "-1" ... ist Teil des Strings. Der ganze Parameter @command wird von SQL an die WinCmd übergeben, deshalb ist @Path und die -1 in Anführungszeichen.

Hm mal probieren...

Edit:
Nee, es kann doch gar nich daran liegen, er meckert ja an dem + vor @Path.
(Wenn ich den String auf drei Zeilen aufteile, meckert er immernoch an Zeile 15, wo dann nur noch der Teil bis zum ersten + steht.)
Billy Gerwitz
"Bei der Softwareentwicklung suchen wir nicht den richtigen Weg, sondern den am wenigsten falschen." - frei nach V. Hillmann
  Mit Zitat antworten Zitat
ToFaceTeKilla

Registriert seit: 17. Mai 2006
Ort: Leipzig
283 Beiträge
 
Delphi XE2 Professional
 
#4

Re: Zeichenkettenverknüpfung

  Alt 13. Nov 2008, 12:52
Alles klar, hab den Fehler gefunden:
SQL-Code:
create procedure dbo.cf_Test
@Path varchar(50),
@JobName varchar(80),
@StepName varchar(80),
@Subsystem varchar(80)
as
declare @com varchar(100)
   execute msdb..sp_add_job
      @job_name = @JobName

set @com = '/FILE "'+@Path+'" /MAXCONCURRENT " -1 " /CHECKPOINTING OFF /REPORTING E'
   execute msdb..sp_add_jobstep
      @job_name = @JobName,
      @step_name = @StepName,
      @subsystem = @Subsystem,
      @command = @com
So muss es lauten. Anscheinend sind zusammengesetzte Strings im Prozeduraufruf nicht zulässig

Aber Thx4Help
Billy Gerwitz
"Bei der Softwareentwicklung suchen wir nicht den richtigen Weg, sondern den am wenigsten falschen." - frei nach V. Hillmann
  Mit Zitat antworten Zitat
nahpets
(Gast)

n/a Beiträge
 
#5

Re: [GELÖST] Zeichenkettenverknüpfung

  Alt 13. Nov 2008, 12:58
Hallo,

jo, sieht so aus, bín da auch gerade zu dem Schluss gekommen
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 16:31 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz