.NET餐厅管理系统sql数据帮助类执行SQL返回DataTable数据集、使用事务执行多条SQL(插入、更新、删除)

 #region  //执行SQL返回DataTable数据集
    /// <summary>
    /// 执行SQL返回DataTable数据集
    /// </summary>
    /// <param name="sql_"></param>
    /// <returns></returns>
    public DataTable GetDataTable(string sql_)
    {
        if (sql_ == "")
            return null;
        DataTable dt = null;
        DataSet ds = null;
        try
        {
            OpenDb();
            SqlDataAdapter myad = new SqlDataAdapter(sql_, conn);
            ds = new DataSet();
            myad.Fill(ds);//用数据适配器填充数据集
            myad.Dispose();
            myad = null;
            CloseDb();

            if (ds.Tables.Count <= 0)
                return null;
            dt = ds.Tables[0];
        }
        catch (Exception e)
        {
            throw new Exception(e.ToString() + "  " + sql_);
        }
        return dt;
    }
    #endregion

    #region //使用事务执行多条SQL(插入、更新、删除)
    /// <summary>
    /// 使用事务执行多条SQL(插入、更新、删除)
    /// </summary>
    /// <param name="sqls"></param>
    public bool ExecTansaction(List<string> sqls)
    {
        if (sqls.Count == 0) return false;

        OpenDb();

        // 启动一个事务。 
        SqlTransaction myTran = conn.BeginTransaction();
        // 为事务创建一个命令
        SqlCommand myCom = new SqlCommand();
        myCom.Connection = conn;
        myCom.Transaction = myTran;
        try
        {
            foreach (string sql in sqls)
            {
                myCom.CommandText = sql;
                myCom.ExecuteNonQuery();
            }
            myTran.Commit();//提交事务
            return true;
        }
        catch (Exception Ex)
        {
            myTran.Rollback();

            //返回异常的错误信息 
            //MessageBox.Show("提交数据失败!\n" + ex.Message.ToString(), "异常信息", MessageBoxButtons.OK, MessageBoxIcon.Warning);
            throw new Exception("提交数据失败!\n" + Ex.Message.ToString());
            return false;
        }
        finally
        {
            conn.Close();
        }
    }
    #endregion
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

m0_74456535

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值