Go Premium for a chance to win a PS4. Enter to Win

x
?
Solved

Connection to SQL Server 2005

Posted on 2006-11-16
8
Medium Priority
?
291 Views
Last Modified: 2010-04-16
Hi experts,

I have a C# windows form application and I connect to SQL server 2005 using two methods:
1)
SqlCommand cmd = new SqlCommand("select ...", sqlConnectionObject);
2)
SqlDataAdapter mDA = new SqlDataAdapter(("select ...", "Data Source...");
mDA.Fill(someDataTable);

A process is created in SQL server after the first method is called. I have used a single object to limit
the connection. Now, when I called the second method, a new process is created. As a result, there
are two processes for each application in the SQL server!

For SqlDataAdapter, I understand that C# will open a connection if it is not connected,
and closed automatically after use.
C# will remain connect if there is already an opened connection after use.

Question:
How can I limit my application to have only one connection in the SQL server?

regards
0
Comment
Question by:novknow
  • 5
  • 3
8 Comments
 
LVL 29

Expert Comment

by:Gautham Janardhan
ID: 17955162
always use one connection object
0
 
LVL 29

Expert Comment

by:Gautham Janardhan
ID: 17955180
u have to write a data acess layer which the whole application will use thru out
0
 
LVL 29

Expert Comment

by:Gautham Janardhan
ID: 17955209
public frmMain()
            {
                  InitializeComponent();
                  AppStartUp.ConnectFromConfigFile();
                  
      
            }


public class AppStartUp
      {
            public static void ConnectFromConfigFile()
            {
                  SQLDBProvider.DataAccess.Connect(" DATA SOURCE="
                        + SC.ConfigurationSettings.AppSettings["SERVER"] + ";"
                        + " PERSIST SECURITY INFO=TRUE;"
                        + " UID=" + SC.ConfigurationSettings.AppSettings["USERNAME"] + ";"
                        + " PWD=" + SC.ConfigurationSettings.AppSettings["PASSWORD"] + ";"
                        + " DATABASE=" + SC.ConfigurationSettings.AppSettings["DATABASE"]);
                                    
                  
                                    
            }
      }
0
Independent Software Vendors: We Want Your Opinion

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 

Author Comment

by:novknow
ID: 17955267
Am I doing the correct thing? :

// my class
public sealed class SingleCon
{
    public readonly static string mString = "Data Source.........";

    private static readonly SqlConnection mSQLConn = new SqlConnection(mString);

    public static void Disconnect()
    {
        if (mSQLConn.State != ConnectionState.Closed)
            mSQLConn.Close();
    }

    public static SqlConnection SQLConnection
    {
        get
        {
            try
            {
                if (mSQLConn.State != ConnectionState.Open)
                    mSQLConn.Open();
            }
            catch (SqlException ex)
            {
                // ...
            }

            return mSQLConn;
        }
    }
}

// Connection code #1 :
SqlCommand cmd = new SqlCommand("select...", SingleCon.SQLConnection);

// Connection code #2 :
SqlDataAdapter mDA = new SqlDataAdapter("select...", SingleCon.mString);

Hi gauthampj, appreciate if you could provide example on your second point.

regards
0
 

Author Comment

by:novknow
ID: 17955620
Hi gauthampj,

What is SQLDBProvider?
How do I connect to SQL server with  SqlDataAdapter and SQLDBProvider?

regards
0
 
LVL 29

Accepted Solution

by:
Gautham Janardhan earned 2000 total points
ID: 17955789
u r on the rt way
this is another ex


public frmMain()
          {
               InitializeComponent();
               AppStartUp.ConnectFromConfigFile();
               
     
          }


public class AppStartUp
     {
          public static void ConnectFromConfigFile()
          {
               CDataBase.Handle.OpenConnection(" DATA SOURCE="
                    + SC.ConfigurationSettings.AppSettings["SERVER"] + ";"
                    + " PERSIST SECURITY INFO=TRUE;"
                    + " UID=" + SC.ConfigurationSettings.AppSettings["USERNAME"] + ";"
                    + " PWD=" + SC.ConfigurationSettings.AppSettings["PASSWORD"] + ";"
                    + " DATABASE=" + SC.ConfigurationSettings.AppSettings["DATABASE"]);
                             
               
                             
          }
     }
      /// <summary>
      /// Summary description for Class1.
      /// </summary>
      public class CDataBase
      {
                                static CDataBase FObject
            OleDbConnection objCon;
            OleDbCommand objCmd;
            OleDbDataAdapter objAd;
            string strConnectionString;
            string strError;
                                public static CDataBase Handle
                                {
                                         get
                                         {
                                         if(FObject == null)
                                                FObject = new CDataBase();
                                                return FObject ;
                                        }
                                }


            private CDataBase()
            {
                  objCon = new OleDbConnection();
                  objCmd = new OleDbCommand();
                  objAd = new OleDbDataAdapter();
                  strError = "";
                  strConnectionString = "";
            }
            public bool OpenConnection(string ConnectionString)
            {
                  bool flag;
                  try
                  {
                        objCon.ConnectionString = strConnectionString;
                        objCon.Open();
                        objCmd.Connection = objCon;
                        flag = true;
                  }
                  catch(Exception e)
                  {
                        strError = e.ToString();
                        flag = false;
                  }
                  return flag;
            }
            public bool OpenConnection(string ConnectionString)
            {
                  strConnectionString = ConnectionString;
                  return this.OpenConnection();
            }
            public bool CloseConnection()
            {
                  bool flag;
                  try
                  {
                        objCon.Close();
                        flag = true;
                  }
                  catch(Exception e)
                  {
                        strError = e.ToString();
                        flag = false;
                  }
                  return flag;
            }
            public bool ProcessNonSelectQuery(string Query)
            {
                  bool flag;
                  try
                  {
                        objCmd.CommandText = Query;
                        objCmd.ExecuteNonQuery();
                        flag = true;
                  }
                  catch(Exception e)
                  {
                        strError = e.ToString();
                        flag = false;
                  }
                  return flag;
            }
            public DataTable ProcessSelectQuery(string Query)
            {
                  DataSet ds = new DataSet();
                  DataTable dt = null;
                  try
                  {
                        objCmd.CommandText = Query;
                        objAd.SelectCommand = objCmd;      
                        objAd.Fill(ds);
                        dt = ds.Tables[0];
                  }
                  catch(Exception e)
                  {
                        strError = e.ToString();
                        dt = null;
                  }
                  return dt;
            }
            public string Error
            {
                  get
                  {
                        return strError;
                  }
            }
      }
0
 

Author Comment

by:novknow
ID: 17974248
Hi gauthampj,

Thanks for providing the example.
While exploring your example, could you point to me what's wrong with my code (why is it creating an additional process in the SQL server)?

regards
0
 
LVL 29

Expert Comment

by:Gautham Janardhan
ID: 17977946
1)
SqlCommand cmd = new SqlCommand("select ...", sqlConnectionObject);
2)
SqlDataAdapter mDA = new SqlDataAdapter(("select ...", "Data Source...");--- here new connetion will be  made b'coz u r not asking the adaptor to use the connection u have already created....

using my code u could call the adpators overload


SqlDataAdapter mDA = new SqlDataAdapter("Comman',Connection)

or the command s overload


SQLCommand mDA = new SQLCommand ("Comman',Connection)

connection would be CDataBase.Handle.Connection in my case
0

Featured Post

Free Tool: Site Down Detector

Helpful to verify reports of your own downtime, or to double check a downed website you are trying to access.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

We all know that functional code is the leg that any good program stands on when it comes right down to it, however, if your program lacks a good user interface your product may not have the appeal needed to keep your customers happy. This issue can…
Introduction Hi all and welcome to my first article on Experts Exchange. A while ago, someone asked me if i could do some tutorials on object oriented programming. I decided to do them on C#. Now you may ask me, why's that? Well, one of the re…
Is your data getting by on basic protection measures? In today’s climate of debilitating malware and ransomware—like WannaCry—that may not be enough. You need to establish more than basics, like a recovery plan that protects both data and endpoints.…
Look below the covers at a subform control , and the form that is inside it. Explore properties and see how easy it is to aggregate, get statistics, and synchronize results for your data. A Microsoft Access subform is used to show relevant calcul…

824 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question