1.如下

using Oracle.ManagedDataAccess.Client;
using System;
using System.Collections.Generic;
using System.Data;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace DataMove
{
public class DBSupport :IDisposable
{
//public static string conncet = System.Configuration.ConfigurationManager.AppSettings["conn"].ToString(); string conn;
public DBSupport(string connect)
{
conn = connect;
if (mQracleConnecting == null)
mQracleConnecting = new OracleConnection(connect);
if (mQracleConnecting.State != ConnectionState.Open)
mQracleConnecting.Open();
} #region DB
OracleConnection mQracleConnecting = null;
public OracleConnection QracleConnecting
{
get
{
return mQracleConnecting;
}
} public DataTable DBGetDataTable(string sql)
{
try
{
DataTable dataSet = new DataTable();
OracleDataAdapter OraDA = new OracleDataAdapter(sql, mQracleConnecting);
OraDA.Fill(dataSet);
return dataSet;
}
catch (Exception)
{
FileSupport.Instance.Write("数据库连接异常" + conn);
return null;
} } // 执行SQL语句,返回所影响的行数
public int ExecuteSQL(string sql)
{
int Cmd = ;
OracleCommand command = new OracleCommand(sql, QracleConnecting);
try
{
Cmd = command.ExecuteNonQuery();
}
catch(Exception ex)
{
FileSupport.Instance.Write(ex.ToString());
}
return Cmd;
}
//public int ExecuteSQL_Update(string sql)
//{
// OracleDataAdapter OraDA = new OracleDataAdapter(sql, QracleConnecting);
// return OraDA.UpdateCommand.ExecuteNonQuery();
//}
//public int ExecuteSQL_Insert(string sql)
//{
// OracleDataAdapter OraDA = new OracleDataAdapter(sql, QracleConnecting);
// return OraDA.InsertCommand.ExecuteNonQuery();
//} public int ExecuteSQL_Insert(object item)
{
var type = item.GetType();
var tablename = type.Name;
var atts = type.GetProperties();
var keys="";
var values ="";
foreach(var a in atts)
{
var aname = a.Name;
var value = a.GetValue(item);
keys += aname+",";
values += GetValue2String(value) + ",";
} keys=keys.Trim(',');
values = values.Trim(','); var sql = "INSERT INTO "+tablename+" ( " + keys + " ) VALUES ( " + values +" )";
return ExecuteSQL(sql);
} #endregion /// <summary>
/// 获取对象列表
/// </summary>
/// <typeparam name="T">表所对应的对象名称</typeparam>
/// <param name="sql">查询语句</param>
/// <returns>返回获取到的对象实例列表</returns>
public List<T> QueryObjectList<T>(string sql) where T : new()
{
var dataset = ReturnDataSet(sql, "table");
if (dataset != null)
{
var table = dataset.Tables[];
return ConvertTableToObject<T>(table);
}
return null;
} public DataSet ReturnDataSet(string sql, string DataSetName)
{
DataSet dataSet = new DataSet();
OracleDataAdapter OraDA = new OracleDataAdapter(sql, QracleConnecting);
OraDA.Fill(dataSet, DataSetName);
return dataSet;
} public List<T> ConvertTableToObject<T>(DataTable t) where T : new()
{
if (t == null)
return null;
List<T> list = new List<T>();
foreach (DataRow row in t.Rows)
{
T obj = new T();
GetObject(t.Columns, row, obj);
if (obj != null && obj is T)
list.Add(obj);
}
return list;
} public T ConvertToObject<T>(DataRow row) where T : new()
{
object obj = new T();
if (row != null)
{
DataTable t = row.Table;
GetObject(t.Columns, row, obj);
}
if (obj != null && obj is T)
return (T)obj;
else
return default(T);
} void GetObject(DataColumnCollection cols, DataRow dr, Object obj)
{
Type t = obj.GetType();
var props = t.GetProperties();
foreach (var pro in props)
{
if (cols.Contains(pro.Name))
{
if (dr[pro.Name] != DBNull.Value)
{
try
{
switch (pro.PropertyType.Name)
{
case "Int32":
{
Int32 value = Convert.ToInt32(dr[pro.Name]);
pro.SetValue(obj, value, null);
}
break;
case "Double":
{
double value = Convert.ToDouble(dr[pro.Name]);
pro.SetValue(obj, value, null);
}
break;
case "Single":
{
float value = Convert.ToSingle(dr[pro.Name]);
pro.SetValue(obj, value, null);
}
break;
case "Int64":
{
Int64 value = Convert.ToInt64(dr[pro.Name]);
pro.SetValue(obj, value, null);
}
break;
case "Int16":
{
Int16 value = Convert.ToInt16(dr[pro.Name]);
pro.SetValue(obj, value, null);
}
break;
case "Decimal":
{
Decimal value = Convert.ToDecimal(dr[pro.Name]);
pro.SetValue(obj, value, null);
}
break;
default:
{
pro.SetValue(obj, dr[pro.Name], null);
}
break;
}
}
catch
{
pro.SetValue(obj, null, null);
}
finally
{
}
}
else
{
pro.SetValue(obj, null, null);
}
}
}
} string GetValue2String(Object obj)
{
if (obj == null)
return "null";
Type t = obj.GetType();
try
{
switch (t.Name)
{
case "String":
{
return "'"+ obj.ToString()+"'";
}
case "DateTime":
{
return "to_date('" + obj.ToString() + "','YYYY-MM-DD hh24:mi:ss')";
}
default:
{
return obj.ToString();
}
}
}
catch
{
return "";
}
} public void Dispose()
{
if(mQracleConnecting.State == ConnectionState.Open)
mQracleConnecting.Close();
}
}
}

最新文章

  1. 1---------java调用NLPIR(ICTCLAS2016)实现分词功能
  2. Html巩固
  3. Android消息处理机制
  4. 如何在redhat下安装WineQQ
  5. MapReduce自定义二次排序流程
  6. strcpy函数导致release版程序崩溃
  7. seajs进行模块化开发
  8. Java中线程的实现:
  9. truffle 安装以及基本指令
  10. SpringBoot(二)_项目属性配置
  11. java对象与Json字符串之间的转化(fastjson)
  12. 主流图库对比以及JanusGraph入门
  13. helm-chart7,调试与hook
  14. JS-函数声明 和 函数表达式
  15. Tomcat开启本地库(Apache Tomcat Native Library)支持
  16. 痞子衡嵌入式:备受开源社区推崇的分布式版本控制工具(Git)
  17. selenium-java,selenium安装配置
  18. 使用Ansible实现数据中心自动化运维管理
  19. VMWARE虚拟机不显示主机共享的文件夹解决办法
  20. java之堆和栈的比较

热门文章

  1. JS中require函数的警告提示
  2. 第十届蓝桥杯CB题目I-分析
  3. 在写论文的参考文献时,有的段落空格很大,有的段落则正常,原因及解决方法(wps)
  4. Elasticsearch集成IKAnalyzer分析器
  5. 拦截器——原理(AOP、责任链模式、配置)
  6. 【33】卷积步长讲解(Strided convolutions)
  7. jQuery Moblie 问题汇总
  8. CTF伪协议+preg_replace()函数的代码执行
  9. 如何实现 List 集合的线程安全
  10. spark之RDD练习