Asp.NetDBクラス

23999 ワード

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();
            }
        }
    

    }
}