Utilizamos cookies propias y de terceros. Al navegar entendemos que aceptas el uso de cookies. +Info.
Política de cookies
Proyecto AjpdSoft

· Inicio
· Buscar
· Contactar
· Cookies
· Descargas
· Foros
· Historia
· Nosotros
· Temas
· Top 10
· Trucos
· Tutoriales
· Usuario
· Wiki

Proyecto AjpdSoft: Foros

AjpdSoft :: Ver tema - Obtener lista de data sources ODBC del equipo con C#
Foros de discusión Buscar Perfil FAQ Iniciar sesión
Information Obtener lista de data sources ODBC del equipo con C#

Publicar nuevo tema Responder al tema
Foros de discusión » VB.Net, C# .Net, Visual Studio .Net   
Ver tema anterior :: Ver tema siguiente
AutorMensaje
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: Obtener lista de data sources ODBC del equipo con C# Responder citando

Estoy desarrollando una aplicación de facturación y contabilidad. Estoy usando Microsoft Visual C# .Net de Microsoft Visual Studio .Net 2010. Quisiera obtener una lista de todos los ODBC (orígenes de datos / data sources) del equipo, tanto los del usuario como los del sistema. Me refiero a obtener el nombre de los data sources ODBC que el usuario haya dado de alta en el equipo. Así podré mostrarlos en un desplegable para que seleccionar el que quiera usar para la conexión con la base de datos de la aplicación de facturación y contabilidad.
MensajePublicado:
Lun Jun 04, 2012 9:13 pm
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Obtener lista de data sources ODBC del equipo con C# Responder citando



Anuncios



varios escribió:
Estoy desarrollando una aplicación de facturación y contabilidad. Estoy usando Microsoft Visual C# .Net de Microsoft Visual Studio .Net 2010. Quisiera obtener una lista de todos los ODBC (orígenes de datos / data sources) del equipo, tanto los del usuario como los del sistema. Me refiero a obtener el nombre de los data sources ODBC que el usuario haya dado de alta en el equipo. Así podré mostrarlos en un desplegable para que seleccionar el que quiera usar para la conexión con la base de datos de la aplicación de facturación y contabilidad.


Puedes usar el siguiente código, como verás se trata de acceder y leer los valores del registro de configuraciones de Windows, en la clave:

HKEY_CURRENT_USER\Software\ODBC\ODBC.INI

Para los DNS del usuario y la siguiente para los DNS del sistema:

HKEY_LOCAL_MACHINE\SOFTWARE\ODBC\ODBC.INI

El código Visual C# sería algo así:

Código:

using System;
using System.Collections;
using System.Windows.Forms;

namespace AjpdSoftIndexarTextoFicherosPDF
{
    public partial class formIndexarPDF : Form
    {
        public formIndexarPDF()
        {
            InitializeComponent();
        }

        //para tipo de DNS (ODBC)
        public enum DataSourceType { System, User }
     
        // Obtiene todos los data sources (orígenes de datos) del sistema
        public System.Collections.SortedList obtenerDataSourcesSistema()
        {
            System.Collections.SortedList listaODBC =
                new System.Collections.SortedList();
           
            Microsoft.Win32.RegistryKey reg =
                (Microsoft.Win32.Registry.LocalMachine).OpenSubKey("Software");
            if (reg != null)
            {
                reg = reg.OpenSubKey("ODBC");
                if (reg != null)
                {
                    reg = reg.OpenSubKey("ODBC.INI");
                    if (reg != null)
                    {
                        reg = reg.OpenSubKey("ODBC Data Sources");
                        if (reg != null)
                        {
                            // Obtener todas las entradas DSN
                            //definidas en DSN_LOC_IN_REGISTRY
                            foreach (string sName in reg.GetValueNames())
                            {
                                listaODBC.Add(sName, DataSourceType.System);
                            }
                        }
                        try
                        {
                            reg.Close();
                        }
                        catch { /* ignorar un posible error */ }
                    }
                }
            }

            return listaODBC;
        }

        // Obtiene todos los data sources (orígenes de datos) del usuario
        public SortedList obtenerDataSourcesUsuario()
        {
            SortedList listaODBC = new SortedList();

            Microsoft.Win32.RegistryKey reg =
                (Microsoft.Win32.Registry.CurrentUser).OpenSubKey("Software");
            if (reg != null)
            {
                reg = reg.OpenSubKey("ODBC");
                if (reg != null)
                {
                    reg = reg.OpenSubKey("ODBC.INI");
                    if (reg != null)
                    {
                        reg = reg.OpenSubKey("ODBC Data Sources");
                        if (reg != null)
                        {
                            // Obtener todas las entradas DSN
                            // definidas en DSN_LOC_IN_REGISTRY
                            foreach (string sName in reg.GetValueNames())
                            {
                                listaODBC.Add(sName, DataSourceType.User);
                            }
                        }
                        try
                        {
                            reg.Close();
                        }
                        catch { /* ignorar un posible error */ }
                    }
                }
            }

            return listaODBC;
        }


        private void btListaODBC_Click(object sender, EventArgs e)
        {
            SortedList listaODBC = new System.Collections.SortedList();
            lsODBC.Items.Clear();
            listaODBC = obtenerDataSourcesSistema();
            foreach (DictionaryEntry key in listaODBC)
            {
                lsODBC.Items.Add(key.Key.ToString());
            }
            listaODBC = obtenerDataSourcesUsuario();
            foreach (DictionaryEntry key in listaODBC)
            {
                lsODBC.Items.Add(key.Key.ToString());
            }
        }
    }
}
MensajePublicado:
Lun Jun 04, 2012 9:22 pm
Top of PageVer perfil de usuario
Mostrar mensajes de anteriores:   
Todas las horas son GMT - 1 Horas
Publicar nuevo tema Responder al tema
Foros de discusión » VB.Net, C# .Net, Visual Studio .Net  

Cambiar a:  
Key
  Puede publicar nuevos temas en este foro
No puede responder a temas en este foro
No puede editar sus mensajes en este foro
No puede borrar sus mensajes en este foro
No puede votar en encuestas en este foro
Este sitio web NO CONTIENE malware, todos los programas con código fuente aquí. Autor: Alonso Javier Pérez Díaz Google+ Síguenos en Google+