首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >单例模式代码实现

单例模式代码实现
EN

Stack Overflow用户
提问于 2014-06-16 06:13:31
回答 1查看 257关注 0票数 0

我编写了下面的代码来连接到我的数据库。你们能给我建议比这更好的选择吗,因为我非常感兴趣的是哪种方式的表现更好。下面的代码是否实现了Singleton模式?

代码语言:javascript
复制
    public static class DbConnect
    {

        public static DataTable SqlConnection(string query)
        {
            DataTable dt = null;

            using (SqlConnection cn = new SqlConnection(ConfigurationManager.ConnectionStrings["ConString"].ConnectionString))
            {
                using (SqlCommand cmd = new SqlCommand())
                {
                    using (SqlDataAdapter da = new SqlDataAdapter(cmd))
                    {
                        if (cn.State == ConnectionState.Closed)
                        {
                            dt = new DataTable();
                            cn.Open();
                            da.Fill(dt);
                        }
                    }
                    return dt;
                }
            }
        }

    }
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-06-16 06:34:11

国际水文学组织预期:

  1. 添加参数支持
  2. 不要隐藏错误:如果连接中断,您应该有一个异常

所以代码看起来可能是这样的:

代码语言:javascript
复制
      // I've used KeyValuePair for parameters; probably a specialized class will be better 
      public static DataTable SqlConnection(string query, params KeyValuePair<String, Object>[] parameters) {
        using (SqlConnection cn = new SqlConnection(ConfigurationManager.ConnectionStrings["ConString"].ConnectionString)) {
          using (SqlCommand cmd = cn.CreateCommand()) {
            cmd.CommandText = query;

            // Parameters, if they're mentioned 
            if (!Object.ReferenceEquals(null, parameters))
              foreach (var prm in parameters)
                cmd.Parameters.AddWithValue(prm.Key, prm.Value);

            using (SqlDataAdapter da = new SqlDataAdapter(cmd)) {
              cn.Open();

              DataTable result = new DataTable();

              da.Fill(result);

              return result;
            }
          }
        }
      }

..。

代码语言:javascript
复制
DataTable dt1 = SqlConnection("select 123");
DataTable dt2 = SqlConnection(
                   @"select * 
                      from MyTable 
                     where MyField = @MyParam", 
                   new KeyValuePair<String, Object>("@MyParam", 123));

代码不是Singleton实现,它甚至不是一个类:只是一个静态方法。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24237568

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档