Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   SQL (https://www.clubdelphi.com/foros/forumdisplay.php?f=6)
-   -   1 Procedimiento para muchas Bd's (https://www.clubdelphi.com/foros/showthread.php?t=52572)

radaalvaro 24-01-2008 18:48:18

1 Procedimiento para muchas Bd's
 
Compañeros, tengo un problema y se que alguno de ustedes puede darme una posible solución.

Uso SQL Server 2000...Tengo varias bases de Datos con estructura de tablas exactamente iguales, es decir se utilizó el mismo script para crearlas y solo se cambio el nombre de la BD. El número de Bases de Datos iguales puede ser variable. (al ser el número de BD indefinido, los nombres de estas bds tampoco son definidos).

Tengo una Base de Datos principal con estructura difernte, esta es única. llamemosle "BDPrincipal"

Necesito crear un procedimiento Almacenado en BDPrincipal, que haga una consulta a varias tablas, pero que por un parametro de este procedimiento se elija a que BD se hará la consulta.

pongo un ejemplo, para que pueda ser mas entendible.

TEngo las Bases de datos.

"BDPrincipal"

y otras con la misma estructura entre ellas.

BD 1
BD 2
...
...
BD n

necesito un Procedimiento creado en BDPrincipal

Código SQL [-]
Create Procedure ProcedimientoEspecial
                    @BaseDeDatos varchar (50)
as
  Select ....................
// requiero que ese select se le haga a la Base de Datos que se paso por el parametro. 
//(La estructura es conocida, y de todas es la misma.)

Espero haber podido explicarme... Muchas gracias por su tiempo.

luisgutierrezb 24-01-2008 19:12:58

pues si la consulta solo va a tomar datos de una base de datos, puedes hacer lo siguiente:
Código SQL [-]
use @BaseDeDatos

Select.....

use BDPrincipal

Tambien puedes hacer esto:

Select temp.campos
from @BDN..tabla as temp

radaalvaro 24-01-2008 22:10:42

fallo el USE.
 
luisgutierrezb, muchas gracias por responder...

Tambien se me ocurrieron las soluciones que planteaste antes de consultar en este foro y no tuve éxito.

Bajo la primera sugerencia, sale un error al crear el procedimiento almacenado por que.... NO PERMITE LA CLAUSULA "USES" dentro de un procedimiento.

La segunda sugerencia tambien falla, por que simplemente no es sintaxis conocida, menciona que hay un error cerca del "."

Saludos.

jcarteagaf 25-01-2008 15:46:34

Stored Procedure que funciona
 
Se que no es lo mas optimo, pero funciona

Código SQL [-]
CREATE PROCEDURE dbo.MiProcedimiento
@Nombredb nvarchar(128)
AS
BEGIN
  DECLARE @SQL VARCHAR(MAX)
  SET @sql = 'SELECT * FROM '+@namedb+'..MITABLA'
  EXEC (@SQL)
END

Espero que sirva.

Saludos

radaalvaro 26-01-2008 03:33:04

La solución.
 
jcarteagaf muchas gracias.

Ciertamente lo que escribiste funciona... es una solución...

Me gustaría saber tambien, si alguien conoce una manera directa de hacer eso, ya que si tengo una consulta bastante compleja, que comprenda muchas, pero muchas lineas de código, este método no seria muy cómodo.

Por favor... alguien que pueda darme una opción 2, en la solución...

Saludos.


La franja horaria es GMT +2. Ahora son las 03:09:33.

Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi