C#.NET 各种连接字符串

近期连接数据库时,经常忘记连接字符串是如何的格式,现在此备注

此文章引用http://www.cnblogs.com/zhiqiang-imagine/archive/2010/03/22/1691538.html

且做了些补充

1.C#连接连接Access  
  程序代码:    
   
  using   System.Data;  
  using   System.Data.OleDb;  
  ..  
 
  string   strConnection="Provider=Microsoft.Jet.OleDb.4.0;";  
  strConnection+=@"Data   Source=C:BegASPNETNorthwind.mdb";
   /*

Provider=Microsoft.ACE.OLEDB.12.0  or Provider=Microsoft.Jet.OLEDB.4.0

共同点:都是做为连接Excel对象的接口引擎

不同点:

对于不同的Excel版本,有两种接口可供选择:Microsoft.Jet.OLEDB.4.0(以下简称 Jet 引擎)和Microsoft.ACE.OLEDB.12.0(以下简称 ACE 引擎)。

Jet 引擎,可以访问 Office 97-2003,但不能访问 Office 2007。

ACE 引擎是随 Office 2007 一起发布的数据库连接组件,既可以访问 Office 2007,也可以访问 Office 97-2003。

另外:Microsoft.ACE.OLEDB.12.0 可以访问正在打开的 Excel 文件,而 Microsoft.Jet.OLEDB.4.0 是不可以的。

所以,在使用不同版本的office时,要注意使用合适的引擎

*/
  OleDbConnection   objConnection=new   OleDbConnection(strConnection);  
  ..  
   
  objConnection.Open();  
  objConnection.Close();  
  解释:  
   
   连接Access数据库需要导入额外的命名空间,所以有了最前面的两条using命令,这是必不可少的!  
   
   strConnection这个变量里存放的是连接数据库所需要的连接字符串,他指定了要使用的数据提供者和要使用的数据源.  
   
   "Provider=Microsoft.Jet.OleDb.4.0;"是指数据提供者,这里使用的是Microsoft   Jet引擎,也就是Access中的数据引擎,asp.net就是靠这个和Access的数据库连接的.  
   
   "Data   Source=C:\BegASPNET\Northwind.mdb"是指明数据源的位置,他的标准形式是"Data   Source=MyDrive:MyPath\MyFile.MDB".  
   
  PS:  
   1."+="后面的"@"符号是防止将后面字符串中的"\"解析为转义字符.  
   2.如果要连接的数据库文件和当前文件在同一个目录下,还可以使用如下的方法连接:  
    strConnection+="Data   Source=";  
    strConnection+=MapPath("Northwind.mdb");  
    这样就可以省得你写一大堆东西了!  
   3.要注意连接字符串中的参数之间要用分号来分隔.  
   
   "OleDbConnection   objConnection=new   OleDbConnection(strConnection);"这一句是利用定义好的连接字符串来建立了一个链接对象,以后对数据库的操作我们都要和这个对象打交道.  
   
   "objConnection.Open();"这用来打开连接.至此,与Access数据库的连接完成.  
  --------------------------------------------------------------------------------  
   
  2.C#连接SQL   Server  
  程序代码:    
   
  using   System.Data;  
  using   System.Data.SqlClient;  
  ..  
   
  string   strConnection="user   id=sa;password=;";  
  strConnection+="initial   catalog=Northwind;Server=YourSQLServer;";  
  strConnection+="Connect   Timeout=30";  
   
  SqlConnection   objConnection=new   SqlConnection(strConnection);  
  ..  
   
  objConnection.Open();  
  objConnection.Close();  
  解释:  
   
  连接SQL   Server数据库的机制与连接Access的机制没有什么太大的区别,只是改变了Connection对象和连接字符串中的不同参数.  
   
  首先,连接SQL   Server使用的命名空间不是"System.Data.OleDb",而是"System.Data.SqlClient".  
   
  其次就是他的连接字符串了,我们一个一个参数来介绍(注意:参数间用分号分隔):  
   "user   id=sa":连接数据库的验证用户名为sa.他还有一个别名"uid",所以这句我们还可以写成"uid=sa".  
   "password=":连接数据库的验证密码为空.他的别名为"pwd",所以我们可以写为"pwd=".  
 
 这里注意,你的SQL   Server必须已经设置了需要用户名和密码来登录,否则不能用这样的方式来登录.如果你的SQL  
Server设置为Windows登录,那么在这里就不需要使用"user  
id"和"password"这样的方式来登录,而需要使用"Trusted_Connection=SSPI"来进行登录.  
   "initial   catalog=Northwind":使用的数据源为"Northwind"这个数据库.他的别名为"Database",本句可以写成"Database=Northwind".  
 
 "Server=YourSQLServer":使用名为"YourSQLServer"的服务器.他的别名为"Data  
Source","Address","Addr".如果使用的是本地数据库且定义了实例名,则可以写为"Server=(local)\实例名";如果
是远程服务器,则将"(local)"替换为远程服务器的名称或IP地址.  
   "Connect   Timeout=30":连接超时时间为30秒.  
   
   在这里,建立连接对象用的构造函数为:SqlConnection.  
   
  3.C#连接Oracle  
  程序代码:    
  --------------------------------------------------------------------------------  
   
  using   System.Data.OracleClient;  
  using   System.Data;  
   
  //在窗体上添加一个按钮,叫Button1,双击Button1,输入以下代码  
  private   void   Button1_Click(object   sender,   System.EventArgs   e)  
  {  
  string   ConnectionString="Data   Source=sky;user=system;password=manager;";//写连接串  
  OracleConnection   conn=new   OracleConnection(ConnectionString);//创建一个新连接  
  try  
  {  
  conn.Open();  
  OracleCommand   cmd=conn.CreateCommand();  
   
  cmd.CommandText="select   *   from   MyTable";//在这儿写sql语句  
  OracleDataReader   odr=cmd.ExecuteReader();//创建一个OracleDateReader对象  
  while(odr.Read())//读取数据,如果odr.Read()返回为false的话,就说明到记录集的尾部了                                  
  {  
  Response.Write(odr.GetOracleString(1).ToString());//输出字段1,这个数是字段索引,具体怎么使用字段名还有待研究  
  }  
  odr.Close();  
  }  
  catch(Exception   ee)  
  {  
  Response.Write(ee.Message);   //如果有错误,输出错误信息  
  }  
  finally  
  {  
  conn.Close();   //关闭连接  
  }  
  }  
  -------------------------------------------------------------------------------  
   
  4.C#连接MySQL  
  程序代码:    
  --------------------------------------------------------------------------------  
   
  using   MySQLDriverCS;    
   
  //   建立数据库连接  
  MySQLConnection   DBConn;  
  DBConn   =   new   MySQLConnection(new   MySQLConnectionString("localhost","mysql","root","",3306).AsString);  
  DBConn.Open();    
   
  //   执行查询语句  
  MySQLCommand   DBComm;  
  DBComm   =   new   MySQLCommand("select   Host,User   from   user",DBConn);    
   
  //   读取数据  
  MySQLDataReader   DBReader   =   DBComm.ExecuteReaderEx();    
   
  //   显示数据  
  try  
  {  
  while   (DBReader.Read())  
  {  
  Console.WriteLine("Host   =   {0}   and   User   =   {1}",   DBReader.GetString(0),DBReader.GetString(1));  
  }  
  }  
  finally  
  {  
  DBReader.Close();  
  DBConn.Close();  
  }    
   
  //关闭数据库连接  
  DBConn.Close();  
  --------------------------------------------------------------------------------  
   
  5.C#连接IBM   DB2  
  程序代码:    
  --------------------------------------------------------------------------------  
   
  OleDbConnection1.Open();  
  //打开数据库连接  
  OleDbDataAdapter1.Fill(dataSet1,"Address");  
  //将得来的数据填入dataSet  
  DataGrid1.DataBind();  
  //绑定数据  
  OleDbConnection1.Close();  
  //关闭连接    
   
  //增加数据库数据  
  在Web   Form上新增对应字段数量个数的TextBox,及一个button,为该按键增加Click响应事件代码如下:  
   
  this.OleDbInsertCommand1.CommandText   =   "INSERTsintosADDRESS(NAME,  
  EMAIL,   AGE,   ADDRESS)   VALUES  
  ('"+TextBox1.Text+"','"+TextBox2.Text+"','"+TextBox3.Text+"','"+TextBox4.Text+"')";  
  OleDbInsertCommand1.Connection.Open();  
  //打开连接  
  OleDbInsertCommand1.ExecuteNonQuery();  
  //执行该SQL语句  
  OleDbInsertCommand1.Connection.Close();  
  //关闭连接    
  --------------------------------------------------------------------------------  
   
  6.C#连接SyBase  
  程序代码:   (OleDb)  
  --------------------------------------------------------------------------------  
   
 
Provider=Sybase.ASEOLEDBProvider.2;Initial   Catalog=数据库名;User  
ID=用户名;Data   Source=数据源;Extended   Properties="";Server  
Name=ip地址;Network   Protocol=Winsock;Server   Port   Address=5000;

C#.NET 各种连接字符串的更多相关文章

  1. ASP.NET web.config中的连接字符串

    在ASP.NET的web.config中,可以用两种方式来写连接字符串的配置. <configuration> <appSettings> <add key=" ...

  2. 使用配置文件定义ADO.NET 的连接字符串

    最近一直在学习ADO.NET的相关知识,发现要对数据库操作的地方都要先创建一个连接字符串: string constr ="Data Source=(local);Initial Catal ...

  3. 用SQL Server(T-SQL)获取连接字符串

    一般情况下,C# 连接SQL Server的字符串可以直接按照说明文档直接手动写出来,或者也可以参考大名鼎鼎的connectionstrings手动拼写 但是如果你已经连接到SQL Server也可以 ...

  4. ASP.NET MVC 5 - 创建连接字符串(Connection String)并使用SQL Server LocalDB

    您创建的MovieDBContext类负责处理连接到数据库,并将Movie对象映射到数据库记录的任务中.你可能会问一个问题,如何指定它将连接到数据库? 实际上,确实没有指定要使用的数据库,Entity ...

  5. 《Entity Framework 6 Recipes》中文翻译系列 (38) ------ 第七章 使用对象服务之动态创建连接字符串和从数据库读取模型

    翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 第七章 使用对象服务 本章篇幅适中,对真实应用中的常见问题提供了切实可行的解决方案. ...

  6. EF6 Create Different DataContext on runtime(运行时改变连接字符串)

    引言   在使用EF时,有时我们需要在程序运行过程中动态更改EF的连接字符串,但不幸的时EF是否对 ConfigurationManager.RefreshSection("xxx" ...

  7. MySql 连接字符串

    一.MySQL Connector/ODBC 2.50 (MyODBC 2.50)连接方式 1.本地数据库连接Driver={MySQL};Server=localhost;Option=16834; ...

  8. SQL Server 2008连接字符串写法大全

    一..NET Framework Data Provider for SQL Server 类型:.NET Framework类库使用:System.Data.SqlClient.SqlConnect ...

  9. web.config连接字符串的一些总结

    阅读目录: DS01:数据库连接字符串的两种写法 DS02:数据库连接字符串的内容 DS01:数据库连接字符串的两种写法 1.连接字符串的两种写法: <configuration>   & ...

  10. SQL Server 连接字符串备忘

    今天把服务器上的远程访问关了,把连接字符串中的IP地址改成了.,然后就一直连不上.弄了半天,原来是本地连接时非默认实例,不能带端口号. 1.原来的连接服务器地址是:192.168.0.1SQL2005 ...

随机推荐

  1. angularjs如何在ng-repeat过程中控制字符串长度超过指定长度后面内容以省略号显示

    angular.module('ng').filter('cut', function () { return function (value, wordwise, max, tail) { if ( ...

  2. Flask学习记录之Flask-SQLAlchemy

    Flask-SQLAlchemy库让flask更方便的使用SQLALchemy,是一个强大的关系形数据库框架,既可以使用orm方式操作数据库,也可以使用原始的SQL命令. Flask-Migrate ...

  3. C/C++与lua实现互调

    1,在lua脚本中调用C/C++代码中的函数 在C++中定义函数时必须以lua_State为参数, 以int为返回值才能被Lua所调用. /* typedef int (*lua_CFunction) ...

  4. Gizmos绘制塔防游戏网格

    1.画线脚本写法及地面调整 首先,新建脚本GridMap 新建绘制网格方法(初始数值为10*10) 在类中创建变量 //定义地图宽度 public int m_mapWidth = 10; //地图高 ...

  5. 一颗 45nm CPU的制造过程

    沙子 :硅是地壳内第二丰富的元素,而脱氧后的沙子(尤其是石英)最多包含25%的硅元素,以二氧化硅(SiO2)的形式存在,这也是半导体制造产业的基础. 硅熔炼: 12英寸/300毫米晶圆级,下同.通过多 ...

  6. PLSQL 循环示例

    <pre name="code" class="sql"><pre name="code" class="sql ...

  7. linux会话命令screen详解

    Screen会话命令 我其实是把文件下载到 /home/zhang/temp/ 里面,当我N久以后再联上服务器,想看看文件下载情况怎样,那又要 cd 老半天,这时候 screen 就是好帮手了. 顾名 ...

  8. hadoop 2.3 集群总结

    用了近两个礼拜的摸索终于搭建好了hadoop集群,测试性能也符合预期. centos6.4下hadoop2.3集群总结如下: 关于环境的设置: 1.关闭selinux (反复折腾了好多次) vi /e ...

  9. 【转】win32,win64编程永恒;语言编程需要注意的64位和32机器的区别

    原文网址:http://www.cnblogs.com/kex1n/archive/2010/10/06/1844737.html 一.数据类型特别是int相关的类型在不同位数机器的平台下长度不同.C ...

  10. 沙湖王 | 用Scipy实现K-means聚类算法

    沙湖王 | 用Scipy实现K-means聚类算法 用Scipy实现K-means聚类算法