C#使用Socket快速判断数据库连接是否正常的方法

本文实例讲述了C#使用Socket快速判断数据库连接是否正常的方法。分享给大家供大家参考。具体分析如下:

大家在做项目的时候,一般都是和数据库有关的。而相信许多人在用代码打开数据库的时候,没有判断数据库连接是否成功。如果写对了还好,但是出错了,会等老长时间(默认15s,不过 实际响应 可能会更长)。而且还会出现卡死的情况,给用户的感觉就会变得非常差劲。所以快速判断数据库连接是否成功,就显得尤为重要了。
 
一般情况下,如果连接字符串正确,那么连接到数据库用的时间一般在5s以内。所以我们可以在连接字符串的最后添加一个等待时间:timeout。如:

代码如下:

string strCon = "Data Source=192.168.24.66;Initial Catalog=master;User ID=sa;password=123456;Connection Timeout=5";

如果连接不成功,应该在5-8s内做出回应。但是并不能确定一定是连接字符串出错。如果大量人访问的话,很可能会出现等待时间超过5s的情况。而且,如果连接不成功,我们依旧最起码得等待5秒。等待的滋味是不好受的,用户一定会给你一个叉叉,所以我们还需要用其他办法来快速判断。

这里我们用Socket来实现这一功能。(至于Socket是什么,有兴趣的朋友可以自己查查资料)

先用Socket来判断与服务器是否连接成功,然后在进行数据库操作。

#region 采用Socket方式,测试服务器连接
/// <summary>
/// 采用Socket方式,测试服务器连接
/// </summary>
/// <param name="host">服务器主机名或IP</param>
/// <param name="port">端口号</param>
/// <param name="millisecondsTimeout">等待时间:毫秒</param>
/// <returns></returns>
public static bool TestConnection(string host, int port, int millisecondsTimeout)
{
  TcpClient client = new TcpClient();
  try
  {
   var ar = client.BeginConnect(host, port, null, null);
   ar.AsyncWaitHandle.WaitOne(millisecondsTimeout);
   return client.Connected;
  }
  catch (Exception e)
  {
   throw e;
  }
  finally
  {
   client.Close();
  }
}
#endregion

下面是数据库的操作,可以根据自己的情况修改。

/// <summary>
/// 数据库连接操作,可替换为你自己的程序
/// </summary>
/// <param name="ConnectionString">连接字符串</param>
/// <returns></returns>
private static bool TestConnection(string ConnectionString)
{
  bool result = true;
  try
  {
   SqlConnection m_myConnection = new SqlConnection(ConnectionString);
   m_myConnection.Open();
   //数据库操作......
   m_myConnection.Close();
  }
  catch (Exception ex)
  {
   System.Diagnostics.Debug.WriteLine(ex.ToString());
   result = false;
  }
  return result;
}

我这里用winForm来测试的。

private void btnSocket_Click(object sender, EventArgs e)
{
  string strCon = "Data Source=192.168.24.566;Initial Catalog=qmaster;User ID=sa;password=123456";
  string[] s=strCon.Split(';');
  s = s[0].Split('=');
  //获取IP
  string strIP =s[1];
  //发送数据,判断是否连接到指定ip
  if (TestConnection(strIP , 1433, 500))
  {
   //连接成功
   MessageBox.Show("Socket Link Succeed","连接服务器");
   // 数据库操作,我这里用了连接测试。可根据你的系统自行修改
   if (TestConnection(strCon))
    MessageBox.Show("Sql Link Succeed","连接数据库");
   else
    MessageBox.Show("Sql Link Failed", "连接数据库");
  }
  else
   MessageBox.Show("Socket Link Failed","连接服务器");
}

用Socket来测试是否连接到服务器非常方便,也非常快捷,不用让用户等待那么长时间,而且这样做还可以知道是服务器地址出错,还是数据库出错。经测试,如果数据库地址出错,在1-3s内即可反馈出结果。提示用户“Socket Link Failed”。而数据库名错误,则只提示“Sql Link Failed”。

这么方便、快捷、高效、易排错的方法,你会不会错过,我不知道,反正我是不会错过了!

希望本文所述对大家的C#程序设计有所帮助。

(0)

相关推荐

  • C#使用ODBC与OLEDB连接数据库的方法示例

    本文实例讲述了C#使用ODBC与OLEDB连接数据库的方法.分享给大家供大家参考,具体如下: using System; using System.Collections.Generic; using System.Text; using System.Data.Odbc; using System.Data.OleDb; namespace ODBCtest { class Program { static void Main(string[] args) { //ODBC连接 string

  • C#连接mysql数据库完整实例

    本文实例讲述了C#连接mysql数据库的方法.分享给大家供大家参考.具体实现方法如下: using System; using System.Configuration; using MySql.Data.MySqlClient; /// <summary> /// TestDatebase 的摘要说明 /// </summary> public class TestDatebase { public TestDatebase() { // // TODO: 在此处添加构造函数逻辑

  • C#简单访问SQLite数据库的方法(安装,连接,查询等)

    本文实例讲述了C#简单访问SQLite数据库的方法.分享给大家供大家参考,具体如下: 下载最新版SQLite(http://www.sqlite.org/download.html),其他版本也可以,这里使用的版本是sqlite-3_6_6_1 a.解压后copy c:\sqlite-3_6_6_1 b.进入cmd模式,进入sqlite-3_6_6_1目录,执行sqlite3 mytest.db c. create table test (seq int,desc varchar(8)); in

  • C#操作SQLite数据库方法小结(创建,连接,插入,查询,删除等)

    本文实例讲述了C#操作SQLite数据库方法.分享给大家供大家参考,具体如下: SQLite介绍 SQLite is a software library that implements a self-contained, serverless, zero-configuration, transactional SQL database engine. SQLite是一个开源.免费的小型RDBMS(关系型数据库),能独立运行.无服务器.零配置.支持事物,用C实现,内存占用较小,支持绝大数的SQ

  • c#连接sqlserver数据库、插入数据、从数据库获取时间示例

    c#连接sqlserver.插入数据.从数据库获取时间 复制代码 代码如下: using System;using System.Data.SqlClient; namespace Test{    //连接数据库    public class Connection    {        private static string connectionString =            "Server = 192.168.1.222;" +            "D

  • C#编程实现连接SQL SERVER数据库实例详解

    本文实例讲述了C#编程实现连接SQL SERVER数据库.分享给大家供大家参考,具体如下: 首先,在SQL SEVER里建立一个名为"Exercise"的数据库名,在该数据库下建立一张名为"lianxi"的表.好,现在开始写代码. 在FORM1里拖一个DATAGIRDVIEW用于显示表,在放一个BUTTON用于执行操作.加入命名空间 复制代码 代码如下: using system.data.sqlclient; private void button1_Click(

  • C#连接数据库和更新数据库的方法

    对数据库的操作总体可以分为两类:查询(select)和更新(insert,delete,update).为什么这样来分呢?仔细看看两类的区别,select只是从数据库中将数据拿出来使用,而其余三者都会对数据库的物理数据进行修改.这篇文章将接着阐述更新数据. 更新数据库信息首先是连接数据库,对数据库的更新需要一个对象:OleDbCommand.该对象表示要对数据源执行的SQL语句或存储过程. 这个对象有三个属性:1.CommandText表示要设置命令的文本:2.Connection表示要设置命令

  • C#使用checkedListBox1控件链接数据库的方法示例

    本文实例讲述了C#使用checkedListBox1控件链接数据库的方法.分享给大家供大家参考,具体如下: 在数据库中创建三个表: 学生信息表  爱好表   学生爱好表 结果让学生的信息和爱好同时显示到C#窗体上面 using System; using System.Collections; using System.Collections.Generic; using System.Data; using System.Diagnostics; using System.Data.Sql;

  • C#与SQL连接:GridView控件对数据库的操作

    GridView和DataGrid的异同 GridView 是 DataGrid的后继控件,在.net framework 2 中,虽然还存在DataGrid,但是GridView已经走上了历史的前台,取代DataGrid的趋势已是势不可挡.GridView和DataGrid功能相似,都是在web页面中显示数据源中的数据,将数据源中的一行数据,也就是一条记录,显示为在web页面上输出表格中的一行. GridView相对于DataGrid来说,具有如下优势,功能上更加丰富,因为提供了智能标记面板(

  • C#连接操作 MySQL 数据库实例(使用官方驱动)

    MySQL 以其免费和足够的性能受到很大的青睐,当然对于国内小公司,甚至是大公司如果对版权看得薄,敢冒险的话,随便装个 SqlServer.DB2.Oracle 都行.对于 SqlServer 数据库,因其与 MS 是一家,自然在 .net 类库中有内建支持,假如 MySQL 就得找第三方的驱动了 -- .net 中多讲 Provider.在这里我也是作为一个预研专题,记录下 C# 连接 MySQL 的两种方法,分别使用 MySQL 官方的和 SourceForge 上一个开源的 MySQL 驱

  • C#编程实现连接ACCESS数据库实例详解

    本文实例讲述了C#编程实现连接ACCESS数据库的方法.分享给大家供大家参考,具体如下: 一.建立FORM窗体,加一个按钮控件,加一个DATAGRIDVIEW控件. 二.双击FORM,加入命名空间 复制代码 代码如下: using System.Data.OleDb; 双击按钮,进入按钮代码,写如下代码 OleDbConnection strConnection = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source

随机推荐