首页 > 数据库技术 > 详细

SQL Procedure Operations

时间:2015-08-07 12:43:08      阅读:339      评论:0      收藏:0      [点我收藏+]

This Class is used to handle SQL procedures, including Verify SP exist or not, Create SP into DB and Execute SP via C#.

using System;
using System.Data.SqlClient;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;

namespace SqlBIS.Auto.Framework
{
    public class SqlHelper
    {
        public string ConnString { get; set; }
        public SqlConnection Connection { get; set; }

        public SqlHelper(string connString)
        {
            this.ConnString = connString;
            Connection = new SqlConnection(connString);
        }

        /// <summary>
        /// Verify if DB contain procedure or not
        /// </summary>
        /// <param name="proName">procedure name</param>
        /// <returns></returns>
        public  bool ProcedureIsExist(string proName)
        {
            bool result = false;
            String sqlComm = String.Format("IF OBJECT_ID(‘{0}‘) IS NOT NULL SELECT ‘true‘ ELSE SELECT ‘false‘", proName);
            
            SqlCommand cmd = new SqlCommand(sqlComm, this.Connection);
            cmd.CommandType = CommandType.Text;
            this.Connection.Open();
            result = Convert.ToBoolean((cmd.ExecuteScalar()).ToString());
            this.Connection.Close();

            return result;
        }

        /// <summary>
        /// Create a new procedure
        /// </summary>
        /// <param name="proName"></param>
        /// <param name="proCommand"></param>
        public  void CreateProcedure(string proName, string proCommand)
        {
            SqlCommand cmd = new SqlCommand(proCommand, this.Connection);
            Connection.Open();
            cmd.CommandType = CommandType.Text;
            cmd.ExecuteNonQuery();
            Connection.Close();
        }

        /// <summary>
        /// Execute procedure and return DataTable
        /// </summary>
        /// <param name="proName"></param>
        /// <param name="parameters"></param>
        /// <returns></returns>
        public DataTable ExecuteProcedure(string proName, SqlParameter[] parameters)
        {
            DataTable dt = new DataTable();

            SqlCommand cmd = new SqlCommand(proName, this.Connection);
            cmd.CommandType = System.Data.CommandType.StoredProcedure;
            foreach (var item in parameters)
                cmd.Parameters.Add(item);
            SqlDataAdapter sa = new SqlDataAdapter(cmd);
            sa.Fill(dt);

            return dt;
        }
    }
}

SQL Procedure Operations

原文:http://www.cnblogs.com/Blackeye286/p/4710150.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!