首页 > 网站 > 建站经验 > 正文

ADO.NET中的Conn,ection对象详解

2019-11-02 15:06:26
字体:
来源:转载
供稿:网友

   连接字符串

  连接字符串的几个常用参数:

  Provider:这个属性用于设置或返回连接提供程序的名称,仅用于OleDbConnection对象。

  Connection Timeout或Connect Timeout:在中止尝试并产生异常前,等待连接到服务器的连接时间长度(以秒为单位)。默认是15秒。

  Initail Catalog:数据库的名称。

  Data Source:连接打开时使用的sql server名称,或者是Microsoft Access数据库的文件名。

  Password:SQL Server帐户的登录密码。

  User ID:SQL Server登录帐户。

  Integrat

小调网电影下载[www.aikan.tv/special/xiaodiaowang/]
ed Security或Trusted Connection:此参数决定是否是安全连接。可能的值有True、False和SSPI(SSPI是True的同义词)。

  Persist Security Info:当设置为False时,如果连接是打开的或曾经处于打开状态,那么安全敏感信息(如密码)不会作为连接的一部分返回。设置属性值为True可能有安全风险。False是默认值。

  1.写法一

  “Data Source=服务器名; Initial Catalog=数据库; User ID =用户名; Password=密码; Charset=UTF8; “

  2.写法二

  “Server=服务器名; Database=数据库; uid=用户名; Password=密码;Charser=UTF8″

  PS: Integrated Security = True;

  如果忘了连接字符串怎么写怎么办?(虽然挺丢人的)

  可以使用SqlConnectionStringBuilder生成字符串,如果忘了怎么写。

  MySqlConnectionStringBuilder可以用点出来你想要的属性。

  Connection需要释放

  Connection是实现了IDisposable接口的对象。使用Connection需要释放资源。

  建议用 using(Connection对象)

  {

  //自动Close(); 自动Dispose();

  }

  StateChange事件

  这个事件会监听数据库连接状态。当数据库连接状态改变时,就会触发这个操作。

  我们就可以进行一些操作。

  数据库连接状态是一个枚举,ConnectionState。

  目前为止ConnectionState一共有三个用的上值分别是

  Closed 连接处于关闭状态。

  Connecting 连接对象正在与数据源连接。

  Open 连接处于打开状态。

  连接池

  1.实验

  首先,在连接字符串中设置 pooling = false;

  然后通过

  StopWatch watch =new StopWatch( );

  watch.Start();

  //进行数据库操作。

  watch.Stop();

  输出watch.Elapsed;

  我们惊喜的返现,在连接字符串中设置了pooling = false以后,照原有性能下降了20~30倍。

  Connection对象提供了4种连接方式

  1、OLEDB :System.Data.Oledb.OledbConnection 对于非SQL Server和非Oracle数据库使用

  2、SQL:System.Data.SqlCilent.SqlConnection 用于连接SQL Server数据库

  3、ODBC:System.Data.Odbc.OdbcConnection 如果数据库没有内置的OLEDB,则可以使ODBC.NET数据提供者对象。

  4、Oracle:System.Data.OracleClient.OracleConnection 用于连接Oracle数据库

  为什么呢?

  我继续看,下一个实验。先把pooling = false删掉。

  用循环控制 Connection对象的关闭与打开。进行2000次吧。

  然后我们使用SqlServer【工具】→【SQL Server Profiler】。使用这个工具可以观察数据库事务、连接记录。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表