web.config connectionStrings[通俗易懂]

web.config connectionStrings[通俗易懂] web.configconnectionStrings数据库连接字符串的解释先来看一下默认的连接SQLServer数据库配置  SqlConnectionStringBuilder实例化时需要使用connectionString。如:SqlConnectionStringBuildbuilder=newSqlConnectionStringBuild(connection

大家好,又见面了,我是你们的朋友全栈君。

 web.config connectionStrings 数据库连接字符串的解释

先来看一下默认的连接SQL Server数据库配置
<connectionStrings>
   <add name=”LocalSqlServer” connectionString=”Data Source=./SQLExpress;Integrated Security=SSPI;AttachDBFilename=|DataDirectory|aspnetdb.mdf;User Instance=true” providerName=”System.Data.SqlClient” />
</connectionStrings>

SqlConnectionStringBuilder实例化时需要使用connectionString。如:SqlConnectionStringBuild builder = new SqlConnectionStringBuild(connectionString);

一、Data Source
SqlConnectionStringBuilder的DataSource属性,对应connectionString中的Data Source,“Data Source”可以由下列字符串代替:“Server”,“Address”,“Addr”和“Network Address”。
Data Source=./SQLExpress也可以写成这样Data Source=(local)/SQLExpress。

二、Integrated Security
SqlConnectionStringBuilder 的 IntegratedSecurity 属性,对应 connectionString 中的I ntegrated Security,“Integrated Security”可以写成“trusted_connection”。
为 True 时,使用当前的 Windows 帐户凭据进行身份验证,为 False 时,需要在连接中指定用户 ID 和密码。可识别的值为 True、False、Yes、No 以及与 True 等效的 SSPI。
如果没有些则必须写上 uid=sa;pwd=123 之类的设置“uid”也可使用“User ID”,“pwd”也可换为“PassWord”。

SSPI:Microsoft安全支持提供器接口(SSPI)是定义得较全面的公用API,用来获得验证、信息完整性、信息隐私等集成安全服务,以及用于所有分布式应用程序协议的安全方面的服务。
应用程序协议设计者能够利用该接口获得不同的安全性服务而不必修改协议本身。

三、AttachDBFilename
SqlConnectionStringBuilder 的 AttachDBFilename 属性,对应 connectionString 中的 AttachDBFilename,“AttachDBFilename”可以写成“extended properties”,“initial file name”。
AttachDbFileName 属性指定连接打开的时候动态附加到服务器上的数据库文件的位置。
这个属性可以接受数据库的完整路径和相对路径(例如使用|DataDirectory|语法),在运行时这个路径会被应用程序的 App_Data 目录所代替。

四、User Instance
SqlConnectionStringBuilder 的 UserInstance 属性,对应 connectionString 中的 User Instance ,该值指示是否将连接从默认的 SQL Server 实例重定向到在调用方帐户之下运行并且在运行时启动的实例。
UserInstance=true 时,SQLServerExpress 为了把数据库附加到新的实例,建立一个新的进程,在打开连接的用户身份下运行。
在 ASP.NET 应用程序中,这个用户是本地的 ASPNET 帐号或默认的 NetworkService,这依赖于操作系统。
为了安全地附加非系统管理员帐号(例如ASP.NET帐号)提供的数据库文件,建立一个独立的 SQLServer 用户实例是必要的。

五、Initial Catalog 等同于 Database。

六、providerName 指定值“System.Data.OracleClient”,该值指定 ASP.NET 在使用此连接字符串进行连接时应使用 ADO.NET System.Data.OracleClient 提供程序。

PS:
DataDirectory是什么?

asp.net 2.0有一个特殊目录app_data,通常Sql Server 2005 express数据文件就放在这个目录,相应的数据库连接串就是:
connectionString=”…… data source=./SQLEXPRESS;Integrated Security=SSPI;AttachDBFilename=|DataDirectory|data.mdf;User Instance=true”
这里有一个DataDirectory的宏,它表示什么意义呢?

DataDirectory是表示数据库路径的替换字符串。由于无需对完整路径进行硬编码,DataDirectory 简化了项目的共享和应用程序的部署。例如,无需使用以下连接字符串:
“Data Source= c:/program files/MyApp/app_data/Mydb.mdf”
通过使用|DataDirectory|(包含在如下所示的竖线中),即可具有以下连接字符串:
“Data Source = |DataDirectory|/Mydb.mdf” 。

不仅仅是Sql server 2005 express中使用,也可以在其它的文件数据库中使用,例如Sqllite数据库文件的连接字符串:

<add name=”DefaultDB”
connectionString=”DriverClass=NHibernate.Driver.SQLite20Driver;Dialect=NHibernate.Dialect.SQLiteDialect;Data Source=|DataDirectory|/data.db3″ />

—————————————    附加一些连接语句例子    —————————————

<–普通例子1–>
<configuration>
<connectionStrings>
    <add name=”Sales” providerName=”System.Data.SqlClient” connectionString=”server=myserver;database=Products;uid=salesUser;pwd=sellMoreProducts” />

    <add name=”NorthWind” providerName=”System.Data.SqlClient” connectionString=”server=.;database=NorthWind;Integrated Security=SSPI” />

</connectionStrings>
</configuration>

<–普通例子2–>
<configuration>
<connectionStrings>
    <add name=”NorthWind” connectionString=”Provider=SQLOLEDB;Integrated Security=SSPI;Initial Catalog=da;Data Source=bar” />
</configuration>

———————————————————————————————————-

<connectionStrings>
   <add name=”LocalSqlServer” connectionString=”Data Source=./SQLExpress;Initial Catalog=NorthWind;Integrated Security=SSPI” providerName=”System.Data.SqlClient” />
</connectionStrings>
<–也可写为–>
<connectionStrings>
   <add name=”LocalSqlServer” connectionString=”Server=./SQLExpress;Database=NorthWind;Integrated Security=Yes” providerName=”System.Data.SqlClient” />
</connectionStrings>

———————————————————————————————————-

<configuration>
<connectionStrings>
    <add name=”DB2005_2″
    providerName=”System.Data.SqlClient”
    connectionString=”Data Source=.;Initial Catalog=Northwind;User ID=dbtester;Password=zhi;Trusted_Connection=False;Connect Timeout=30;Min Pool Size=16;Max Pool Size=100″/>

    <add name=”DB2005_1″
    providerName=”System.Data.SqlClient”
    connectionString=”Server=.;Database=Northwind;User ID=dbtester;Password=zhi;Trusted_Connection=False;Connect Timeout=30;Min Pool Size=16;Max Pool Size=100″/>

    <add name=”Northword2000″
    providerName=”System.Data.SqlClient”
    connectionString=”Initial Catalog=Northwind;User ID=dbtester;PassWord=zhi;Persist Security Info=false;Data Source=(local);Connect Timeout=30;Min Pool Size=16;Max Pool Size=100;”/>

    <add name=”SQLExp”
       providerName=”System.Data.SqlClient”
       connectionString=”Data Source=./SQLEXPRESS;AttachDbFilename=|DataDirectory|/northwnd1.mdf;Integrated Security=True;Connect Timeout=30;User Instance=True”/>
   
    <add name=”Oracle”
      connectionString=”Data Source=TEST;User ID=sa;Password=sa;”
      providerName=”System.Data.OracleClient” />

    <add name=”oleconn”
       providerName=”System.Data.OleDb”
       connectionString=”Provider=Microsoft.Jet.OleDb.4.0;Data Source=|DataDirectory|northwind.mdb”/>

    <add name=”MySql”
    providerName=”MySql.Data.MySqlClient”
    connectionString=”Server=172.29.131.27;Port=3311;DataBase=comctl;Persist Security Info=False;User ID=root;Password=123456;Allow Zero Datetime=true;” />
</connectionStrings>
    <system.data>
        <DbProviderFactories>
            <add name=”MySQL Data Provider”
                 invariant=”MySql.Data.MySqlClient”
                 description=”.Net Framework Data Provider for MySQL”
                 type=”MySql.Data.MySqlClient.MySqlClientFactory, MySql.Data, Version=5.2.5.0, Culture=neutral, PublicKeyToken=c5687fc88969c44d”/>
        </DbProviderFactories>
    </system.data>
</configuration>

======================================      可以保存为(以下转自他处).cs      ======================================

using System.Data.SqlClient;
using System.Configuration;
public class Class1
{

    public Class1()
    {

        //Persist Security Info如果数据库连接成功后不再需要连接的密码,建议False
        //string sql2000 = “Initial Catalog=Northwind;User ID=dbtester;PassWord=zhi;Persist Security Info=false;Data Source=(local);Connect Timeout=30;Min Pool Size=16;Max Pool Size=100;”;
        //string sql2000 = “Initial Catalog=Northwind;User ID=sa;PassWord=5;Persist Security Info=false;Data Source=.”;
        //string sql2000 = “Initial Catalog=Northwind;User ID=sa;PassWord=5;Persist Security Info=false;Data Source=newtime”;
        string source = “server=(local);integrated security=SSPI;database=Northwind”;
        string expressSource = @”Data Source=./SQLEXPRESS;AttachDbFilename=|DataDirectory|/northwnd.mdf;Integrated Security=True;Connect Timeout=30;User Instance=True”;
        //Integrated Security采用windows的集成身份验证,integraged   Security=SSPI;
        //Integrated Security=SSPI 这个表示以当前WINDOWS系统用户身去登录SQL SERVER服务器,如果SQL SERVER服务器不支持这种方式登录时,就会出错
        //表示你的连接安全验证方式,可用trusted_connection=yes取代
        //Integrated Security 为 True。用户实例仅与集成安全性一起使用,带有用户名和密码的 SQL Server 用户不起作用。
        //string source3 = @”Data Source=190.190.200.100,1433;Network Library=DBMSSOCN;Initial Catalog= pubs;UserID=sa;Password=asdasd;”;
        //(DBMSSOCN=TCP/IP instead of Named Pipes, at the end of the Data Source is the port to use (1433 is the default))
        //Standard Security:
        string source4 = “Data Source=Aron1;Initial Catalog= pubs;UserId=sa;Password=asdasd;”;
        string source5 = “Server=Aron1;Database=pubs;UserID=sa;Password=asdasd;Trusted_Connection=False”;
        //Trusted_Connection ‘false’ 当为 false 时,将在连接中指定用户 ID 和密码。当为 true 时,将使用当前的 Windows 帐户凭据进行身份验证。
        //可识别的值为 true、false、yes、no 以及与 true 等效的 sspi(强烈推荐)。所以一定要设置Trusted_Connection= false,以防被别人”登录”、”注入语句”等
        string source6 = “Data Source=Aron1;Initial Catalog=pubs;Integrated Security=SSPI;”;
        string source7 = “Server=Aron1;Database=pubs;Trusted_Connection=True;”;
        //(use serverName/instanceName as Data Source to use an specifik SQLServer instance, only SQLServer2000)
        //Integrated   Security或Trusted_Connection   ‘false’   当为   false   时,
        //将在连接中指定用户   ID   和密码。当为   true   时,将使用当前的   Windows   帐户凭据进行身份验证
        //VS2003:string connStr=System.Configuration.ConfigurationSettings.AppSettings[“SQLCONNECTIONSTRING”];2003中用的
        //VS2005:string connStr=System.Configuration.ConfigurationManager.ConnectionStrings[“SQLCONNECTIONSTRING”].ToString();2005-8中用
        System.Configuration.ConnectionStringSettings i = System.Configuration.ConfigurationManager.ConnectionStrings[“Northword2000”];
    }
}

 

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/lzyzwbn/archive/2009/09/06/4525179.aspx

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/143508.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • centos安装python环境

    centos安装python环境centos安装python环境查看系统自带版本查看系统自带版本位置下面介绍安装Python3的方法下载python包解压安装包创建软链接升级pip测试python3由于centos7原本就安装了Python2,而且这个Python2不能被删除,因为有很多系统命令,比如yum都要用到。查看系统自带版本输入Python命令,查看可以得知是Python2.7.5版本查看系统自带版本位置whichpython一般是位于/usr/bin/python目录下。下面介绍安装Python3的方法

    2022年6月29日
    36
  • 数据库设计工具MySQLWorkBench[通俗易懂]

    数据库设计工具MySQLWorkBench[通俗易懂]  该工具为MySQL官方提供地址:http://dev.mysql.com/downloads/workbench/小伙伴们注意按自己的操作系统选择下载版本。·       注意事项:安装后将环境语言配置成简体中文,否则中文乱码工作步骤新建模型后,会进入此页面。 1./2.切换数据库表设计与ER图。3. 创建/管理ER图4. 创建/管理表结构1….

    2022年7月11日
    20
  • 第一次安装android studio时候弹出unable to access android sdk add-on list解决方法

    第一次安装android studio时候弹出unable to access android sdk add-on list解决方法

    2021年9月30日
    68
  • icem网格划分如何给内部面网格,ICEM CFD处理混合网格划分中低质量的问题

    icem网格划分如何给内部面网格,ICEM CFD处理混合网格划分中低质量的问题所谓的混合网格,指的是模型中同时存在结构网格与非结构网格的情况。采用混合网格的主要优势在于:对于复杂的几何,我们可以将其分解成多个几何,对于适合划分结构网格的采用结构网格划分方式,而对于非常复杂的部分,可以使用非结构方式进行划分。然而采用混合网格也有一些缺点:交接面位置网格质量会非常差。因此我们需要采用一些方式对网格质量进行改善。另外对于交界面的处理也存在一些问题。我们先说说在ICEMCFD中进…

    2022年5月26日
    38
  • shell脚本–sed的用法[通俗易懂]

    shell脚本–sed的用法[通俗易懂]sed在处理文本时是逐行读取文件内容,读到匹配的行就根据指令做操作,不匹配就跳过。sed是Linux下一款功能强大的非交互流式文本编辑器,可以对文本文件进行增、删、改、查等操作,支持按行、按字段、按正则匹配文本内容,灵活方便,特别适合于大文件的编辑。本文主要介绍sed的一些基本用法,并通过shell脚本演示sed的使用实例。1.sed的使用方法,调用sed命令的语法有两种:一.在命令…

    2022年7月26日
    10
  • PhpStorm激活码2024.3.5版本最新教程,永久有效激活码,亲测可用,记得收藏

    PhpStorm激活码2024.3.5版本最新教程,永久有效激活码,亲测可用,记得收藏PhpStorm 激活码教程永久有效 2024 3 5 激活码教程 Windows 版永久激活 持续更新 Idea 激活码 2024 3 5 成功激活

    2025年5月23日
    7

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号