AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Tabellenname als Parameter für Stored Procedure
Thema durchsuchen
Ansicht
Themen-Optionen

Tabellenname als Parameter für Stored Procedure

Ein Thema von Mavarik · begonnen am 2. Jun 2010 · letzter Beitrag vom 2. Jun 2010
Antwort Antwort
Seite 1 von 2  1 2      
Benutzerbild von Mavarik
Mavarik

Registriert seit: 9. Feb 2006
Ort: Stolberg (Rhld)
4.130 Beiträge
 
Delphi 10.3 Rio
 
#1

Tabellenname als Parameter für Stored Procedure

  Alt 2. Jun 2010, 13:52
Datenbank: MySQL • Version: 5.x • Zugriff über: SciBit Komponenten Direkt
Hallo!

Ich habe folgende Stored Procedure programmiert.

SQL-Code:
DROP PROCEDURE IF EXISTS `CALC` $$
CREATE PROCEDURE `CALC`(IN BASE VarCHAR(20))
BEGIN
  DECLARE done BOOLEAN DEFAULT FALSE;
...
  DECLARE cur1 CURSOR FOR SELECT ID, Betrag, EIN_AUS, Saldo, Kontonummer FROM BASE GROUP BY ISAMKey_2 ASC;
  DECLARE CONTINUE HANDLER FOR SQLSTATE '02000SET done = TRUE;
...
Aber anstatt den die übergebene Datenbank zu benutzen erhalte ich immer die Fehlermeldung...

Datenbank "Base" nicht gefunden...

Aufruf ist CALC('MeineDatenbank');

Wo ist der Trick?

Grsse Mavarik
  Mit Zitat antworten Zitat
Benutzerbild von Forlan
Forlan

Registriert seit: 17. Feb 2008
Ort: Herford
265 Beiträge
 
Delphi 2007 Architect
 
#2

Re: Tabellenname als Parameter für Stored Procedure

  Alt 2. Jun 2010, 13:59
Moin,

eine evtl. überflüssige Frage, aber bist du dir sicher das die DB Base heißt?

Edit:
Kurz vor Feierabend, Müll geschrieben, sorry...^^
Marcel
マルセル
www.youtube.com/beethoven1990
  Mit Zitat antworten Zitat
Benutzerbild von Neutral General
Neutral General

Registriert seit: 16. Jan 2004
Ort: Bendorf
5.219 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#3

Re: Tabellenname als Parameter für Stored Procedure

  Alt 2. Jun 2010, 14:01
Zitat von Forlan:
Moin,

eine evtl. überflüssige Frage, aber bist du dir sicher das die DB Base heißt?
Base ist eine Variable.

@Mavarik: Also bei Firebird würde ich einen Doppelpunkt vor BASE machen. ==> FROM :BASE ...

Allerdings kann das bzgl. MySQL völliger Schwachsinn sein.
Michael
"Programmers talk about software development on weekends, vacations, and over meals not because they lack imagination,
but because their imagination reveals worlds that others cannot see."
  Mit Zitat antworten Zitat
Benutzerbild von Mavarik
Mavarik

Registriert seit: 9. Feb 2006
Ort: Stolberg (Rhld)
4.130 Beiträge
 
Delphi 10.3 Rio
 
#4

Re: Tabellenname als Parameter für Stored Procedure

  Alt 2. Jun 2010, 14:03
Zitat von Neutral General:

@Mavarik: Also bei Firebird würde ich einen Doppelpunkt vor BASE machen. ==> FROM :BASE ...

Allerdings kann das bzgl. MySQL völliger Schwachsinn sein.
Funktioniert NICHT...
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.851 Beiträge
 
Delphi 11 Alexandria
 
#5

Re: Tabellenname als Parameter für Stored Procedure

  Alt 2. Jun 2010, 14:04
Die wenigsten DBMS unterstützen Parameter für Tabellen usw.
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von Mavarik
Mavarik

Registriert seit: 9. Feb 2006
Ort: Stolberg (Rhld)
4.130 Beiträge
 
Delphi 10.3 Rio
 
#6

Re: Tabellenname als Parameter für Stored Procedure

  Alt 2. Jun 2010, 14:05
Zitat von mkinzler:
Die wenigsten DBMS unterstützen Parameter für Tabellen usw.
DBMS?

Bedeutet geht oder geht nicht bei MySQL?

Mavarik
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.270 Beiträge
 
Delphi 10.4 Sydney
 
#7

Re: Tabellenname als Parameter für Stored Procedure

  Alt 2. Jun 2010, 14:07
Hallo,

also eine Suche bei Google war wohl zu einfach ?

"mysql stored procedure table as parameter"

1


Heiko
Heiko
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.542 Beiträge
 
Delphi 11 Alexandria
 
#8

Re: Tabellenname als Parameter für Stored Procedure

  Alt 2. Jun 2010, 14:09
Geht, siehe http://dev.mysql.com/tech-resources/...toredproc.html
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von Mavarik
Mavarik

Registriert seit: 9. Feb 2006
Ort: Stolberg (Rhld)
4.130 Beiträge
 
Delphi 10.3 Rio
 
#9

Re: Tabellenname als Parameter für Stored Procedure

  Alt 2. Jun 2010, 14:14
Tja Danke für die Links...

Aber wie funktioniert das mit

SQL-Code:
 SET @BASENAME = CONCAT("SELECT ID, Betrag, EIN_AUS, Saldo, Kontonummer FROM ",BASE,"GROUP BY ISAMKey_2 ASC"
 DECLARE cur1 CURSOR FOR @BASENAME;
Dann kommt der Fehler beim CURSOR DELCLARE...

Und PREAPRE und DECLARE kann ich nicht zuordnen....

Mavarik
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.270 Beiträge
 
Delphi 10.4 Sydney
 
#10

Re: Tabellenname als Parameter für Stored Procedure

  Alt 2. Jun 2010, 14:28
Hallo,

Ein Bsp aus meinem Link

SQL-Code:
DELIMITER $$

DROP PROCEDURE IF EXISTS `eduplan`.`GetStakeholder`$$

CREATE PROCEDURE `eduplan`.`GetStakeholder`(usingtable varchar(255), usingid varchar(255), identifier varchar(255))
BEGIN
SET @qry = CONCAT('SELECT * FROM ', usingtable, ' WHERE ', usingid,' = ?');
PREPARE stmt1 FROM @qry;
SET @c = identifier;
EXECUTE stmt1 USING @c;
DEALLOCATE PREPARE stmt1;
END$$

DELIMITER ;

Oder so

SQL-Code:
declare @mySql varchar(220)
set @mysql = 'select customerid from customers'
exec ('DECLARE cur CURSOR FOR ' + @mysql)

Heiko
Heiko
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 10:18 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