随笔 - 24  文章 - 0  评论 - 2  阅读 - 69089

单例模式在创建数据库连接中的运用

什么是单例模式?

单例模式就是保证内存中只有一个对象。

 

为了实现单例,需要做以下操作:

1.将构造器设为私有private,为了防止通过new来创建对象;

2.在本类中定义一个本类的对象,并设为私有;

3.提供公共的访问方式(饿汉式);

复制代码
public class CreateDBHelper
{
    //私有,禁止通过new创建对象
    private CreateDBHelper()
    {
    }

    //创建本类的对象,并设为私有,禁止外部直接访问
    private static CreateDBHelper db = new CreateDBHelper();

    //提供公共的访问方式,返回对象
    public static CreateDBHelper getDBHelper()
    {
        return db;
    }

    //查询方法
    public DataTable GetDataTable(string sql)
    {
        using (SqlConnection connection = GetConnection())
        {
            SqlDataAdapter dap = new SqlDataAdapter(sql, connection);

            DataTable dt = new DataTable();
            dap.Fill(dt);
            dap.Dispose();
            return dt;
        }
    }

    public SqlConnection GetConnection()
    {
        return new SqlConnection(connectionString);
    }
}
复制代码

补充:

   1)静态方法返回的对象也必须为静态的,非静态方法可以返回静态对象,也可以返回非静态对象;

   2)静态方法属于类的成员,非静态方法属于类的实例成员;

   3)静态方法中调用非静态方法,通过类的实例来调用,

                          调用静态方法,通过类名.或者方法名;

        非静态方法中调用静态方法,通过类名.或者方法名来访问,

                             调用非静态方法,通过方法名即可。

         


调用数据库对象查询数据:
DataTable db = CreateDBHelper.getDBHelper().GetDataTable("select * from Member"); 

 

posted on   慢慢走~  阅读(356)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示