LOGO OA教程 ERP教程 模切知识交流 PMS教程 CRM教程 开发文档 其他文档  
 
网站管理员

C#操作ORACL数据库调用ORACL存储过程

admin
2025年7月11日 14:41 本文热度 64

一、执行存储过程

        /// <summary>        /// 执行存储过程        /// </summary>        /// <param name="SQLString"></param>        /// <returns></returns>        public static Boolean SqlProcedure(string SQLString)        {            using (OracleConnection connection = new OracleConnection(connectionString))            {                try                {                    connection.Open();                    OracleCommand command = new OracleCommand(SQLString, connection);                    int recordCount = command.ExecuteNonQuery();
                    return true;                }                catch (Exception ex)                {                    LogHelper.WriteErrorLog("SQL:" + SQLString, ex);                    Global.strMessage = ex.Message.ToString();                    return false;                    throw new Exception(ex.Message);                }                finally                {                    connection.Close();                }            }        }

二、一次执行多个存储过程,带事务回滚

/// <summary>        /// 执行存储过程        /// </summary>        /// <param name="SQLArrayList"></param>        /// <returns></returns>        public static Boolean SqlProcedure(ArrayList SQLArrayList)        {            using (OracleConnection connection = new OracleConnection(connectionString))            {                connection.Open();                OracleTransaction transaction = connection.BeginTransaction();
                try                {                    for (int i = 0; i < SQLArrayList.Count; i++)                    {                        string SQLString = SQLArrayList[i].ToString();                        OracleCommand command = new OracleCommand(SQLString, connection);                        command.ExecuteNonQuery();                    }                    transaction.Commit();                    return true;                }                catch (Exception ex)                {                    transaction.Rollback();                    Common.Global.strMessage = ex.Message.ToString();                    return false;                    throw new Exception(ex.Message);                }                finally                {                    connection.Close();                }            }        }

三、执行XmlType类型返回值的存储过程

        /// <summary>        /// 执行带返回值的存储过程        /// </summary>        /// <param name="CunChuName"></param>        /// <param name="parm"></param>        /// <returns></returns>        public static string RunProcedures(string CunChuName, OracleParameter[] parm)        {            string strOut = "";            OracleCommand cmd = new OracleCommand();            using (OracleConnection conn = new OracleConnection(connectionString))            {                try                {                    cmd.CommandType = CommandType.StoredProcedure;                    cmd.CommandText = CunChuName;                    for (int i = 0; i < parm.Length; i++)                    {                        cmd.Parameters.Add(parm[i]);                    }                    if (conn.State != ConnectionState.Open)                        conn.Open();
                    cmd.Connection = conn;                    cmd.ExecuteNonQuery();
                    //返回参数                    strOut = ((Oracle.ManagedDataAccess.Types.OracleXmlType)cmd.Parameters["Xml_Out"].Value).Value;
                    return strOut;                }                catch (Exception ex)                {                    Common.Global.strMessage = ex.Message.ToString();                    LogHelper.WriteErrorLog("CunChuName:" + CunChuName, ex);                    return strOut;                }                finally                {                    if (conn.State == ConnectionState.Open)                        conn.Close();                    conn.Dispose();                    cmd.Parameters.Clear();                    cmd.Dispose();                }            }
        }


该文章在 2025/7/11 14:41:22 编辑过
关键字查询
相关文章
正在查询...
点晴ERP是一款针对中小制造业的专业生产管理软件系统,系统成熟度和易用性得到了国内大量中小企业的青睐。
点晴PMS码头管理系统主要针对港口码头集装箱与散货日常运作、调度、堆场、车队、财务费用、相关报表等业务管理,结合码头的业务特点,围绕调度、堆场作业而开发的。集技术的先进性、管理的有效性于一体,是物流码头及其他港口类企业的高效ERP管理信息系统。
点晴WMS仓储管理系统提供了货物产品管理,销售管理,采购管理,仓储管理,仓库管理,保质期管理,货位管理,库位管理,生产管理,WMS管理系统,标签打印,条形码,二维码管理,批号管理软件。
点晴免费OA是一款软件和通用服务都免费,不限功能、不限时间、不限用户的免费OA协同办公管理系统。
Copyright 2010-2025 ClickSun All Rights Reserved