ADO.net 工具类

    public class sqlHelper
    {
        public static readonly object locker = new object();
        private static sqlHelper instance = null;
        private OleDbConnection conn = new OleDbConnection(@"Provider=SQLOLEDB;Data Source=172.11.11.11;Initial Catalog=aaa;Password=aaa;Persist Security Info=True;User ID=sa");
        private sqlHelper()
        {
        }

        public static sqlHelper getInstance()
        {
            lock (locker)
            {
                if (instance == null)
                {
                    instance = new sqlHelper();
                    instance.conn.Open();
                }
                else if (instance.conn.State != ConnectionState.Open)
                {
                    instance.conn.Open();
                }
                return instance;
            }
        }

        public string QuerySingle(string sql)
        {
            string single = null;
            using (OleDbCommand command = new OleDbCommand(sql, conn))
            {
                object obj = command.ExecuteScalar();
                if (obj != null)
                {
                    single = command.ExecuteScalar().ToString();
                }
            }
            return single;
        }

        public DataTable Query(string sql)
        {
            DataTable table = null;
            using (OleDbCommand command = new OleDbCommand(sql, conn))
            {
                using (OleDbDataAdapter adapter = new OleDbDataAdapter(command))
                {
                    DataSet data = new DataSet();
                    adapter.Fill(data);
                    table = data.Tables[0];
                }
            }
            return table;
        }

        public int Execute(string sql)
        {
            int result = 0;
            using (OleDbCommand command = new OleDbCommand(sql, conn))
            {
                result = command.ExecuteNonQuery();
            }
            return result;
        }

        /// <summary>
        /// 传参防sql注入
        /// </summary>
        /// <param name="sql"></param>
        /// <param name="args"></param>
        /// <returns></returns>
        public DataTable Query(string sql, params object[] args)
        {
            DataTable table = null;
            using (OleDbCommand command = new OleDbCommand(sql, conn))
            {

                foreach (var arg in args)
                {
                    if (arg == null)
                        command.Parameters.AddWithValue("?", DBNull.Value);
                    else
                        command.Parameters.AddWithValue("?", arg);
                }

                using (OleDbDataAdapter adapter = new OleDbDataAdapter(command))
                {
                    DataSet data = new DataSet();
                    adapter.Fill(data);
                    table = data.Tables[0];
                }
            }
            return table;
        }
    }

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值