[MSSQL] exec (Insert ...
Marcin - 30-06-2006 00:08
[MSSQL] exec (Insert ...
Witajcie Probuje stworzyc sobie prosta aplikacje korzystajaca z procedur skladowanych. Kod wyglada tak: CREATE PROCEDURE CallTime AS DECLARE @czas varchar(2), @minuty varchar(2), @sekundy varchar(2) UPDATE Stats SET Roznica= EndTime - StartTime, @czas=Roznica, @minuty=SUBSTRING(@czas,5,2),@sekundy=SUBSTRING(@c zas,7,2) WHERE (Id = '8') exec ( 'INSERT INTO Czas (sekund) VALUES ('+@sekundy+')') GO
Jesli dam Check syntax jest OK, ale przy wywolaniu procedury dostaje inforamcje Incorect syntax near ')'
Pozdrawiam Domin
-- Wysłano z serwisu OnetNiusy: http://niusy.onet.pl
keczerad - 30-06-2006 00:08
Marcin napisał(a): > Witajcie > Probuje stworzyc sobie prosta aplikacje korzystajaca z procedur skladowanych. > Kod wyglada tak: > CREATE PROCEDURE CallTime AS > DECLARE > @czas varchar(2), > @minuty varchar(2), > @sekundy varchar(2) > UPDATE Stats > SET Roznica= EndTime - StartTime, @czas=Roznica, > @minuty=SUBSTRING(@czas,5,2),@sekundy=SUBSTRING(@c zas,7,2) > WHERE (Id = '8') > exec ( 'INSERT INTO Czas (sekund) VALUES ('+@sekundy+')') > GO > > Jesli dam Check syntax jest OK, ale przy wywolaniu procedury dostaje inforamcje > Incorect syntax near ')' > > Pozdrawiam > Domin >
exec sp_sqlexec @varchar
--
keczerad
http://www.e-mo.com.pl sklep w (X)HTML
Grzesiek G. - 02-07-2006 00:14
Marcin napisał(a): > Witajcie > Probuje stworzyc sobie prosta aplikacje korzystajaca z procedur skladowanych. > Kod wyglada tak: > CREATE PROCEDURE CallTime AS > DECLARE > @czas varchar(2), > @minuty varchar(2), > @sekundy varchar(2) > UPDATE Stats > SET Roznica= EndTime - StartTime, @czas=Roznica, > @minuty=SUBSTRING(@czas,5,2),@sekundy=SUBSTRING(@c zas,7,2) > WHERE (Id = '8') > exec ( 'INSERT INTO Czas (sekund) VALUES ('+@sekundy+')') > GO > > Jesli dam Check syntax jest OK, ale przy wywolaniu procedury dostaje inforamcje > Incorect syntax near ')'
Zobacz co zawiera pole sekundy, np PRINT @sekundy przed insertem.
-- Grzegorz Gruza Odpowiadając usuń "spamerom_nie." z adresu!!!
Dawid Kloch - 12-07-2006 02:07
Marcin wrote: > Witajcie > Probuje stworzyc sobie prosta aplikacje korzystajaca z procedur skladowanych. > Kod wyglada tak: > CREATE PROCEDURE CallTime AS > DECLARE > @czas varchar(2), > @minuty varchar(2), > @sekundy varchar(2) > UPDATE Stats > SET Roznica= EndTime - StartTime, @czas=Roznica, > @minuty=SUBSTRING(@czas,5,2),@sekundy=SUBSTRING(@c zas,7,2) > WHERE (Id = '8') > exec ( 'INSERT INTO Czas (sekund) VALUES ('+@sekundy+')') > GO > > Jesli dam Check syntax jest OK, ale przy wywolaniu procedury dostaje inforamcje > Incorect syntax near ')' >
Masz niedomknietę apostrofy Powinno być: exec ( 'INSERT INTO Czas (sekund) VALUES ('''+@sekundy+''')')
Choć tak naprawdę lepiej to:
@SQL = 'INSERT INTO Czas (sekund) VALUES ('''+@sekundy+''')' PRINT @SQL exec ( @SQL )
A tak w ogóle to polecam:
sp_executesql
pozdrawiam Dawid Kloch
zanotowane.pldoc.pisz.plpdf.pisz.pleffulla.pev.pl
|
Zdalny =?ISO-8859-2?Q?dost=EAp_do_MSSQL_bez_zarz=B1dzani?==?ISO-8859-2?Q?a?=
[MSSQL] =?ISO-8859-2?Q?zgodno=B6ci_z_licencjami_Microsoft_?==?ISO-8859-2?Q?SQL_Server?=
[MSSQL 2k] - jak =?ISO-8859-2?Q?pod=B3=B1czy=E6_serwer_na_?==?ISO-8859-2?Q?porcie_innym_ni=BF_1433=3F?=
MSSQL Express czy Oracle Express
MSSQL 2005 i uruchamianie procedury o =?ISO-8859-2?Q?okre=B6lone?==?ISO-8859-2?Q?j_godzinie?=
[MSSQL] ACCESS - SQL =?ISO-8859-2?Q?B=B3ad_w_konwersji_lic?==?ISO-8859-2?Q?zb?=
[MSSQL 2000] =?ISO-8859-2?Q?wywo=B3anie_procesu_z_poziomu_?==?ISO-8859-2?Q?job=27a?=
[MSSQL 2K] =?ISO-8859-2?Q?Wp=B3yw_ustawie=F1_regionalnych_?==?ISO-8859-2?Q?serwera_na_zapytania?=
Pobierananie danych z innej bazy danych w MSSQL
Migracja MSSQL 2005 CTP na 2005 Express
zanotowane.pldoc.pisz.plpdf.pisz.plfantazia.htw.pl
Cytat
Decede mihi sole - nie zasłaniaj mi słonca. Gdy kogoś kochasz, jesteś jak stworzyciel świata - na cokolwiek spojrzysz, nabiera to kształtu, wypełnia się barwą, światłem. Powietrze przytula się do ciebie, choćby był mróz, a ty masz w sobie tyle radości, że musisz ją rozdawać wokoło, bo się w tobie nie mieści Hoc fac - tak czyń. A tergo - od tyłu; z tyłu. I czarne włosy posiwieją. Safona |
|