You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
304 lines
9.2 KiB
Plaintext
304 lines
9.2 KiB
Plaintext
11 months ago
|
using System;
|
||
|
using BP.Sys;
|
||
|
using BP.Difference;
|
||
|
|
||
|
namespace BP.DA
|
||
|
{
|
||
|
/// <summary>
|
||
|
/// 参数
|
||
|
/// </summary>
|
||
|
public class Para
|
||
|
{
|
||
|
#region 属性
|
||
|
public System.Data.DbType DAType = System.Data.DbType.String;
|
||
|
public Oracle.ManagedDataAccess.Client.OracleDbType DATypeOfOra
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
switch (this.DAType)
|
||
|
{
|
||
|
case System.Data.DbType.String:
|
||
|
case System.Data.DbType.Object:
|
||
|
if (this.ItIsBigText)
|
||
|
return Oracle.ManagedDataAccess.Client.OracleDbType.Clob;
|
||
|
else
|
||
|
return Oracle.ManagedDataAccess.Client.OracleDbType.Varchar2;
|
||
|
case System.Data.DbType.Int32:
|
||
|
case System.Data.DbType.Int16:
|
||
|
return Oracle.ManagedDataAccess.Client.OracleDbType.Int16;
|
||
|
case System.Data.DbType.Int64:
|
||
|
return Oracle.ManagedDataAccess.Client.OracleDbType.Int64;
|
||
|
case System.Data.DbType.Decimal:
|
||
|
case System.Data.DbType.Double:
|
||
|
return Oracle.ManagedDataAccess.Client.OracleDbType.Double;
|
||
|
default:
|
||
|
throw new Exception("没有涉及到的类型。typeof(obj)=" + this.DAType.ToString());
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
public string ParaName = null;
|
||
|
public int Size = 10;
|
||
|
public Object val;
|
||
|
/// <summary>
|
||
|
/// 是否是大文本?
|
||
|
/// </summary>
|
||
|
public bool ItIsBigText = false;
|
||
|
#endregion
|
||
|
|
||
|
/// <summary>
|
||
|
/// 参数
|
||
|
/// </summary>
|
||
|
public Para()
|
||
|
{
|
||
|
|
||
|
}
|
||
|
|
||
|
}
|
||
|
/// <summary>
|
||
|
/// 参数集合
|
||
|
/// </summary>
|
||
|
public class Paras : System.Collections.CollectionBase
|
||
|
{
|
||
|
|
||
|
/// <summary>
|
||
|
/// 要执行的SQL
|
||
|
/// </summary>
|
||
|
public string SQL = null;
|
||
|
/// <summary>
|
||
|
/// 获得SQL没有参数的
|
||
|
/// </summary>
|
||
|
public string SQLNoPara
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
string mysql = this.SQL.Clone() as string;
|
||
|
foreach (Para p in this)
|
||
|
{
|
||
|
if (p.DAType == System.Data.DbType.String)
|
||
|
{
|
||
|
if (mysql.Contains(BP.Difference.SystemConfig.AppCenterDBVarStr + p.ParaName + ","))
|
||
|
mysql = mysql.Replace(BP.Difference.SystemConfig.AppCenterDBVarStr + p.ParaName + ",", "'" + p.val.ToString() + "',");
|
||
|
else
|
||
|
mysql = mysql.Replace(BP.Difference.SystemConfig.AppCenterDBVarStr + p.ParaName, "'" + p.val.ToString() + "'");
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
if (mysql.Contains(BP.Difference.SystemConfig.AppCenterDBVarStr + p.ParaName + ","))
|
||
|
mysql = mysql.Replace(BP.Difference.SystemConfig.AppCenterDBVarStr + p.ParaName + ",", p.val.ToString() + ",");
|
||
|
else
|
||
|
mysql = mysql.Replace(BP.Difference.SystemConfig.AppCenterDBVarStr + p.ParaName, p.val.ToString());
|
||
|
}
|
||
|
}
|
||
|
return mysql;
|
||
|
}
|
||
|
}
|
||
|
/// <summary>
|
||
|
/// 构造参数
|
||
|
/// </summary>
|
||
|
public Paras()
|
||
|
{
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// 数据库连接标记
|
||
|
/// </summary>
|
||
|
public string DBStr
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
return BP.Difference.SystemConfig.AppCenterDBVarStr;
|
||
|
}
|
||
|
}
|
||
|
/// <summary>
|
||
|
/// 增加参数
|
||
|
/// </summary>
|
||
|
/// <param name="para"></param>
|
||
|
public void Add(Para para)
|
||
|
{
|
||
|
foreach (Para p in this)
|
||
|
{
|
||
|
if (p.ParaName == para.ParaName)
|
||
|
{
|
||
|
p.val = para.val;
|
||
|
return;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
this.InnerList.Add(para);
|
||
|
}
|
||
|
/// <summary>
|
||
|
/// 增加参数
|
||
|
/// </summary>
|
||
|
/// <param name="obj"></param>
|
||
|
public void Add(object obj)
|
||
|
{
|
||
|
this.Add("p", obj);
|
||
|
}
|
||
|
/// <summary>
|
||
|
/// 增加参数
|
||
|
/// </summary>
|
||
|
/// <param name="_name">参数名</param>
|
||
|
/// <param name="obj">参数值</param>
|
||
|
public void Add(string _name, object obj)
|
||
|
{
|
||
|
if (_name == "abc")
|
||
|
return;
|
||
|
|
||
|
if (obj == null)
|
||
|
throw new Exception("@参数:" + _name + " 值无效.");
|
||
|
|
||
|
foreach (Para p in this)
|
||
|
{
|
||
|
if (p.ParaName == _name)
|
||
|
{
|
||
|
p.val = obj;
|
||
|
return;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if (obj.GetType() == typeof(string))
|
||
|
{
|
||
|
this.Add(_name, obj.ToString());
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
if (obj.GetType() == typeof(int)
|
||
|
|| obj.GetType() == typeof(Int32)
|
||
|
|| obj.GetType() == typeof(Int16))
|
||
|
{
|
||
|
this.Add(_name, Int32.Parse(obj.ToString()));
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
if (obj.GetType() == typeof(Int64))
|
||
|
{
|
||
|
this.Add(_name, Int64.Parse(obj.ToString()));
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
if (obj.GetType() == typeof(float))
|
||
|
{
|
||
|
this.Add(_name, float.Parse(obj.ToString()));
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
if (obj.GetType() == typeof(decimal))
|
||
|
{
|
||
|
this.Add(_name, decimal.Parse(obj.ToString()));
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
if (obj.GetType() == typeof(double))
|
||
|
{
|
||
|
this.Add(_name, double.Parse(obj.ToString()));
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
if (obj == DBNull.Value)
|
||
|
this.AddDBNull(_name);
|
||
|
else
|
||
|
throw new Exception("@没有判断的参数类型:" + _name);
|
||
|
}
|
||
|
/// <summary>
|
||
|
/// 是否是大块文本?
|
||
|
/// </summary>
|
||
|
/// <param name="_name">名称</param>
|
||
|
/// <param name="_val">值</param>
|
||
|
/// <param name="isBigTxt">是否是大文本?</param>
|
||
|
public void Add(string _name, string _val, bool isBigTxt = false)
|
||
|
{
|
||
|
Para en = new Para();
|
||
|
|
||
|
en.DAType = System.Data.DbType.String;
|
||
|
en.val = _val;
|
||
|
en.ParaName = _name;
|
||
|
if (DataType.IsNullOrEmpty(_val) == true)
|
||
|
en.Size = 0;
|
||
|
else
|
||
|
en.Size = _val.Length;
|
||
|
en.ItIsBigText = isBigTxt; //是否是大块文本.
|
||
|
this.Add(en);
|
||
|
}
|
||
|
/// <summary>
|
||
|
/// 增加参数
|
||
|
/// </summary>
|
||
|
/// <param name="_name">参数名</param>
|
||
|
/// <param name="_val">值</param>
|
||
|
public void Add(string _name, Int32 _val)
|
||
|
{
|
||
|
Para en = new Para();
|
||
|
en.DAType = System.Data.DbType.Int32;
|
||
|
en.val = _val;
|
||
|
en.ParaName = _name;
|
||
|
this.Add(en);
|
||
|
}
|
||
|
/// <summary>
|
||
|
/// 增加参数
|
||
|
/// </summary>
|
||
|
/// <param name="_name">参数名</param>
|
||
|
/// <param name="_val">值</param>
|
||
|
public void Add(string _name, Int64 _val)
|
||
|
{
|
||
|
Para en = new Para();
|
||
|
en.DAType = System.Data.DbType.Int64;
|
||
|
en.val = _val;
|
||
|
en.ParaName = _name;
|
||
|
this.Add(en);
|
||
|
}
|
||
|
/// <summary>
|
||
|
/// 增加参数
|
||
|
/// </summary>
|
||
|
/// <param name="_name">参数名</param>
|
||
|
/// <param name="_val">值</param>
|
||
|
public void Add(string _name, float _val)
|
||
|
{
|
||
|
Para en = new Para();
|
||
|
en.DAType = System.Data.DbType.Decimal;
|
||
|
// en.DAType = System.Data.DbType.Int64;
|
||
|
en.val = _val;
|
||
|
en.ParaName = _name;
|
||
|
this.Add(en);
|
||
|
}
|
||
|
/// <summary>
|
||
|
/// 增加参数
|
||
|
/// </summary>
|
||
|
/// <param name="_name">参数名</param>
|
||
|
/// <param name="_val">值</param>
|
||
|
public void AddDBNull(string _name)
|
||
|
{
|
||
|
Para en = new Para();
|
||
|
en.DAType = System.Data.DbType.Object;
|
||
|
en.val = DBNull.Value;
|
||
|
en.ParaName = _name;
|
||
|
this.Add(en);
|
||
|
}
|
||
|
/// <summary>
|
||
|
/// 增加参数
|
||
|
/// </summary>
|
||
|
/// <param name="_name">参数名</param>
|
||
|
/// <param name="_val">值</param>
|
||
|
public void Add(string _name, decimal _val)
|
||
|
{
|
||
|
Para en = new Para();
|
||
|
en.DAType = System.Data.DbType.Decimal;
|
||
|
en.val = _val;
|
||
|
en.ParaName = _name;
|
||
|
this.Add(en);
|
||
|
}
|
||
|
/// <summary>
|
||
|
/// 增加参数
|
||
|
/// </summary>
|
||
|
/// <param name="_name">参数名</param>
|
||
|
/// <param name="_val">值</param>
|
||
|
public void Add(string _name, double _val)
|
||
|
{
|
||
|
Para en = new Para();
|
||
|
en.DAType = System.Data.DbType.Decimal;
|
||
|
en.val = _val;
|
||
|
en.ParaName = _name;
|
||
|
this.Add(en);
|
||
|
}
|
||
|
|
||
|
}
|
||
|
}
|