zoukankan      html  css  js  c++  java
  • ADO.net 增删改查封装DBhelper

    using System;
    using System.Collections.Generic;
    using System.Data.SqlClient;//引用数据库客户端
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    using System.Reflection;
    using System.Data;
    namespace PubilcHelper
    {
        public class DBHelper
        {
            //连接数据库
            static SqlConnection conn = new SqlConnection("连接字符串“); 
            static SqlDataReader sdr;
            /// <summary>
            /// 获取数据流  查询、显示、绑定下拉
            /// </summary>
            /// <param name="sql"></param>
            /// <returns></returns>
            private static SqlDataReader GetDataReader(string sql)
            {
                try
                {
                    //打开
                    if (conn.State == ConnectionState.Closed)
                    {
                        conn.Open();
                    }
                    //命令对象
                    SqlCommand cmd = new SqlCommand(sql, conn);
                     sdr = cmd.ExecuteReader();
                    return sdr;
                }
                catch (Exception)
                {
    
                    if (!sdr.IsClosed)//数据流关闭
                    {
                        sdr.Close();
                    }
                    throw;
                }
    
            }
            /// <summary>
            /// 返回受影响行数  
            /// 添加、删除、修改
            /// </summary>
            /// <param name="sql"></param>
            /// <returns></returns>
            public static int ExecuteNonQuery(string sql)
            {
                try
                {
                    //打开
                    //判断状态
                    if (conn.State == ConnectionState.Closed)
                    {
                        conn.Open();
                    }
    
                    //命令对象
                    SqlCommand cmd = new SqlCommand(sql, conn);
                    int n = cmd.ExecuteNonQuery();
                    if (conn.State == ConnectionState.Open)
                    {
                        conn.Close();
                    }
                    return n;
                }
                catch (Exception)
                {
                   
                    throw;
                }
            }
            /// <summary>
            /// 数据流转List
            /// </summary>
            /// <typeparam name="T"></typeparam>
            /// <param name="sdr"></param>
            /// <returns></returns>
            private static List<T> DataReaderToList<T>(SqlDataReader sdr) {
                Type t = typeof(T);//获取类型
                //获取所有属性
                PropertyInfo[] p = t.GetProperties();
                //定义集合
                List<T> list = new List<T>();
                //遍历数据流
                while (sdr.Read()) {
                    //创建对象
                    T obj = (T)Activator.CreateInstance(t);
                    //数据流列数
                    string[] sdrFileName = new string[sdr.FieldCount];
                    for (int i = 0; i < sdr.FieldCount; i++)
                    {
                        sdrFileName[i] = sdr.GetName(i).Trim();
                    }
                    foreach (PropertyInfo item in p)
                    {
                        //判断Model中的属性是否在流的列名中
                        if (sdrFileName.ToList().IndexOf(item.Name) > -1)
                        {
                            if (sdr[item.Name] != null && sdr[item.Name]!=DBNull.Value)
                            {
                                item.SetValue(obj, sdr[item.Name]);//对象属性赋值
                            }
                            else
                            {
                                item.SetValue(obj, null);//对象属性赋值
                            }
                        }
                        else {
                            item.SetValue(obj, null);//对象属性赋值
                        }
                       
                    }
                    list.Add(obj);
                }
                return list;
            }
            /// <summary>
            /// 获取list集合
            /// </summary>
            /// <typeparam name="T"></typeparam>
            /// <returns></returns>
            public static List<T> GetToList<T>(string sql) {
                //获取流数据
                SqlDataReader sdr = GetDataReader(sql);
                List<T> list = DataReaderToList<T>(sdr);
                if (!sdr.IsClosed)//数据流关闭
                {
                    sdr.Close();
                }
                return list;
            }
            /// <summary>
            /// 返回首行首列
            /// </summary>
            /// <param name="sql"></param>
            /// <returns></returns>
            public static object ExecuteScalar(string sql)
            {
                try
                {
                    //打开
                    //判断状态
                    if (conn.State == ConnectionState.Closed)
                    {
                        conn.Open();
                    }
    
                    //命令对象
                    SqlCommand cmd = new SqlCommand(sql, conn);
                    object n = cmd.ExecuteScalar();
                    if (conn.State == ConnectionState.Open)
                    {
                        conn.Close();
                    }
                    return n;
                }
                catch (Exception)
                {
    
                    throw;
                }
            }
    
        }
    }
  • 相关阅读:
    百度地图点击地图显示地址详情的默认方法怎么关闭,去掉百度地图api图标信息
    两个inline-block中间有空白,解决inline-block 元素之间的空白问题
    视频直播 object 标签属性详解
    2018.10.26 酷狗音乐校招前端一面经历(转)
    JS心得——判断一个对象是否为空
    echarts在tab切换时容器宽度设置为100%,只展示100px
    js生成[n,m]的随机数,js如何生成随机数,javascript随机数Math.random()
    vue2.0 日历日程表 ,可进行二次开发.
    浏览器兼容性问题解决方案 · 总结
    详解前端响应式布局、响应式图片,与自制栅格系统
  • 原文地址:https://www.cnblogs.com/ly-03-04/p/12088093.html
Copyright © 2011-2022 走看看