码迷,mamicode.com
首页 > 数据库 > 详细

Asp.net DB类

时间:2015-10-19 17:29:08      阅读:299      评论:0      收藏:0      [点我收藏+]

标签:

using System;
using System.Collections.Generic;
using System.Text;
using System.Data;
using System.Data.OleDb;
using System.Web;
using System.Collections;
using System.Configuration;
using System.Drawing;
using System.IO;
using System.Data.SqlClient;

namespace DBTool
{
    public class DB
    {

        public static OleDbConnection conn = null;
        public static string GetConnStringOut()
        {
            string s = System.Configuration.ConfigurationManager.ConnectionStrings["smconn"].ConnectionString.ToString();
            return s;
        }
        public static string connectionString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
        public string GetConnString()
        {
            string s = System.Configuration.ConfigurationManager.ConnectionStrings["smconn"].ConnectionString.ToString();
            return s;
        }
        /// <summary>
        /// 打开数据库连接
        /// </summary>
        public void OpenConn()
        {
            try
            {
                //if (conn == null)
                //{
                    conn = new OleDbConnection();
                    conn.ConnectionString = this.GetConnString();
               // }
                //if (conn != null && conn.State == ConnectionState.Closed)
                    conn.Open();
            }
            catch
            {
            }
        }
        /// <summary>
        /// 关闭数据库连接
        /// </summary>
        public void CloseConn()
        {
            if (conn != null && conn.State == ConnectionState.Open)
                conn.Close();
            conn.Dispose();
        }
        /// <summary>
        /// 执行查询返回DataTable
        /// </summary>
        /// <param name="sql">要执行查询的sql语句</param>
        /// <returns>DataTable</returns>
        public DataTable RunSqlGetDataTable(string sql)
        {

            using (SqlConnection connection = new SqlConnection(connectionString))
            {
                DataSet ds = new DataSet();
                try
                {
                    connection.Open();
                    SqlDataAdapter command = new SqlDataAdapter(sql, connection);
                    command.Fill(ds, "ds");
                }
                catch (System.Data.SqlClient.SqlException ex)
                {
                    throw new Exception(ex.Message);
                }
                return ds.Tables[0];
            }
        }
        /// <summary>
        /// 执行非查询返回影响行数
        /// </summary>
        /// <param name="sql">要执行非查询的sql语句</param>
        /// <returns> int </returns>
        public int RunSqlGetRowCount(string sql)
        {
            OpenConn();
            OleDbCommand cmd = new OleDbCommand(sql, conn);
            int rowcount = -1;
            try
            {
                rowcount = cmd.ExecuteNonQuery();
            }
            catch (OleDbException ex)
            {
                string sTmp = ex.Message.ToLower();
                if (sTmp.IndexOf("重复键") >= 0)
                {
                    //MessageBox.Show("不允许重复!");
                }
                else if (sTmp.IndexOf("reference") >= 0)
                {
                    //MessageBox.Show("数据已经被使用!");
                }
                else
                {
                    rowcount = -3;//主要是为了在系统重建的时候使用
                }
            }
            catch { }

            CloseConn();
            return rowcount;
        }


        /// <summary>
        /// Execute a SqlCommand that returns a resultset against the database specified in the connection string 
        /// using the provided parameters.
        /// </summary>
        /// <param name="connectionString">一个有效的数据库连接字符串</param>
        /// <param name="cmdType">SqlCommand命令类型 (存储过程, T-SQL语句, 等等。)</param>
        /// <param name="cmdText">存储过程的名字或者 T-SQL 语句</param>
        /// <param name="commandParameters">以数组形式提供SqlCommand命令中用到的参数列表</param>
        /// <returns>A SqlDataReader containing the results</returns>
        public static SqlDataReader ExecuteReader(CommandType cmdType, string cmdText, params SqlParameter[] commandParameters)
        {
            SqlCommand cmd = new SqlCommand();
            SqlConnection conn = new SqlConnection(connectionString);
            try
            {
                PrepareCommand(cmd, conn, null, cmdType, cmdText, commandParameters);
                SqlDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnection);
                cmd.Parameters.Clear();
                return rdr;
            }
            catch (Exception ex)
            {
                conn.Close();
                throw new Exception(ex.Message);
            }
        }
        private static void PrepareCommand(SqlCommand cmd, SqlConnection conn, SqlTransaction trans, CommandType cmdType, string cmdText, SqlParameter[] cmdParms)
        {
            //判断数据库连接状态
            if (conn.State != ConnectionState.Open)
                conn.Open();
            cmd.Connection = conn;
            cmd.CommandText = cmdText;
            //判断是否需要事物处理
            if (trans != null)
                cmd.Transaction = trans;
            cmd.CommandType = cmdType;
            if (cmdParms != null)
            {
                foreach (SqlParameter parm in cmdParms)
                    cmd.Parameters.Add(parm);
            }
        }

        /// <summary>
        /// 执行非查询返回影响行数
        /// </summary>
        /// <param name="sql">要执行非查询的sql语句  返回id</param>
        /// <returns> int </returns>
        public int RunSqlGetRowCountReturnId(string sql)
        {
            OpenConn();
            OleDbCommand cmd = new OleDbCommand(sql, conn);
            object rowcount = "0";
            try
            {
                rowcount = cmd.ExecuteScalar();
            }
            catch (OleDbException ex)
            {
                string sTmp = ex.Message.ToLower();
                if (sTmp.IndexOf("重复键") >= 0)
                {  //MessageBox.Show("不允许重复!"); 
                }
                else if (sTmp.IndexOf("reference") >= 0)
                { //MessageBox.Show("数据已经被使用!");
                }
                else
                {
                    rowcount = -3;//主要是为了在系统重建的时候使用
                }
            }
            catch { }
            CloseConn();
            return int.Parse(rowcount.ToString());
        }

        /// <summary>
        /// 返回查询结果集中第一行第一列
        /// </summary>
        /// <param name="sql">查询语句</param>
        /// <returns>object</returns>
        /// 
        public object RunSqlGetObject(string sql)
        {
            OpenConn();
            OleDbCommand cmd = new OleDbCommand(sql, conn);

            object o = cmd.ExecuteScalar();
            CloseConn();
            return o;
        }


        ///
        /// <summary>
        /// 获得一个具有事务功能的数据库连接对象
        /// </summary>
        /// <param name="tconn"></param>
        /// <param name="transaction"></param>
        public void OpenTransConn(ref OleDbConnection tconn, ref OleDbTransaction transaction)
        {

            try
            {
                if (tconn == null)
                {
                    tconn = new OleDbConnection();
                    tconn.ConnectionString = this.GetConnString();
                }
                if (tconn != null && tconn.State == ConnectionState.Closed)
                {
                    tconn.Open();
                    transaction = tconn.BeginTransaction();
                }
            }
            catch
            {
            }
        }
        /// <summary>
        /// 关闭事务数据库连接
        /// </summary>
        public void CloseTransConn(ref OleDbConnection tconn, ref OleDbTransaction transaction)
        {
            if (transaction != null)
            {
                transaction.Commit();//提交事务
            }
            if (tconn != null && tconn.State == ConnectionState.Open)
                tconn.Close();
        }

        public bool RunTransSqlGetBool(ref OleDbConnection tconn, ref OleDbTransaction transaction, string sql)
        {
            OleDbCommand cmd = new OleDbCommand();
            cmd.Connection = tconn;
            cmd.CommandText = sql;
            cmd.Transaction = transaction;
            int rowcount = -1;
            try
            {
                rowcount = cmd.ExecuteNonQuery();
            }
            catch (OleDbException ex)
            {
                if (ex.ErrorCode == -2147217873)
                {
                    //MessageBox.Show("不能添加重复的值!");
                }
                else
                {
                    //MessageBox.Show("不能添加重复的值!");
                }
                transaction.Rollback();
                return false;
            }
            catch { }
            if (rowcount > 0)
                return true;
            return false;
        }
        //通过事务完成增加一系列记录
        public bool RunTransSqls(ArrayList sqlAl)
        {
            int rowcount = -1;

            OleDbConnection conn = new OleDbConnection();
            conn.ConnectionString = this.GetConnString();
            OleDbTransaction tran = null;
            OleDbCommand cmd = null;

            #region MyRegion
            try
            {
                conn.Open();
                tran = conn.BeginTransaction();
                cmd = new OleDbCommand();
                cmd.Connection = conn;
                cmd.Transaction = tran;
                cmd.CommandType = CommandType.Text;

                foreach (string sql in sqlAl)
                {
                    //MessageBox.Show(sql);
                    rowcount = -1;
                    cmd.CommandText = sql;
                    rowcount = cmd.ExecuteNonQuery();

                    if (rowcount <= 0)//有些时候是没有数据的,也算成功
                    {
                        //tran.Rollback();
                        //return false;
                    }
                }
                tran.Commit();
                return true;
            }
            catch (Exception ex)
            {
                tran.Rollback();
                //MessageBox.Show(ex.Message);
            }
            finally
            {
                try
                {
                    if (conn != null && conn.State == ConnectionState.Open)
                        conn.Close();
                    if (conn != null)
                        conn.Dispose();
                }
                catch { }
            }
            #endregion

            return false;
        }

        //通过存储过程  添加删除和修改
        public int RunProcGetReturnValue(string procName, ArrayList al)
        {
            int re = 0;
            //数据库连接
            OpenConn();
            try
            {
                //定义命令对象
                #region
                OleDbCommand cmd = new OleDbCommand();
                cmd.Connection = conn;//关联数据库连接对象
                cmd.CommandText = procName;//设置存储过程名称
                cmd.CommandType = CommandType.StoredProcedure;//命令类型
                #endregion
                cmd.Parameters.Clear();
                //设置返回参数return ,
                //注意:返回参数必须写在参数列表的第一个位置
                OleDbParameter paramReturn = new OleDbParameter("returnvalue", OleDbType.VarChar, 50);
                paramReturn.Direction = ParameterDirection.ReturnValue;//参数传递方向;默认传入
                paramReturn.Value = -1;//返回值   
                cmd.Parameters.Add(paramReturn);//增加返回参数到命令对象cmd
                foreach (OleDbParameter p in al)
                {
                    cmd.Parameters.Add(p);
                }
                cmd.ExecuteNonQuery();

                re = Convert.ToInt32(paramReturn.Value);
            }
            catch { }
            finally
            {
                CloseConn();
            }
            return re;
        }

        public int RunProcGetOutputValue(string procName, ArrayList al)
        {
            //数据库连接
            OpenConn();
            //定义命令对象
            #region
            OleDbCommand cmd = new OleDbCommand();
            cmd.Connection = conn;//关联数据库连接对象
            cmd.CommandText = procName;//设置存储过程名称
            cmd.CommandType = CommandType.StoredProcedure;//命令类型
            #endregion
            cmd.Parameters.Clear();
            foreach (OleDbParameter p in al)
            {
                cmd.Parameters.Add(p);
            }
            try
            {
                return cmd.ExecuteNonQuery(); ;
            }
            catch
            {
                return 0;
            }
            finally
            {
                CloseConn();
            }
        }
        //通过存储过程 查询(不带参数的查询)
        public DataSet RunProcGetDataTable(string procName)
        {
            //数据库连接
            OpenConn();
            //定义命令对象
            #region
            ArrayList al = new ArrayList();
            OleDbCommand cmd = new OleDbCommand();
            cmd.Connection = conn;//关联数据库连接对象
            cmd.CommandText = procName;//设置存储过程名称
            cmd.CommandType = CommandType.StoredProcedure;//命令类型
            #endregion
            cmd.Parameters.Clear();

            foreach (OleDbParameter p in al)
            {
                cmd.Parameters.Add(p);
            }
            try
            {
                DataSet ds = new DataSet();
                OleDbDataAdapter da = new OleDbDataAdapter();
                da.SelectCommand = cmd;
                da.Fill(ds);
                return ds;
            }
            catch
            {
                return null;
            }
            finally
            {
                CloseConn();
            }
        }

        // 通过存储过程查询数据(带参数的)
        public DataTable RunSqlGetDataTableFY(string name, int id)
        {
            OpenConn();
            OleDbDataAdapter da = null;
            DataTable dt = null;
            OleDbCommand cmd = new OleDbCommand();
            cmd.Connection = conn;
            cmd.CommandText = name; ;
            cmd.CommandType = CommandType.StoredProcedure;

            OleDbParameter p2 = new OleDbParameter("@Id", OleDbType.Integer, 4);
            p2.Value = id;
            cmd.Parameters.Add(p2);
            try
            {
                da = new OleDbDataAdapter();
                da.SelectCommand = cmd;
                dt = new DataTable();
                da.Fill(dt);
            }
            catch { }
            CloseConn();
            return dt;
        }
        public static OleDbConnection Getconn()
        {
            try
            {

                if (conn != null && conn.State == ConnectionState.Closed)
                    conn.Open();
            }
            catch
            {
            }
            return conn;
        }
        /// <summary>
        /// 导出报表文件为csv格式
        /// </summary>
        public static bool DataDownTOcsv(string sql, string filename, string tableheader1, string tableheader2, string columname, int columcount)
        {
            try
            {
                string strFileToOrg = "", strBufferLine = "", strBufferLine1 = "";
                int i;
                strFileToOrg = HttpContext.Current.Server.MapPath("~/pdf/" + filename + ".csv");
                StreamWriter strmWriterObj = new StreamWriter(strFileToOrg, false, System.Text.Encoding.Default);//声明写入流对象            
                //OleDbConnection OleDbConnection1=new OleDbConnection();
                OleDbConnection OleDbConnection1 = DB.Getconn();
                //OleDbConnection1.ConnectionString="File Name="+HttpContext.Current.Server.MapPath("conn.udl");
                //OleDbConnection1.Open();
                OleDbCommand cmdGenFile = new OleDbCommand();
                cmdGenFile.Connection = OleDbConnection1;
                cmdGenFile.CommandText = sql;
                OleDbDataReader drGenFile = cmdGenFile.ExecuteReader();
                strmWriterObj.WriteLine(tableheader1);
                strmWriterObj.WriteLine(tableheader2);
                strmWriterObj.WriteLine(columname);
                while (drGenFile.Read())
                {
                    strBufferLine = "";
                    strBufferLine1 = Convert.ToString(drGenFile.GetValue(0));
                    strBufferLine = strBufferLine1;
                    for (i = 1; i <= (columcount - 1); i++)
                    {
                        strBufferLine1 = "";
                        strBufferLine1 = Convert.ToString(drGenFile.GetValue(i));
                        strBufferLine = strBufferLine + "," + strBufferLine1;
                    }
                    strmWriterObj.WriteLine(strBufferLine);
                }
                strmWriterObj.Close();
                drGenFile.Close();
                return true;
            }
            catch
            {
                return false;
            }
        }


        /// <summary>
        /// 生成缩略图
        /// </summary>
        /// <param name="originalImagePath">源图路径(物理路径)</param>
        /// <param name="thumbnailPath">缩略图路径(物理路径)</param>
        /// <param name="width">缩略图宽度</param>
        /// <param name="height">缩略图高度</param>
        /// <param name="mode">生成缩略图的方式</param>    
        public bool MakeThumbnail(string originalImagePath, string thumbnailPath, int width, int height, string mode)
        {
            System.Drawing.Image originalImage = System.Drawing.Image.FromFile(originalImagePath);
            int towidth = width;
            int toheight = height;
            int x = 0;
            int y = 0;
            int ow = originalImage.Width;
            int oh = originalImage.Height;
            switch (mode)
            {
                case "HW"://指定高宽缩放(可能变形)                
                    break;
                case "W"://指定宽,高按比例                    
                    toheight = originalImage.Height * width / originalImage.Width;
                    break;
                case "H"://指定高,宽按比例
                    towidth = originalImage.Width * height / originalImage.Height;
                    break;
                case "Cut"://指定高宽裁减(不变形)                
                    if ((double)originalImage.Width / (double)originalImage.Height > (double)towidth / (double)toheight)
                    {
                        oh = originalImage.Height;
                        ow = originalImage.Height * towidth / toheight;
                        y = 0;
                        x = (originalImage.Width - ow) / 2;
                    }
                    else
                    {
                        ow = originalImage.Width;
                        oh = originalImage.Width * height / towidth;
                        x = 0;
                        y = (originalImage.Height - oh) / 2;
                    }
                    break;
                default:
                    break;
            }

            //新建一个bmp图片
            System.Drawing.Image bitmap = new System.Drawing.Bitmap(towidth, toheight);
            //新建一个画板
            System.Drawing.Graphics g = System.Drawing.Graphics.FromImage(bitmap);
            //设置高质量插值法
            g.InterpolationMode = System.Drawing.Drawing2D.InterpolationMode.High;
            //设置高质量,低速度呈现平滑程度
            g.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.HighQuality;
            //清空画布并以透明背景色填充
            g.Clear(System.Drawing.Color.Transparent);
            //在指定位置并且按指定大小绘制原图片的指定部分
            g.DrawImage(originalImage, new System.Drawing.Rectangle(0, 0, towidth, toheight),
                new System.Drawing.Rectangle(x, y, ow, oh),
                System.Drawing.GraphicsUnit.Pixel);
            try
            {
                //以jpg格式保存缩略图
                bitmap.Save(thumbnailPath, System.Drawing.Imaging.ImageFormat.Jpeg);
                return true;
            }
            catch (System.Exception e)
            {
                throw e;
                return false;
            }
            finally
            {
                originalImage.Dispose();
                bitmap.Dispose();
                g.Dispose();
            }
        }
    

    }
}

  

Asp.net DB类

标签:

原文地址:http://www.cnblogs.com/jingyong001/p/4892223.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!