Csharp/C#教程:C#使用SqlConnection连接到SQL Server的代码示例分享

使用SqlConnection连接到SQLServer2012

示例如下:

(1).利用SqlConnection创建连接

publicSQLServerAPI(stringstr_ip,stringstr_db,stringstr_user,stringstr_pwd) { m_strIp=str_ip; m_strDb=str_db; m_strUser=str_user; m_strPwd=str_pwd; //SQLServer身份验证 m_strConnection=@"DataSource="+m_strIp; m_strConnection+=@";InitialCatalog="+m_strDb; m_strConnection+=@";UID="+m_strUser+";PWD="+m_strPwd; m_strConnection+=";ConnectionTimeout=10;Pooling=true;MaxPoolSize=100"; //Windows身份验证 //m_strConnection= @"server=localhostSQLEXPRESS;database=SQL2012Db;Trusted_Connection=SSPI;"; DisConnect(); m_Transaction=null; m_SqlConnection=newSqlConnection(m_strConnection); }

(2).调用Open方法,以建立与服务器的会话。

///<summary> ///尝试连接数据库 ///</summary> privateboolConnect() { if(m_SqlConnection==null) returnfalse; try { m_SqlConnection.Open(); } catch(Exceptione) { Debug.WriteLine(e.Message); returnfalse; } returntrue; }

(3).调用Close()方法终止会话

privateboolDisConnect() { if(m_SqlConnection==null) returntrue; try { m_SqlConnection.Close(); } catch(Exceptione) { Debug.WriteLine(e.Message); returnfalse; } returntrue;

许多程序员都使连接一直处于打开状态,直到程序结束为止,这通常会浪费服务器资源。与这种打开一次,永不关闭的方式相比,使用连接池,在需要时打开和关闭连接要更加高效。

如下所示,我们封装一个执行SQL存储过程的函数:

///<summary> ///执行返回查询结果的存储过程 ///</summary> ///<paramname="procname">存储过程名?</param> ///<paramname="param">参数。函数正常返回时,所有类型为out的参数值也在对应位置上</param> ///<paramname="result">返回查询的结果</param> ///<returns>0正确,其他错误</returns> publicintExecQueryStoreProc(stringprocname,refSqlParameter[]param,outDataTableresult) { if(!Connect()) { result=null; return-1; } try { SqlCommandcommand=newSqlCommand(procname,m_SqlConnection); command.CommandType=CommandType.StoredProcedure; if(m_Transaction!=null) command.Transaction=m_Transaction; SqlParameterrvalue=command.Parameters.Add(newSqlParameter("RETURN_VALUE",SqlDbType.Int)); rvalue.Direction=ParameterDirection.ReturnValue; if(param!=null) command.Parameters.AddRange(param); result=newDataTable(); SqlDataReaderreader=command.ExecuteReader(); if(reader.HasRows) result.Load(reader); returnConvert.ToInt32(command.Parameters["RETURN_VALUE"].Value); } catch(Exception) { result=null; return-1; } finally { DisConnect(); } }

上述过程就是在需要时打开和关闭连接的实现方式,另外finally块始终调用Close()方法,这并不会造成问题或者过多地浪费资源,而且能确保关闭连接。

上述就是C#学习教程:C#使用SqlConnection连接到SQL Server的代码示例分享的全部内容,如果对大家有所用处且需要了解更多关于C#学习教程,希望大家多多关注—计算机技术网(www.ctvol.com)!

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/cdevelopment/908383.html

(0)
上一篇 2021年10月25日
下一篇 2021年10月25日

精彩推荐