zoukankan      html  css  js  c++  java
  • win7(64bit)中asp.net连接sybase

    总的来说有三种方式:

    1.ODBC :需要安装ase odbc驱动。本文里用的是ase15版本

    2.OLEDB:需要安装ase oledb驱动,本文版本ase15

    3.Sybase.Data.AseClient 连接 。需要Sybase.Data.AseClient.dll文件并在项目里引用。

    连接字符串参考:http://www.connectionstrings.com/sybase-adaptive

    代码:

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Data;
    using System.Data.Odbc;
    using System.Data.OleDb;
    using Sybase.Data.AseClient; 
    
    namespace ConsoleApplication1
    {
        class Program
        {
            static void Main(string[] args)
            {
                DBInfo dbinfo=new DBInfo{
                    ip="---",
                    port="---",
                    uid="---",
                    pwd="----"
                };
                string sql = "select Psam_id , Tel_no from Itel_reg_info";
                Console.WriteLine("测试开始:"+DateTime.Now);
                funDll(dbinfo,sql);
                Console.WriteLine("DLL结束:" + DateTime.Now);
                funOLEDB(dbinfo,sql);
                Console.WriteLine("OLEDB结束:" +DateTime.Now);
                funODBC(dbinfo,sql);
                Console.WriteLine("ODBC结束:"+DateTime.Now);
                Console.ReadLine();
            }
            static void funODBC(DBInfo dbinfo,string sql)
            {
                string connectionString = @"Driver={Adaptive Server Enterprise};server=" + dbinfo.ip + ";port=" + dbinfo.port + "; uid=" + dbinfo.uid + ";pwd=" + dbinfo.pwd + ";";
                OdbcConnection myConnection = new OdbcConnection(connectionString);
                OdbcDataAdapter myDataAdapter = new OdbcDataAdapter(sql, myConnection);
                myConnection.Open();
                DataSet ds = new DataSet();
                myDataAdapter.Fill(ds);
            }
            static void funOLEDB(DBInfo dbinfo,string sql)
            {
                string connectionString = @"Provider=ASEOLEDB;Data Source=" + dbinfo.ip + ":" + dbinfo.port + ";User Id=" + dbinfo.uid + ";Password=" + dbinfo.pwd + ";";
                OleDbConnection myConnection = new OleDbConnection(connectionString);
                OleDbDataAdapter myDataAdapter = new OleDbDataAdapter(sql, myConnection);
                myConnection.Open();
                DataSet ds = new DataSet();
                myDataAdapter.Fill(ds);
            }
            static DataSet funDll(DBInfo dbinfo,string sql)
            {
                string connectionString = @"Data Source='" + dbinfo.ip + "';Port=" + dbinfo.port + ";UID='" + dbinfo.uid + "';Password='" + dbinfo.pwd + "'";
                AseConnection myConnection = new AseConnection(connectionString);
                AseDataAdapter myDataAdapter = new AseDataAdapter(sql, myConnection);
                myConnection.Open();
                DataSet ds = new DataSet();
                myDataAdapter.Fill(ds);
                return ds;
            }
        }
    }
    
    Class DBInfo:
        class DBInfo
        {
            public string ip { get; set; }
            public string port { get; set; }
            public string uid { get; set; }
            public string pwd { get; set; }
        }

    Itel_reg_info表有40万的数据,我实验的结果是funDll 2秒完成,funOLEDB  7秒完成,funODBC 16秒完成。

    最后感叹一下,ODBC太坑爹了~~~~~~~

  • 相关阅读:
    Vue的router和route的区别
    对cookie进行编解码用到的函数escape,unescape
    动态控制按钮的禁用和启用
    追踪算法总结
    MATLAB imread读取imwrite保存图片前后矩阵数据不一样
    图像质量评价和视频质量评价(IQA/VQA)
    c++ 使用torchscript 加载训练好的pytorch模型
    Transformer(self attention pytorch)代码
    tensorflow 单机多GPU训练时间比单卡更慢/没有很大时间上提升
    python+selenium爬取关键字搜索google图片
  • 原文地址:https://www.cnblogs.com/lt1983/p/1968314.html
Copyright © 2011-2022 走看看