csharp: read system DSN configured get Driver Names on windows

来源:https://www.cnblogs.com/geovindu/archive/2018/02/23/8462397.html
-Advertisement-
Play Games

using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.... ...


 

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Runtime.InteropServices;
using Microsoft.Win32;
using System.Data.Odbc;

namespace SQLanyWhereDemo
{
    public partial class Form5 : Form
    {

        [DllImport("odbc32")]
        public static extern short SQLAllocHandle(short HandleType, IntPtr InputHandle, out IntPtr OutputHandle);
        [DllImport("odbc32", CharSet = CharSet.Unicode)]
        public static extern short SQLSetEnvAttr(IntPtr envHandle, ushort attribute, IntPtr val, int stringLength);
        [DllImport("odbc32.dll", CharSet = CharSet.Ansi)]
        public static extern short SQLDataSources(IntPtr EnvironmentHandle, ushort Direction, StringBuilder ServerName, short BufferLength1, ref short NameLength1Ptr, StringBuilder Description, short BufferLength2, ref short NameLength2Ptr);
        [DllImport("ODBCCP32.dll")]
        private static extern bool SQLConfigDataSource(IntPtr parent, int request, string driver, string attributes);

        [DllImport("odbccp32.dll", CharSet = CharSet.Unicode, SetLastError = true)]
        private static extern bool SQLGetInstalledDriversW(char[] lpszBuf, ushort cbufMax, out ushort pcbBufOut);

        public const int SQL_SUCCESS = 0;
        public const int SQL_ERROR = -1;

        public const int SQL_FETCH_NEXT = 1;
        public const int SQL_FETCH_FIRST = 2;
        public const int SQL_FETCH_FIRST_USER = 31;
        public const int SQL_FETCH_FIRST_SYSTEM = 32;

        public const int SQL_ATTR_ODBC_VERSION = 200;

        public const int SQL_HANDLE_ENV = 1;
        public const int SQL_HANDLE_DBC = 2;
        public const int SQL_HANDLE_STMT = 3;
        public const int SQL_HANDLE_DESC = 4;
        /// <summary>
        /// 
        /// </summary>
        public Form5()
        {
            InitializeComponent();
        }
        /// <summary>
        /// 
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void button1_Click(object sender, EventArgs e)
        {

            List<ODBCStr> ls = new List<ODBCStr>();
            short iResult = 0;
            IntPtr lhEnvIn = (IntPtr)0;
            IntPtr lhEnv = (IntPtr)0;
            StringBuilder sDSNItem = new StringBuilder(1024);
            StringBuilder sDRVItem = new StringBuilder(1024);
            short iDSNLen = 0;
            short iDRVLen = 0;

            SQLSetEnvAttr(lhEnv, 200, (IntPtr)3, 0);

            iResult = SQLAllocHandle(1, lhEnvIn, out lhEnv);
            MessageBox.Show(iResult.ToString(), "iResult SQLAllocHandle");

            //short iResult = 0;
            //IntPtr lhEnvIn = (IntPtr)0;
            //IntPtr lhEnv = (IntPtr)0;
            //StringBuilder sDSNItem = new StringBuilder(1024);
            //StringBuilder sDRVItem = new StringBuilder(1024);
            //short iDSNLen = 0;
            //short iDRVLen = 0;

            iResult = SQLAllocHandle(SQL_HANDLE_ENV, lhEnvIn, out lhEnv);

            SQLSetEnvAttr(lhEnv, SQL_ATTR_ODBC_VERSION, (IntPtr)3, 0);

            if (iResult == SQL_SUCCESS)
            {
                ODBCStr sr = null;
                iResult = SQLDataSources(lhEnv, SQL_FETCH_FIRST, sDSNItem, 1024, ref iDSNLen, sDRVItem, 1024, ref iDRVLen);
                while (iResult == SQL_SUCCESS)
                {
                    sr=new ODBCStr();
                    //MessageBox.Show(sDSNItem.ToString(), "sDSNItem.ToString()");
                    iResult = SQLDataSources(lhEnv, SQL_FETCH_NEXT, sDSNItem, 1024, ref iDSNLen, sDRVItem, 1024, ref iDRVLen);
                    sr.DsnName = sDSNItem.ToString();
                    sr.DriveName = sDRVItem.ToString();
                    //string str = "SERVER=HOME\0DSN=MYDSN\0DESCRIPTION=MYDSNDESC\0DATABASE=DBServer\0TRUSTED_CONNECTION=YES";
                    //SQLConfigDataSource((IntPtr)0, 4, "Sybase SQL Anywhere 5.0", str);//SQL Server
                    //MessageBox.Show(str);

                    ls.Add(sr);
                }
            }

            this.dataGridView1.DataSource = ls;

        }
        /// <summary>
        /// 
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void button2_Click(object sender, EventArgs e)
        {

            string[] list = GetOdbcDriverNames();


        }

        /// <summary>
        /// Gets the ODBC driver names from the SQLGetInstalledDrivers function.
        /// </summary>
        /// <returns>a string array containing the ODBC driver names, if the call to SQLGetInstalledDrivers was successfull; null, otherwise.</returns>
        public static string[] GetOdbcDriverNames()
        {
            string[] odbcDriverNames = null;
            char[] driverNamesBuffer = new char[ushort.MaxValue];
            ushort size;

            bool succeeded = SQLGetInstalledDriversW(driverNamesBuffer, ushort.MaxValue, out size);

            if (succeeded == true)
            {
                char[] driverNames = new char[size - 1];
                Array.Copy(driverNamesBuffer, driverNames, size - 1);
                odbcDriverNames = (new string(driverNames)).Split('\0');
            }

            return odbcDriverNames;
        }
    }


    /// <summary>
    /// 塗聚文
    /// 20180223
    /// Geovin Du
    /// </summary>
    public class ODBCStr
    {
        /// <summary>
        /// 
        /// </summary>
        public string DriveName { get; set; }
        /// <summary>
        /// 
        /// </summary>
        public string DsnName { get; set; }
        /// <summary>
        /// 
        /// </summary>
        public string ServerName { get; set; }
        /// <summary>
        /// 
        /// </summary>
        public string DatabaseName { get; set; }
        /// <summary>
        /// 
        /// </summary>
        public string DataSrource { get; set; }
        /// <summary>
        /// 
        /// </summary>
        public string DataFile { get; set; }


    }


}

  

 

  /// <summary>
        /// 
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void button3_Click(object sender, EventArgs e)
        {

            //string connectionString = "dsn=LocalServer";
            //System.Data.Common.DbConnectionStringBuilder builder = new System.Data.Common.DbConnectionStringBuilder(); 
            //builder.ConnectionString = connectionString;
            //string server = builder["Data Source"] as string;
            //string database = builder["Initial Catalog"] as string;

            //string conString = "SERVER=localhost;DATABASE=tree;UID=root;PASSWORD=branch;Min Pool Size = 0;Max Pool Size=200";
            //SqlConnectionStringBuilder builder = new SqlConnectionStringBuilder(conString);
            //string user = builder.UserID;
            //string pass = builder.Password;

            //OdbcConnectionStringBuilder buil =new OdbcConnectionStringBuilder();
            //buil.Driver = "Sybase SQL Anywhere 5.0";
            //buil.Dsn = "achive";

            System.Data.Odbc.OdbcConnectionStringBuilder connBuilder = new System.Data.Odbc.OdbcConnectionStringBuilder();
            connBuilder.Dsn = "achive";
            connBuilder.Driver = "Sybase SQL Anywhere 5.0";           
            //connBuilder.Add("uid", "");
            //connBuilder.Add("pwd", "");

            connBuilder.Add("database", "塗聚文");
            
            string sss = connBuilder.ToString();
            //MessageBox.Show(connBuilder.ToString());
            System.Data.Odbc.OdbcConnection conn = new System.Data.Odbc.OdbcConnection(connBuilder.ToString());
            try
            {
                conn.Open();
                System.Data.Odbc.OdbcCommand comm = new System.Data.Odbc.OdbcCommand("select count(*) from item_description", conn);
                var reader = comm.ExecuteReader();
                while (reader.Read())
                {
                    MessageBox.Show(reader[0].ToString());
                }
                MessageBox.Show("連接成功!");
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message.ToString());
            }
            finally
            {
                conn.Close();
            }
          
            //設置
            //OdbcConnectionStringBuilder.Dsn=connectionString;


        }


        /// <summary>
        /// 
        /// </summary>
        /// <param name="Database"></param>
        /// <param name="Version"></param>
        /// <returns></returns>
        public static string GetODBCDriverName(string Database, string Version)
        {

            string ODBCDriverName = "";

            RegistryKey registryKey = Registry.LocalMachine;

            RegistryKey registrySubKey = registryKey.OpenSubKey(@"SOFTWARE\ODBC\ODBCINST.INI\");

            String[] SubKeyNames = registrySubKey.GetSubKeyNames();

            foreach (String KeyName in SubKeyNames)
            {

                if (KeyName.Contains(Database) && KeyName.Contains(Version))
                {

                    ODBCDriverName = KeyName;

                    break;

                }
            }

            registrySubKey.Close();

            registryKey.Close();

            return ODBCDriverName;

        }
        /// <summary>
        /// 
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void button4_Click(object sender, EventArgs e)
        {
                OdbcConnectionStringBuilder odbcConnectionStringBuilder = new OdbcConnectionStringBuilder();
                OdbcCommand odbcCommand;
                int RecordFound = 0;
                odbcConnectionStringBuilder.Driver = GetODBCDriverName("Sybase SQL Anywhere", "5.0");
                if (odbcConnectionStringBuilder.Driver == "")
                {

                    MessageBox.Show(" ODBC Driver is not installed");
                    //return -1;
                }
                odbcConnectionStringBuilder.Add("DSN", "achive");
                //odbcConnectionStringBuilder.Add("UID", "no-user");
                //odbcConnectionStringBuilder.Add("PWD", "no-pass");
                odbcConnectionStringBuilder.Add("DB", @"C:\Documents and Settings\geovindu\My Documents\Visual Studio 2010\Projects\SQLanyWhereDemo\SQLanyWhereDemo\bin\Debug\geovindu.db;"); // copy of database SPORTS
                odbcConnectionStringBuilder.Add("HOST", ".");
                //odbcConnectionStringBuilder.Add("PORT", "5162"); // i found this port inn the log file
                using (OdbcConnection connection = new OdbcConnection(odbcConnectionStringBuilder.ConnectionString))

                {

                    connection.Open();
                        try
                        {
                                odbcCommand = new OdbcCommand("SELECT COUNT(*) FROM pub.Invoice WHERE Invoicenum > 0", connection);
                                odbcCommand.CommandTimeout = 1;
                                object executeScalarResult = odbcCommand.ExecuteScalar();
                                RecordFound = Convert.ToInt32(executeScalarResult);
                        }
                        catch (Exception ex)
                        {
                            MessageBox.Show(ex.Message.ToString());
                        }
               }


    }

  


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • settings.py 一般不用修改settings.py,但是使用模版需要修改如下:(即將TEMPLATES中的DIRS改成[os.path.join(BASE_DIR, 'templates')]) urls.py models.py views.py index.html login.html ...
  • java類里的重載構造函數可以互相調用,如下代碼: 代碼執行結果是: constructor1:TestConstructor@74a14482constructor2:TestConstructor@74a1448210TestConstructor@74a14482 可見結果是預期的,對valu ...
  • 題目背景 無 題目描述 有兩堆石子,數量任意,可以不同。游戲開始由兩個人輪流取石子。游戲規定,每次有兩種不同的取法,一是可以在任意的一堆中取走任意多的石子;二是可以在兩堆中同時取走相同數量的石子。最後把石子全部取完者為勝者。現在給出初始的兩堆石子的數目,你先取,假設雙方都採取最好的策略,問最後你是勝 ...
  • 對資料庫操作的常用方法 ...
  • 引言 隨著手機及移動設備的普及,移動端的應用也進入了熱潮。以前PC端的門戶網站,大多也均推出了適配移動設備的網站或者APP,再差的也註冊了個公眾號。在移動應用開發中,目前據我所瞭解到的解決方案有:1、原生態APP開發;2、適配移動設備的JS+HTML網站,套上跨平臺的“馬甲”;3、微信小程式及公眾號 ...
  • var array=['REG','2018','2018']; array.indexOf(‘REG’) // 0 array.indexOf(‘R’) // -1 array.indexOf(’2018′) // 1 array.indexOf(2018) // -1 var array=['R ...
  • Routing 到目前為止,我們已經解決了MVC的很多問題,但忽略了最基本的最重要的一個問題:當用戶發送請求時,會發生什麼? 最好的答案是“執行Action 方法”,但仍存在疑問:對於一個特定的URL請求,如何確定控制器和action 方法。在開始實驗31之前,我們首先來解答上述問題,你可能會困惑為 ...
  • 在前面的文章中,我們已經知道如何合併、拆分多個PDF文件,在這篇文章中的合併、拆分PDF文檔主要是以方便文檔管理的目的來操作文檔,在文檔查閱、管理及存儲上很方便實用。但是我們如果想要合併多個文檔中的部分文檔頁的內容,該如何來做呢?可以參考接下來將要介紹的合併方法。 PS: 本篇文章是對Free Sp ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...