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 组件提供的用于批量操作的方法—获取数据库表结构方法和跟参数赋值方法的更多相关文章

  1. .net 调用Oracle.Data.Access 组件提供的用于批量操作的方法

    1.添加引用 using Oracle.DataAccess.Client; using System.Configuration; 2.代码 增加方法 //DestinationTableName ...

  2. Windows 的 Oracle Data Access Components (ODAC)

     下载 x64bit https://www.oracle.com/technetwork/cn/database/windows/downloads/index.html 适用于 Windows 的 ...

  3. MySQL,SQLSERVER,ORACLE获取数据库表名及字段名

    1.MySQL 获取表名: 用“show tables”命令.在程序中也可以采用该命令获取,在返回的RowSet中的“Tables_in_db”读出来.其中“db”是指你的数据库的名称,比如说Tabl ...

  4. ORACLE 中写入txt文本与从Txt文件中读入数据 修改表结构

    --创建一个表 DROP TABLE TEST CASCADE CONSTRAINTS ; CREATE TABLE TEST(A VARCHAR(30),B VARCHAR(30)); --查看具体 ...

  5. oracle数据库自动生成数据库表结构文档(亲测有效)

    import java.awt.Color; import java.io.FileOutputStream; import java.sql.Connection; import java.sql. ...

  6. 使用 Oracle Data Access Components连接oracel

    使用微软自带的oracle连接类,在framework4.0中被标识为弃用,强行用它开发了Winform程序,发布放到XP上提示: Error System.Data.OracleClient req ...

  7. (转)oracle使用expdp、impdp和exp、imp导入导出表及表结构

    使用expdp.impdp和exp.imp时应该注重的事项: 1.exp和imp是客户端工具程序,它们既可以在客户端使用,也可以在服务端使用. 2.expdp和impdp是服务端的工具程序,他们只能在 ...

  8. Oracle数据库表结构导出

    1. 在PL/SQL中找到"工具--导出用户对象"菜单.点击运行.

  9. oracle 使用sql获取数据库表,表的字段

    --第一种方法: 查询dba_tab_columns select COLUMN_NAME,DATA_TYPE,DATA_LENGTH  from   dba_tab_columns where  t ...

随机推荐

  1. iOS_SN_地图的使用(2)

    上一篇讲的是地图的基本使用,和注意事项,这一篇主要讲POI检索.百度地图SDK提供三种类型的POI检索:周边检索.区域检索和城市内检索.下面将以周边检索为例,向大家介绍如何使用检索服务. - (voi ...

  2. iOS中你必须了解的多线程

    多线程概念详解 什么是进程? 简单的说进程就是我们电脑上运行的一个个应用程序,每一个程序就是一个进程,并且每个进程之间是独立的,每个进程运行在其专用受保护的内存空间内(window系统可以通过任务管理 ...

  3. C#多线程实践——锁和线程安全

    锁实现互斥的访问,用于确保在同一时刻只有一个线程可以进入特殊的代码片段,考虑下面的类: class ThreadUnsafe { static int val1, val2; static void ...

  4. JS正则验证格式

    function test() { var temp = document.getElementById("text1"); //对电子邮件的验证 var myreg = /^([ ...

  5. java下socket传图片

    package cn.stat.p4.ipdemo; import java.io.File; import java.io.FileOutputStream; import java.io.IOEx ...

  6. Android-4

    显式Intent 隐式Intent Intent过滤器相关选项 通过浏览器链接启动本地Activity

  7. Ubuntu常用命令速查手册-珍藏版-完整版

    sudo apt-get install 软件名 安装软件命令 sudo nautilus 打开文件(有root权限) su root 切换到“root” ls 列出当前目录文件(不包括隐含文件) l ...

  8. chord原理的解读

    chord: A Scalable Peer-to-peer Lookup Service for Internet Application 在 P2P 系统中,有效地定位分布在网络中不同节点的数据资 ...

  9. python中的嵌套类(内部类调用外部类中的方法函数)

    在为书中版本是3.X的,但2.X不太支持直接调用. 所以,在PYTHON2.X中,要在内部类中调用外部类的方法,就必须得实例化外部类,然后,传入实例进行调用. 花了我两个小时啊,资料没找到,自己一个一 ...

  10. Codeforces 204A Little Elephant and Interval

    http://codeforces.com/problemset/problem/204/A 题意:给定一个[L,R]区间,求这个区间里面首位和末尾相同的数字有多少个 思路:考虑这个问题满足区间加减, ...