123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299 |
- using System;
- using System.Data;
- using System.Collections.Generic;
- using System.Configuration;
- using System.Text;
- using System.IO;
- using Oracle.ManagedDataAccess.Client;
- using System.Reflection;
- using System.Linq;
- namespace Oracle11
- {
- /// <summary>
- /// Oracle数据库操作类
- /// </summary>
- static class OracleHelper
- {
- public static void TestConnection(string connectionString)
- {
- using (OracleConnection con = new OracleConnection(connectionString))
- {
- con.Open();
- }
- }
- /// <summary>
- /// 执行数据库非查询操作,返回受影响的行数
- /// </summary>
- /// <param name="connectionString">数据库连接字符串</param>
- /// <param name="cmdType">命令的类型</param>
- /// <param name="sql">注意sql包含左斜杠会被拆分成多条语句执行</param>
- /// <param name="cmdParms">命令参数集合</param>
- /// <returns>当前操作影响的数据行数</returns>
- public static int ExecuteNonQuery(string connectionString, string sql, params OracleParameter[] cmdParms)
- {
- var lines = sql.Split("/".ToCharArray(), StringSplitOptions.RemoveEmptyEntries).ToList();
- OracleCommand cmd = new OracleCommand();
- int val = 0;
- using (OracleConnection conn = new OracleConnection(connectionString))
- {
- foreach (var line in lines)
- {
- PrepareCommand(cmd, conn, null, CommandType.Text, line, cmdParms);
- val = cmd.ExecuteNonQuery();
- cmd.Parameters.Clear();
- }
- }
- return val;
- }
- public static void BatchInsert(OracleConnection conn, OracleTransaction trans,string sql, params OracleParameter[] cmdParms)
- {
- var cmd = conn.CreateCommand();
- PrepareCommand(cmd, conn, trans, CommandType.Text, sql, cmdParms);
- cmd.ExecuteNonQuery();
- cmd.Parameters.Clear();
- }
- /// <summary>
- /// 执行数据库查询操作,返回DataTable类型的结果集
- /// </summary>
- /// <param name="connectionString">数据库连接字符串</param>
- /// <param name="cmdText">Oracle存储过程名称或PL/SQL命令</param>
- /// <param name="cmdParms">命令参数集合</param>
- /// <returns>当前查询操作返回的DataTable类型的结果集</returns>
- public static DataTable ExecuteDataTable(string connectionString, string cmdText, params OracleParameter[] cmdParms)
- {
- OracleCommand cmd = new OracleCommand();
- OracleConnection conn = new OracleConnection(connectionString);
- DataTable dt = null;
- try
- {
- PrepareCommand(cmd, conn, null, CommandType.Text, cmdText, cmdParms);
- OracleDataAdapter adapter = new OracleDataAdapter();
- adapter.SelectCommand = cmd;
- dt = new DataTable();
- adapter.Fill(dt);
- cmd.Parameters.Clear();
- }
- catch
- {
- throw;
- }
- finally
- {
- cmd.Dispose();
- conn.Close();
- conn.Dispose();
- }
- return dt;
- }
- /// <summary>
- /// 将DataTable转换为泛型List
- /// </summary>
- /// <typeparam name="T"></typeparam>
- /// <param name="dt"></param>
- /// <returns></returns>
- public static List<T> TableToListClass<T>(this DataTable dt) where T : new()
- {
- List<T> ts = new List<T>();
- Type type = typeof(T);
- string tempName = "";
- foreach (DataRow dr in dt.Rows)
- {
- T t = new T();
- // 获得此模型的公共属性
- PropertyInfo[] propertys = t.GetType().GetProperties();
- foreach (PropertyInfo pi in propertys)
- {
- tempName = pi.Name; // 检查DataTable是否包含此列
- if (dt.Columns.Contains(tempName))
- {
- // 判断此属性是否有Setter
- if (!pi.CanWrite) continue;
- object value = dr[tempName];
- if (value != DBNull.Value)
- pi.SetValue(t, value, null);
- }
- }
- ts.Add(t);
- }
- return ts;
- }
- /// <summary>
- /// 将DataTable转换为List,泛型类型为string、int、double等基础类型
- /// </summary>
- /// <typeparam name="T"></typeparam>
- /// <param name="dt"></param>
- /// <returns></returns>
- public static List<T> TableToListBcl<T>(this DataTable dt)
- {
- List<T> ts = new List<T>();
- foreach (DataRow dr in dt.Rows)
- {
- var valObj = dr[0];
- var val = (T)Convert.ChangeType(valObj, typeof(T));
- ts.Add(val);
- }
- return ts;
- }
- /// <summary>
- /// 将两列的DataTable转换为字典,key为第一列的值,value为第二列的值
- /// </summary>
- /// <param name="dt"></param>
- /// <returns></returns>
- public static Dictionary<string, string> TableToDictionary(this DataTable dt)
- {
- Dictionary<string, string> dic = new Dictionary<string, string>();
- foreach (DataRow dr in dt.Rows)
- {
- string key = dr[0].ToString();
- string value = dr[1].ToString();
- dic.Add(key, value);
- }
- return dic;
- }
- /// <summary>
- /// 执行数据库查询操作,返回结果集中位于第一行第一列的Object类型的值
- /// </summary>
- /// <param name="connectionString">数据库连接字符串</param>
- /// <param name="cmdType">命令的类型</param>
- /// <param name="cmdText">Oracle存储过程名称或PL/SQL命令</param>
- /// <param name="cmdParms">命令参数集合</param>
- /// <returns>当前查询操作返回的结果集中位于第一行第一列的Object类型的值</returns>
- public static object ExecuteScalar(string connectionString, string cmdText, params OracleParameter[] cmdParms)
- {
- OracleCommand cmd = new OracleCommand();
- OracleConnection conn = new OracleConnection(connectionString);
- object result = null;
- try
- {
- PrepareCommand(cmd, conn, null, CommandType.Text, cmdText, cmdParms);
- result = cmd.ExecuteScalar();
- cmd.Parameters.Clear();
- }
- catch (Exception ex)
- {
- throw;
- }
- finally
- {
- cmd.Dispose();
- conn.Close();
- conn.Dispose();
- }
- return result;
- }
- /// <summary>
- /// 执行数据库命令前的准备工作
- /// </summary>
- /// <param name="cmd">Command对象</param>
- /// <param name="conn">数据库连接对象</param>
- /// <param name="trans">事务对象</param>
- /// <param name="cmdType">Command类型</param>
- /// <param name="cmdText">Oracle存储过程名称或PL/SQL命令</param>
- /// <param name="cmdParms">命令参数集合</param>
- private static void PrepareCommand(OracleCommand cmd, OracleConnection conn, OracleTransaction trans, CommandType cmdType, string cmdText, OracleParameter[] cmdParms)
- {
- if (conn.State != ConnectionState.Open)
- conn.Open();
- cmd.Connection = conn;
- cmd.CommandText = cmdText;
- if (trans != null)
- cmd.Transaction = trans;
- cmd.CommandType = cmdType;
- if (cmdParms != null)
- {
- foreach (OracleParameter parm in cmdParms)
- cmd.Parameters.Add(parm);
- }
- }
- /// <summary>
- /// 将.NET日期时间类型转化为Oracle兼容的日期时间格式字符串
- /// </summary>
- /// <param name="date">.NET日期时间类型对象</param>
- /// <returns>Oracle兼容的日期时间格式字符串(如该字符串:TO_DATE('2007-12-1','YYYY-MM-DD'))</returns>
- public static string GetOracleDateFormat(DateTime date)
- {
- return "TO_DATE('" + date.ToString("yyyy-M-dd") + "','YYYY-MM-DD')";
- }
- /// <summary>
- /// 将.NET日期时间类型转化为Oracle兼容的日期格式字符串
- /// </summary>
- /// <param name="date">.NET日期时间类型对象</param>
- /// <param name="format">Oracle日期时间类型格式化限定符</param>
- /// <returns>Oracle兼容的日期时间格式字符串(如该字符串:TO_DATE('2007-12-1','YYYY-MM-DD'))</returns>
- public static string GetOracleDateFormat(DateTime date, string format)
- {
- if (format == null || format.Trim() == "") format = "YYYY-MM-DD";
- return "TO_DATE('" + date.ToString("yyyy-M-dd") + "','" + format + "')";
- }
- /// <summary>
- /// 将指定的关键字处理为模糊查询时的合法参数值
- /// </summary>
- /// <param name="source">待处理的查询关键字</param>
- /// <returns>过滤后的查询关键字</returns>
- public static string HandleLikeKey(string source)
- {
- if (source == null || source.Trim() == "") return null;
- source = source.Replace("[", "[]]");
- source = source.Replace("_", "[_]");
- source = source.Replace("%", "[%]");
- return ("%" + source + "%");
- }
- /// <summary>
- /// 执行存储过程
- /// </summary>
- /// <param name="connection">SqlServer数据库连接对象</param>
- /// <param name="storedProcName">存储过程名</param>
- /// <param name="parameters">存储过程参数</param>
- /// <returns>SqlDataReader对象</returns>
- public static OracleDataReader RunStoredProcedure(OracleConnection connection, string storedProcName, IDataParameter[] parameters)
- {
- OracleDataReader returnReader = null;
- connection.Open();
- OracleCommand command = BuildSqlCommand(connection, storedProcName, parameters);
- returnReader = command.ExecuteReader(CommandBehavior.CloseConnection);
- return returnReader;
- }
- /// <summary>
- /// 构建SqlCommand对象
- /// </summary>
- /// <param name="connection">数据库连接</param>
- /// <param name="storedProcName">存储过程名</param>
- /// <param name="parameters">存储过程参数</param>
- /// <returns>SqlCommand</returns>
- private static OracleCommand BuildSqlCommand(OracleConnection connection, string storedProcName, IDataParameter[] parameters)
- {
- OracleCommand command = new OracleCommand(storedProcName, connection);
- command.CommandType = CommandType.StoredProcedure;
- foreach (OracleParameter parameter in parameters)
- {
- command.Parameters.Add(parameter);
- }
- return command;
- }
- }
- }
|