.net 调用Oracle.Data.Access 组件提供的用于批量操作的方法—获取数据库表结构方法和跟参数赋值方法
1、/// <summary>
/// 获取当前目标表结构
/// </summary>
/// <param name="tableName">目标表</param>
/// <returns></returns>
public static DataTable GetOracleTableSchema(string tableName)
{ BS.EAP.DBAccess.IDataBase oDB = BS.EAP.DBAccess.DBFactory.GetDBInstance();
string sql = string.Format(@" select t.COLUMN_NAME as name, t.DATA_LENGTH as ColLength,t.DATA_TYPE as Typeid, t.DATA_SCALE as Scale,decode(nvl(tp.column_name, ''),'',0,1) as isPrimary, '{0}' as tableName, '{0}' as viewName, 0 as viewField, (case t.NULLABLE when 'Y' then 1 else 0 end) as isNullable, tp.column_name from USER_TAB_COLS t left join (select col.table_name, col.column_name from user_constraints con, user_cons_columns col where con.constraint_name = col.constraint_name and con.constraint_type='P' ) tp on tp.table_name = t.TABLE_NAME and tp.column_name = t.column_name where t.HIDDEN_COLUMN ='NO' and t.TABLE_NAME = '{0}'", tableName.ToUpper());
return oDB.GetDataTable(sql);
}
2、/// <summary>
/// 生成批量插入Sql语句
/// </summary>
/// <param name="DestinationTableName">目标表</param>
/// <param name="table">数据源</param>
/// <param name="cmd">操作命令</param>
/// <param name="DicInitData">初始数据</param>
/// <returns></returns>
public static string GenerateInserSql(string DestinationTableName, DataTable table, string strDsid)
{
BS.EAP.DBAccess.IDataBase oDB = DBFactory.GetDBInstance();
DataTable dt = new DataTable();
string column_name = string.Empty;
string param = string.Empty;
//查询表机构字段
dt = oDB.GetDataTable(@"select column_name EnKey from
user_tab_columns where lower(table_name)= '" + DestinationTableName.ToLower() + "' order by COLUMN_ID");
for (int i = 0; i < dt.Rows.Count; i++)
{
column_name += dt.Rows[i][0].ToString() + ",";
param += ":" + dt.Rows[i][0].ToString() + ",";
}
column_name = column_name.Substring(0, column_name.Length - 1);
param = param.Substring(0, param.Length - 1);
return string.Format("insert into " + DestinationTableName + "(" + column_name + ") values(" + param + ")");
}
3、/// <summary>
/// 构造参数
/// </summary>
/// <param name="DestDataTable"></param>
/// <param name="table"></param>
/// <param name="cmd"></param>
public static void GenerateParameter(DataTable DestDataTable, DataTable table, OracleCommand cmd, string Dsid, string TableName, DataTable dbwell)
{
string strTypID = string.Empty;
string strColumName = string.Empty;
string IsRep = string.Empty;
int colCount = table.Columns.Count;
for (int i = 0; i < colCount; i++)
{
strColumName = table.Columns[i].ColumnName;
OracleParameter parameter = new OracleParameter();
parameter.ParameterName = strColumName;
parameter.Direction = ParameterDirection.Input;
int iScale = 0;
strTypID = GetColumnType(strColumName, DestDataTable, out iScale);
DbType oDbType = GetDataFieldType(strTypID, iScale);
parameter.DbType = oDbType;
parameter.Value = GetObjectArray(table, strColumName, oDbType, dbwell);
cmd.Parameters.Add(parameter);
}
}
4、GetColumnType方法
/// <summary>
/// 获取字段类型 /// </summary>
/// <param name="columnName">字段名称</param>
/// <param name="dt">数据表</param>
/// <returns></returns>
public static string GetColumnType(string columnName, DataTable dt, out int iScale)
{
string strType = string.Empty;
iScale = 0;
for (int iRow = 0; iRow < dt.Rows.Count; iRow++)
{
string strColName = dt.Rows[iRow]["Name"].ToString();
if (strColName.ToUpper() == columnName.ToUpper())
{
strType = dt.Rows[iRow]["TypeID"].ToString();
if (dt.Rows[iRow]["SCALE"].ToString() == "" || dt.Rows[iRow]["SCALE"].ToString() == "0")
iScale = 0;
else
iScale = Convert.ToInt32(dt.Rows[iRow]["SCALE"].ToString());
break;
}
}
return strType;
}
5、// <summary>
/// 获取字段类型
/// </summary>
/// <param name="strType">字段类型</param>
/// <param name="iScale">小数位数</param>
/// <returns></returns>
public static DbType GetDataFieldType(string strType, int iScale)
{
DbType oDbType = DbType.String;
switch (strType.ToUpper())
{
case "VARCHAR2":
oDbType = DbType.String;
break;
case "DATE":
oDbType = DbType.DateTime;
break;
case "NVARCHAR2":
oDbType = DbType.String;
break;
case "NUMBER":
if (iScale == 0)
oDbType = DbType.Int32;
else
oDbType = DbType.Decimal;
break;
case "FLOAT":
oDbType = DbType.Decimal;
break;
case "LONG":
oDbType = DbType.Decimal;
break;
case "BINARY_FLOAT":
oDbType = DbType.Decimal;
break;
case "BINARY_DOUBLE":
oDbType = DbType.Decimal;
break;
default:
break;
}
return oDbType;
}
6、/// <summary>
/// 构造值数组,供赋值使用
/// </summary>
/// <param name="dt">数据源表</param>
/// <param name="colname">列名</param>
/// <returns></returns>
public static object[] GetObjectArray(DataTable dt, string colname, DbType oDbType, DataTable dbwell)
{
object[] objArray = new object[dt.Rows.Count];
int iCol = 0;
for (int i = 0; i < dt.Columns.Count; i++)
{
if (dt.Columns[i].ColumnName == colname)
{
iCol = i;
break;
}
}
for (int j = 0; j < dt.Rows.Count; j++)
{
if (string.IsNullOrEmpty(dt.Rows[j][iCol].ToString()))
objArray[j] = DBNull.Value;
else
objArray[j] = GetObjValue(dt.Rows[j][iCol], oDbType);
}
return objArray;
}
.net 调用Oracle.Data.Access 组件提供的用于批量操作的方法—获取数据库表结构方法和跟参数赋值方法的更多相关文章
- .net 调用Oracle.Data.Access 组件提供的用于批量操作的方法
1.添加引用 using Oracle.DataAccess.Client; using System.Configuration; 2.代码 增加方法 //DestinationTableName ...
- Windows 的 Oracle Data Access Components (ODAC)
下载 x64bit https://www.oracle.com/technetwork/cn/database/windows/downloads/index.html 适用于 Windows 的 ...
- MySQL,SQLSERVER,ORACLE获取数据库表名及字段名
1.MySQL 获取表名: 用“show tables”命令.在程序中也可以采用该命令获取,在返回的RowSet中的“Tables_in_db”读出来.其中“db”是指你的数据库的名称,比如说Tabl ...
- ORACLE 中写入txt文本与从Txt文件中读入数据 修改表结构
--创建一个表 DROP TABLE TEST CASCADE CONSTRAINTS ; CREATE TABLE TEST(A VARCHAR(30),B VARCHAR(30)); --查看具体 ...
- oracle数据库自动生成数据库表结构文档(亲测有效)
import java.awt.Color; import java.io.FileOutputStream; import java.sql.Connection; import java.sql. ...
- 使用 Oracle Data Access Components连接oracel
使用微软自带的oracle连接类,在framework4.0中被标识为弃用,强行用它开发了Winform程序,发布放到XP上提示: Error System.Data.OracleClient req ...
- (转)oracle使用expdp、impdp和exp、imp导入导出表及表结构
使用expdp.impdp和exp.imp时应该注重的事项: 1.exp和imp是客户端工具程序,它们既可以在客户端使用,也可以在服务端使用. 2.expdp和impdp是服务端的工具程序,他们只能在 ...
- Oracle数据库表结构导出
1. 在PL/SQL中找到"工具--导出用户对象"菜单.点击运行.
- oracle 使用sql获取数据库表,表的字段
--第一种方法: 查询dba_tab_columns select COLUMN_NAME,DATA_TYPE,DATA_LENGTH from dba_tab_columns where t ...
随机推荐
- Swift缩水版MJExtension - Reflect的基本使用
github:https://github.com/CharlinFeng/Reflect 直接拖拽Reflect文件夹到您的项目中即可,无任何第三方依赖!文件夹结构说明:.Coding 归档相关.R ...
- div有最小高度且自适应高度
DIV最小高度且自适应高度 在IE6中,如果子容器的高度超过父容器的时候,父容器会被子容器撑开,所以我们可以直接设置一个height的高度值即可.但是在IE7和firefox就不行了,它不会自动撑 ...
- uva 352 - The Seasonal War
題意: 要確認畫面中有幾隻Eagles,每個pixel如果是'1'代表為一隻Eagles,但上下左右(包含斜角共8個方向)相連的'1'只能算是同一隻. 想法: 使用DFS找'1'有幾個區域. #inc ...
- JSONP的原理
JSONP的原理 JSONP的最基本的原理是:动态添加一个<script>标签,而script标签的src属性是没有跨域的限制的. <script type="text/j ...
- 前端开发攻城师绝对不可忽视的五个HTML5新特性
HTML5已经火了一段时间了,相信作为web相关开发工程师,肯定或多或少的了解和尝试过一些HTML5的特性和编程.还记得以前我们介绍过的HTML5新标签. 作为未来前端开发技术的潮流和风向标,HTML ...
- vmware workstation 7.0官方下载安装
https://my.vmware.com/group/vmware/downloads#tab2 这里注册后可以下载到vmware的所有产品,可以下载到免费的vmplayer,以及收费的vmware ...
- cf E. Neatness
http://codeforces.com/contest/359/problem/E 题意:要关掉所有房间的灯,一个步骤要么开灯,要么关灯,要么向有灯的方向前进一格.输出一种关掉所有灯的方案.不能关 ...
- Codeforces 161D Distance in Tree
题目大意:给出一棵n个节点的树,统计树中长度为k的路径的条数(1<=n<=50000 , 1<=k<=500) 思路:树分治! #include<cstdio> # ...
- 深入理解7816(4)---关于T=1
之前说过的T=0协议,基本上相当于是透明的数据,也就是说从应用的角度看,通过T=0传递的TPDU数据信息大都可以直接转换为对应的APD命令响应数据,“字节”是T=0协议最小的数据传输单元. 对于T=1 ...
- Delphi中多线程下使用使用 UniDAC+MSSQL 需要注意的问题(连接前调用CoInitialize)
一般解决方法是在线程开始启用 CoInitialize(nil),线程结束调用 CoUninitialize .如果你使用多种数据库连接,比如三层中经常切换到MSSQL和Oracle,我们只需在判断 ...