Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > SQL
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 24-01-2008
radaalvaro radaalvaro is offline
Miembro
 
Registrado: oct 2005
Ubicación: Santa Cruz - Bolivia
Posts: 163
Poder: 19
radaalvaro Va por buen camino
Question 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.

Última edición por radaalvaro fecha: 24-01-2008 a las 22:12:55. Razón: Mensaje muy ancho. fue recortado un poco.
Responder Con Cita
  #2  
Antiguo 24-01-2008
luisgutierrezb luisgutierrezb is offline
Miembro
 
Registrado: oct 2005
Ubicación: México
Posts: 925
Poder: 19
luisgutierrezb Va por buen camino
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
Responder Con Cita
  #3  
Antiguo 24-01-2008
radaalvaro radaalvaro is offline
Miembro
 
Registrado: oct 2005
Ubicación: Santa Cruz - Bolivia
Posts: 163
Poder: 19
radaalvaro Va por buen camino
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.
Responder Con Cita
  #4  
Antiguo 25-01-2008
Avatar de jcarteagaf
[jcarteagaf] jcarteagaf is offline
Miembro Premium
 
Registrado: abr 2006
Ubicación: La Paz, Bolivia
Posts: 651
Poder: 19
jcarteagaf Va por buen camino
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
Responder Con Cita
  #5  
Antiguo 26-01-2008
radaalvaro radaalvaro is offline
Miembro
 
Registrado: oct 2005
Ubicación: Santa Cruz - Bolivia
Posts: 163
Poder: 19
radaalvaro Va por buen camino
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.
Responder Con Cita
Respuesta


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
algun procedimiento para obtener el RFC Goyo Varios 11 12-08-2012 19:47:05
Manual para iniciarse en sistemas de BD's en CodeBase FunBit Varios 0 16-09-2005 17:34:45
Consulta en diferentes BD's FunBit MySQL 1 13-07-2005 15:27:07
Iniciando con BD's antrax Varios 3 01-09-2004 16:27:49
El cortafuegos y las BD's hectorin Firebird e Interbase 1 01-04-2004 20:57:45


La franja horaria es GMT +2. Ahora son las 21:49:34.


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
Copyright 1996-2007 Club Delphi