zoukankan      html  css  js  c++  java
  • web.config连接字符串的一些总结

    阅读目录

    DS01:数据库连接字符串的两种写法

    1、连接字符串的两种写法:

    <configuration>
       <appSettings>
          <add key="connstr1" value="Data Source=.;Initial Catalog=DBName;Integrated Security=true"/>
          <add key="connstr2" value=".........">
       </appSettings>
       <connectionStrings>
          <add name="connstr3" connectionString="........" />
          <add name="connstr4" connectionString="......" providerName="System.Data.Sqlclient"/>
       </connectionStrings>
    </configuration>

    如上代码所示:两种方式为<appSettings><connectionStrings>

    2、下面对两种写法进行分析:

    appSettings:

     ①它是asp.net1.1的时候用的,在vs2003中用的。

     ②里面存的相当于键值对的形式,key和value。不仅仅可以存连接字符串,还可以存储一些配置项。

     ③在appSettings中,不能使用ProviderName="System.Data......."(不过如果你要用也可以,只要写在value里面就可以了,当成值传递过去)。

     ④在后台取值方式:string conn=System.Configuration.ConfigurationManager.AppSettings["connstr";]

    connectionStrings:

    ①它是asp.net2.0中新增的。

    ②里面存的也类似于键值对的形式,使用的是name和connectionString,一般就存连接字符串。

    ③在connectionStrings中可以使用providerName。

    ④在后台取值的方式:string conn=System.Configuration.ConfigurationManager.ConnectionStrings["connstr"].ConnectionString;

    3、两种方式的区别:
    connectionStrings是2.0版本出来的,它比appsettings多的好处如下:

    ① 可将连接字符串加密,使用MS的一个加密工具即可。 

    ② 可直接绑定数据源控件,而不必写代码读出来再赋值给控件。 

    ③ 可方便的更换数据库平台,如换为Oracle数据库,只需修改providerName。

     

    4、providerName的作用是什么呢?

    我们先看一下providerName的参数值。

    ①providerName="System.Data.SqlClient"        ----说明使用的是MSSQLServer数据库
    ②providerName="System.Data.SqlLite"           ----说明使用的是SQLLite数据库
    ③providerName="System.Data.OracleClient"  ----说明使用的是Oracle数据库
    或providerName="System.Data.Oracle.DataAccess.Client"  ----同上
    ④providerName="System.Data.OleDb"           ----说明使用的是Access数据库

    注意:providerName可写可不写。

     

    5、那我们什么时候用providerName呢?

    比如,我们现在要做一个项目,以后会卖个两个企业使用:A和B。那么这就有不确定因素了,万一A使用Oracle,而B使用SQL Server呢?所以:

    ①数据库:我们需要建两个库,一个用Oracle,一个用SQL Server。

    ②程序:我们一般不去写两个系统让他们使用,我们肯定会去判断他们使用的是什么数据库,然后再在程序里执行什么样的数据库脚本。

    ③web.config代码如下:

    <configuration>
      <connectionStrings>
        <add name="connStr" connectionString="Data Source=.;Initial Catalog=mydb;Integrated Security=true"  providerName="System.Data.SqlClient"/>
      </connectionStrings>
    </configuration>

    ④程序代码如下:
     
    现在进行判断,如果providerName="System.Data.SqlClient"则执行SQLServer的脚本,而如果providerName="System.Data.OracleClient"则调用Oracle的数据库脚本,代码如下:
     1 public static readonly string connStr = System.Configuration.ConfigurationManager.ConnectionStrings["connStr"].ConnectionString;
     2 public static string databaseType = System.Configuration.ConfigurationManager.ConnectionStrings["connStr"].ProviderName;
     3 public static int ExecuteNonQuery(CommandType commandType, string commandText, params System.Data.OleDb.OleDbParameter[] parm)
     4 {
     5     int num = 0;
     6     if (databaseType == "System.Data.SqlClient")
     7     {
     8         //此处执行Microsoft SQLServer的数据库脚本
     9     }
    10     else if (databaseType == "System.Data.OracleClient")
    11     {
    12         //此处执行Oracle的数据库脚本
    13     }
    14     return num;
    15 }            

    回到顶部

    DS02:数据库连接字符串的内容

    1、背景:我们写一个程序要访问SQL Server数据库就要用到连接字符串,连接字符串告诉程序要连接哪台数据库服务器,哪个实例,哪个数据库,以及数据库登录验证方式是什么等信息。

         这三者是最基本的,所以连接字符串最少由以上三个要素组成,其他的根据不同的情况用到什么添加什么即可。

    2、虽然说最简单的数据库连接字符串仅由三个要素组成,但是有很多的写法,我们首先来看最简单的连接字符串书写格式:

    @”Data Source=XL-PC; Initial Catalog=DB_Test; UID=Sa; PWD= test”

    @”Data Source=XL-PC; Initial Catalog=DB_Test; Integrated Security=true”

    3、以上是两个最简单的连接字符串,现在我们来具体分析一下:

    (1)DataSource:指定要连接到的数据服务器名称。书写格式一般为“数据服务器名/实例名”。

    DataSource也可以用Server,Address,Addr来代替。如果数据库服务器在本地,该项可以直接写“.”或者“(local)”两者都不包括引号。

    如果本地安装了多个数据库实例,直接写“.”或者“(local)”会自动连接到较高版本的实例。

    本地非EXPRESS版数据库服务器地址于数据库实例名称相同,可以直接写数据库服务器名称;

    本地Express版本的数据库实例名一般默认为“计算机名+/SQLEXPRESS”如“XL-PC/SQLEXPRESS”或“(local)/SQLEXPRESS”或“./SQLEXPRESS”;

    如果连接的是远程服务器则格式为“IP地址+/实例名”。

    Data和Source之间必须有且只有一个空格。除密码外不区分大小写。所有标点符号都是英文标点。

     (2)Initial Catalog:指定要连接的数据库名称。

    数据规范与DataSource相同,也可以用Database代替。

     (3)UID为用户名,PWD为密码,两者分别可以用Userid和Password代替。

     (4)Integrated Security:属性设为true表示采用Windows身份验证,不需要指定用户名与密码。

    回到顶部

    2015年1月19日 13:26:59

    by selonsy

  • 相关阅读:
    Upgrading to MySQL 5.7---focusing on temporal types
    mysqldump备份7
    mysqldump原理5
    mysqldump原理4
    mysqldump原理3
    mysqldump原理2
    mysqldump原理1
    MySQL复制中slave延迟监控
    赵浮云的blog 关注IT运维,开源硬件。
    爱维帮---LVS
  • 原文地址:https://www.cnblogs.com/selonsy/p/4233605.html
Copyright © 2011-2022 走看看