Power Builder - Origen de base de datos via código.

 
Vista:
sin imagen de perfil

Origen de base de datos via código.

Publicado por Rogger (144 intervenciones) el 19/10/2007 02:07:58
Hola a todos los foristas, mi pregunat es la siguiente: tengo una aplicación ya con su base de datos en sql2000, y quiero saber si es factible poder realizar un origen de base de datos via código desde power bulder o de alguna otra forma.
Valora esta pregunta
Me gusta: Está pregunta es útil y esta claraNo me gusta: Está pregunta no esta clara o no es útil
0
Responder

RE:Origen de base de datos via código.

Publicado por Alejandro (78 intervenciones) el 19/10/2007 13:57:27
será crear un //new profile?
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar
sin imagen de perfil

RE:Origen de base de datos via código.

Publicado por Rogger (144 intervenciones) el 19/10/2007 16:09:33
La idea es q quiero q se ejecute una aplicacion en power builder y en un comandbutton se cree el DNS y q se conecte a mi base de datos.
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar

RE:Origen de base de datos via código.

Publicado por Alejandro (78 intervenciones) el 19/10/2007 16:32:59
mmm...si has logrado una conexion basica en tu aplicacion...en mi caso lo hago con PB80 y SQL2000 y la forma en conectarme es:

SQLCA.DBMS = "MSS Microsoft SQL Server 6.x"
SQLCA.Database = "MiBaseDeDatos"
SQLCA.ServerName = "SERVIDOR"
SQLCA.LogId = "USUARIO"
SQLCA.AutoCommit = False
SQLCA.DBParm = ""
connect;

Yo colocaria eso mismo dentro Comanbuton.
o sino...seria mas efieciente si crearas una ventana donde ingreses el servidor, usuaio, pass, y basede datos...
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar
sin imagen de perfil

RE:Origen de base de datos via código.

Publicado por Roger (144 intervenciones) el 20/10/2007 00:33:41
ok, yo quiero crear un registro mas en el "ODBC Administrator", via código desde power builder.
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar

RE:Origen de base de datos via código.

Publicado por wend (95 intervenciones) el 20/10/2007 01:04:00
Te recomiendo que hagas un ODBC a tu base de datos y luego busques por ese nombre en el registro de windows (regedit).

Desde power builder puedes usar la función RegistrySet(parametros..) para poner valor allí, talves eso te funcione.
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar
sin imagen de perfil

RE:Origen de base de datos via código.

Publicado por Rogger (144 intervenciones) el 20/10/2007 03:01:11
Ok, gracias esa pista parece interesante, lo del regedit creo q es pa punta de la madeja.
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar

RE:Origen de base de datos via código.

Publicado por Jorge Escobar (110 intervenciones) el 20/10/2007 04:01:46
paso 1.
crea un objeto datawindow con los siguientes campos
dbms
profile
provider
database
servername
logid
logpass
autocommit
dbparm

paso 2
// crea una funcion algo asi
of_SetRegisterODBC(string as_section, string as_key,string as_value) return (none)
String ls_regkey
ls_regkey = "HKEY_CURRENT_USER\Software\ODBC\ODBC.INI\"

RegistrySet(ls_regkey + as_section, as_key, as_value)

ls_regkey = "HKEY_CURRENT_USER\Software\ODBC\ODBC.INI\ODBC Data Sources"
RegistrySet(ls_regkey , as_section ,"SQL Server")

paso 3

// script en un command button
string ls_profile,ls_provider
Transaction ltr_connection
DataWindow idw_handle
idw_handle = dw_1
idw_handle.AcceptText()
long ll_pos

// creo la entrada odbc
ls_profile = trim(idw_handle.getitemstring(1,"profile"))
if trim(ls_profile) = "" then
MessageBox("Error","Ingrese el Nombre del Perfil de conexción",StopSign!)
idw_handle.setcolumn("profile") ; idw_handle.setfocus() ; return -1
end if
ll_pos = pos(ls_profile,' ')
if ll_pos > 0 then
MessageBox("Error","El perfil no permite espacios en blanco",StopSign!)
idw_handle.setcolumn("profile") ; idw_handle.setfocus() ; return -1
end if

ls_provider = idw_handle.getitemstring(ll_row,"Provider")
// registro el odbc
of_setregisterodbc( ls_profile,"DataBase",idw_handle.getitemstring(ll_row,"DataBase"))
of_setregisterodbc(ls_profile,"Description","")
of_setregisterodbc( ls_profile,"Driver","C:\WINDOWS\system32\SQLSRV32.dll")
of_setregisterodbc( ls_profile,"LastUser", idw_handle.getitemstring( ll_row,"LogId"))
of_setregisterodbc( ls_profile,"Server", idw_handle.getitemstring( ll_row,"ServerName"))

// aqui compruebas si la conexion fue satisfactoria
ls_autocommit = lower(idw_handle.getitemstring(ll_row,"AutoCommit"))
if ls_autocommit = 'true' or ls_autocommit = 'on' or ls_autocommit = '1' then
ib_autocommit = True
elseif ls_autocommit = 'false' or ls_autocommit = 'off' or ls_autocommit = '0' then
ib_autocommit = False
End if


ltr_connection = Create Transaction
ltr_connection.DBMS = idw_handle.getitemstring( ll_row, "DBMS")
ltr_connection.DataBase = idw_handle.getitemstring(ll_row,"DataBase")
ltr_connection.ServerName= idw_handle.getitemstring( ll_row,"ServerName")
ltr_connection.LogId =idw_handle.getitemstring( ll_row,"LogId")
ltr_connection.LogPass = idw_handle.getitemstring( ll_row,"LogPass")
ltr_connection.DBParm = idw_handle.Getitemstring( ll_row,"DBParm")

Connect Using ltr_connection;
if ltr_connection.SQLCode <> 0 then
MessageBox("Error", &
"Error al conectar con la base de datos~r Verifique los parámetros de ingreso",StopSign!)
Destroy ltr_connection;
Return -1
End If

// si todo ok
creas tu conexion ya sea en archivo ini o clave de registro o donde tu quieras con el fin de obtener estos datos y establecer la conexion


los providers lo encuentras en
"HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\Providers"
puedes crear una funcion para obtener en un dddw todo los providers de sql

es script es parte de lo que quieres. no puedo pasarte los objetos porque están super heredados.
coméntalo si todo va ok.
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar
sin imagen de perfil

RE:Origen de base de datos via código.

Publicado por Rogger (144 intervenciones) el 20/10/2007 15:37:57
Gracias, muchas gracias Jorge ahora lo pruebo!!!
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar

RE:Origen de base de datos via código.

Publicado por Jorge Escobar (110 intervenciones) el 20/10/2007 16:09:42
revisando el codigo que deposité, veo que me faltó una linea muy importante donde se construye el dbparm

en tu script deve de quedar de la siguiente y orden.

//of_setregisterodbc( ls_profile,"LastUser", idw_handle.getitemstring( ll_row,"LogId"))
//of_setregisterodbc( ls_profile,"Server", idw_handle.getitemstring( ll_row,"ServerName"))

idw_handle.setitem(ll_row,"DBParm","PROVIDER='" + ls_provider + "',DATASOURCE='" + ls_profile + "'")

// aqui compruebas si la conexion fue satisfactoria
//ls_autocommit = lower(idw_handle.getitemstring(ll_row,"AutoCommit"))
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar