西西软件园多重安全检测下载网站、值得信赖的软件下载站!
软件
软件
文章
搜索
鐢熸椿鏈嶅姟
鏀粯瀹濋挶鍖�(Alipay)V10.2.53.7000 瀹夊崜鐗�鏀粯瀹濋挶鍖�(Alipay)V10.2.53.7000 瀹夊崜鐗�
鐧惧害鍦板浘瀵艰埅2022V15.12.10 瀹夊崜鎵嬫満鐗�鐧惧害鍦板浘瀵艰埅2022V15.12.10 瀹夊崜鎵嬫満鐗�
鎵嬫満娣樺疂瀹㈡埛绔痸10.8.40瀹樻柟鏈€鏂扮増鎵嬫満娣樺疂瀹㈡埛绔痸10.8.40瀹樻柟鏈€鏂扮増
鐣呴€旂綉鎵嬫満瀹㈡埛绔痸5.6.9 瀹樻柟鏈€鏂扮増鐣呴€旂綉鎵嬫満瀹㈡埛绔痸5.6.9 瀹樻柟鏈€鏂扮増
鍗冭亰鐭ヨ瘑鏈嶅姟appv4.5.1瀹樻柟鐗�鍗冭亰鐭ヨ瘑鏈嶅姟appv4.5.1瀹樻柟鐗�
褰遍煶鎾斁
p2psearcher瀹夊崜鐗�7.3  鎵嬫満鐗�p2psearcher瀹夊崜鐗�7.3 鎵嬫満鐗�
閰风嫍闊充箰2022瀹樻柟鐗圴11.0.8 瀹樻柟瀹夊崜鐗�閰风嫍闊充箰2022瀹樻柟鐗圴11.0.8 瀹樻柟瀹夊崜鐗�
鐖卞鑹烘墜鏈虹増v13.1.0鐖卞鑹烘墜鏈虹増v13.1.0
鐧惧害褰遍煶7.13.0 瀹樻柟鏈€鏂扮増鐧惧害褰遍煶7.13.0 瀹樻柟鏈€鏂扮増
褰遍煶鍏堥攱v6.9.0 瀹夊崜鎵嬫満鐗�褰遍煶鍏堥攱v6.9.0 瀹夊崜鎵嬫満鐗�
闃呰宸ュ叿
鑵捐鍔ㄦ极V9.11.5 瀹夊崜鐗�鑵捐鍔ㄦ极V9.11.5 瀹夊崜鐗�
涔︽棗灏忚鍏嶈垂鐗堟湰v11.5.5.153 瀹樻柟鏈€鏂扮増涔︽棗灏忚鍏嶈垂鐗堟湰v11.5.5.153 瀹樻柟鏈€鏂扮増
QQ闃呰鍣╝ppV7.7.1.910 瀹樻柟鏈€鏂扮増QQ闃呰鍣╝ppV7.7.1.910 瀹樻柟鏈€鏂扮増
鎳掍汉鐣呭惉鍚功appv7.1.5 瀹樻柟瀹夊崜鐗�鎳掍汉鐣呭惉鍚功appv7.1.5 瀹樻柟瀹夊崜鐗�
璧风偣璇讳功app鏂扮増鏈�20227.9.186 瀹夊崜鐗�璧风偣璇讳功app鏂扮増鏈�20227.9.186 瀹夊崜鐗�
閲戣瀺鐞嗚储
骞冲畨璇佸埜瀹塭鐞嗚储V9.1.0.1 瀹樻柟瀹夊崜鐗�骞冲畨璇佸埜瀹塭鐞嗚储V9.1.0.1 瀹樻柟瀹夊崜鐗�
娴烽€氳瘉鍒告墜鏈虹増(e娴烽€氳储)8.71 瀹樻柟瀹夊崜鐗�娴烽€氳瘉鍒告墜鏈虹増(e娴烽€氳储)8.71 瀹樻柟瀹夊崜鐗�
涓滄捣璇佸埜涓滄捣鐞嗚储4.0.5 瀹夊崜鐗�涓滄捣璇佸埜涓滄捣鐞嗚储4.0.5 瀹夊崜鐗�
涓摱璇佸埜绉诲姩鐞嗚储杞欢6.02.010 瀹樻柟瀹夊崜鐗�涓摱璇佸埜绉诲姩鐞嗚储杞欢6.02.010 瀹樻柟瀹夊崜鐗�
鍗庨緳璇佸埜灏忛噾鎵嬫満鐞嗚储杞欢3.2.4 瀹夊崜鐗�鍗庨緳璇佸埜灏忛噾鎵嬫満鐞嗚储杞欢3.2.4 瀹夊崜鐗�
鎵嬫満閾惰
绂忓缓鍐滄潙淇$敤绀炬墜鏈洪摱琛屽鎴风2.3.4 瀹夊崜鐗�绂忓缓鍐滄潙淇$敤绀炬墜鏈洪摱琛屽鎴风2.3.4 瀹夊崜鐗�
鏄撳埗浣滆棰戝壀杈慳pp4.1.16瀹夊崜鐗�鏄撳埗浣滆棰戝壀杈慳pp4.1.16瀹夊崜鐗�
鏀粯瀹濋挶鍖�(Alipay)V10.2.53.7000 瀹夊崜鐗�鏀粯瀹濋挶鍖�(Alipay)V10.2.53.7000 瀹夊崜鐗�
涓浗宸ュ晢閾惰鎵嬫満閾惰appV7.0.1.2.5 瀹夊崜鐗�涓浗宸ュ晢閾惰鎵嬫満閾惰appV7.0.1.2.5 瀹夊崜鐗�
涓浗閾惰鎵嬫満閾惰瀹㈡埛绔�7.2.5 瀹樻柟瀹夊崜鐗�涓浗閾惰鎵嬫満閾惰瀹㈡埛绔�7.2.5 瀹樻柟瀹夊崜鐗�
浼戦棽鐩婃櫤
鑵捐鐚庨奔杈句汉鎵嬫満鐗圴2.3.0.0 瀹樻柟瀹夊崜鐗�鑵捐鐚庨奔杈句汉鎵嬫満鐗圴2.3.0.0 瀹樻柟瀹夊崜鐗�
鍔茶垶鍥㈠畼鏂规鐗堟墜娓竩1.2.1瀹樻柟鐗�鍔茶垶鍥㈠畼鏂规鐗堟墜娓竩1.2.1瀹樻柟鐗�
楗ラタ椴ㄩ奔杩涘寲鏃犻檺閽荤煶鐗坴7.8.0.0瀹夊崜鐗�楗ラタ椴ㄩ奔杩涘寲鏃犻檺閽荤煶鐗坴7.8.0.0瀹夊崜鐗�
妞嶇墿澶ф垬鍍靛案鍏ㄦ槑鏄�1.0.91 瀹夊崜鐗�妞嶇墿澶ф垬鍍靛案鍏ㄦ槑鏄�1.0.91 瀹夊崜鐗�
鍔ㄤ綔灏勫嚮
鍦颁笅鍩庣獊鍑昏€卋t鐗�1.6.3 瀹樻柟鐗�鍦颁笅鍩庣獊鍑昏€卋t鐗�1.6.3 瀹樻柟鐗�
瑁呯敳鑱旂洘1.325.157 瀹夊崜鐗�瑁呯敳鑱旂洘1.325.157 瀹夊崜鐗�
鍦f枟澹槦鐭㈤泦缁搗4.2.1 瀹夊崜鐗�鍦f枟澹槦鐭㈤泦缁搗4.2.1 瀹夊崜鐗�
閬ぉ3D鎵嬫父1.0.9瀹夊崜鐗�閬ぉ3D鎵嬫父1.0.9瀹夊崜鐗�
濉旈槻娓告垙
瀹夊崜妞嶇墿澶ф垬鍍靛案2榛戞殫鏃朵唬淇敼鐗圴1.9.5 鏈€鏂扮増瀹夊崜妞嶇墿澶ф垬鍍靛案2榛戞殫鏃朵唬淇敼鐗圴1.9.5 鏈€鏂扮増
涔辨枟瑗挎父2v1.0.150瀹夊崜鐗�涔辨枟瑗挎父2v1.0.150瀹夊崜鐗�
淇濆崼钀濆崪3鏃犻檺閽荤煶鏈€鏂扮増v2.0.0.1 瀹夊崜鐗�淇濆崼钀濆崪3鏃犻檺閽荤煶鏈€鏂扮増v2.0.0.1 瀹夊崜鐗�
鍙h鑻遍泟鍗曟満鐗�1.2.0 瀹夊崜鐗�鍙h鑻遍泟鍗曟満鐗�1.2.0 瀹夊崜鐗�
灏忓皬鍐涘洟瀹夊崜鐗�2.7.4 鏃犻檺閲戝竵淇敼鐗�灏忓皬鍐涘洟瀹夊崜鐗�2.7.4 鏃犻檺閲戝竵淇敼鐗�
璧涜溅绔炴妧
鐧诲北璧涜溅2鎵嬫父1.47.1  瀹夊崜鐗�鐧诲北璧涜溅2鎵嬫父1.47.1 瀹夊崜鐗�
涓€璧锋潵椋炶溅瀹夊崜鐗坴2.9.14 鏈€鏂扮増涓€璧锋潵椋炶溅瀹夊崜鐗坴2.9.14 鏈€鏂扮増
璺戣窇鍗′竵杞︽墜鏈虹増瀹樻柟鏈€鏂扮増v1.16.2 瀹夊崜鐗�璺戣窇鍗′竵杞︽墜鏈虹増瀹樻柟鏈€鏂扮増v1.16.2 瀹夊崜鐗�
鐙傞噹椋欒溅8鏋侀€熷噷浜戜慨鏀圭増(鍏嶆暟鎹寘)v4.6.0j 閲戝竵鏃犻檺鐗�鐙傞噹椋欒溅8鏋侀€熷噷浜戜慨鏀圭増(鍏嶆暟鎹寘)v4.6.0j 閲戝竵鏃犻檺鐗�
鐧句箰鍗冪偖鎹曢奔2021鏈€鏂扮増5.78 瀹夊崜鐗�鐧句箰鍗冪偖鎹曢奔2021鏈€鏂扮増5.78 瀹夊崜鐗�
瑙掕壊鎵紨
姊﹀够鍓戣垶鑰呭彉鎬佺増1.0.1.2瀹夊崜鐗�姊﹀够鍓戣垶鑰呭彉鎬佺増1.0.1.2瀹夊崜鐗�
浠欏浼犺ro澶嶅叴瀹夊崜鐗�1.20.3鏈€鏂扮増浠欏浼犺ro澶嶅叴瀹夊崜鐗�1.20.3鏈€鏂扮増
姊﹀够璇涗粰鎵嬫父鐗�1.3.6 瀹樻柟瀹夊崜鐗�姊﹀够璇涗粰鎵嬫父鐗�1.3.6 瀹樻柟瀹夊崜鐗�
鐜嬭€呰崳鑰€V3.72.1.1 瀹夊崜鏈€鏂板畼鏂圭増鐜嬭€呰崳鑰€V3.72.1.1 瀹夊崜鏈€鏂板畼鏂圭増
璋佸灏忚溅寮烘墜鏈虹増v1.0.49 瀹夊崜鐗�璋佸灏忚溅寮烘墜鏈虹増v1.0.49 瀹夊崜鐗�
绯荤粺杞欢
mac纾佺洏鍒嗗尯宸ュ叿(Paragon Camptune X)V10.8.12瀹樻柟鏈€鏂扮増mac纾佺洏鍒嗗尯宸ュ叿(Paragon Camptune X)V10.8.12瀹樻柟鏈€鏂扮増
鑻规灉鎿嶄綔绯荤粺MACOSX 10.9.4 Mavericks瀹屽叏鍏嶈垂鐗�鑻规灉鎿嶄綔绯荤粺MACOSX 10.9.4 Mavericks瀹屽叏鍏嶈垂鐗�
Rar瑙e帇鍒╁櫒mac鐗坴1.4 瀹樻柟鍏嶈垂鐗�Rar瑙e帇鍒╁櫒mac鐗坴1.4 瀹樻柟鍏嶈垂鐗�
Mac瀹夊崜妯℃嫙鍣�(ARC Welder)v1.0 瀹樻柟鏈€鏂扮増Mac瀹夊崜妯℃嫙鍣�(ARC Welder)v1.0 瀹樻柟鏈€鏂扮増
Charles for MacV3.9.3瀹樻柟鐗�Charles for MacV3.9.3瀹樻柟鐗�
缃戠粶宸ュ叿
鎼滅嫍娴忚鍣╩ac鐗坴5.2 瀹樻柟姝e紡鐗�鎼滅嫍娴忚鍣╩ac鐗坴5.2 瀹樻柟姝e紡鐗�
閿愭嵎瀹㈡埛绔痬ac鐗圴1.33瀹樻柟鏈€鏂扮増閿愭嵎瀹㈡埛绔痬ac鐗圴1.33瀹樻柟鏈€鏂扮増
蹇墮mac鐗坴1.3.2 瀹樻柟姝e紡鐗�蹇墮mac鐗坴1.3.2 瀹樻柟姝e紡鐗�
鏋佺偣浜旂瑪Mac鐗�7.13姝e紡鐗�鏋佺偣浜旂瑪Mac鐗�7.13姝e紡鐗�
濯掍綋宸ュ叿
Apple Logic Pro xV10.3.2Apple Logic Pro xV10.3.2
Adobe Premiere Pro CC 2017 mac鐗坴11.0.0 涓枃鐗�Adobe Premiere Pro CC 2017 mac鐗坴11.0.0 涓枃鐗�
鍗冨崈闈欏惉Mac鐗圴9.1.1 瀹樻柟鏈€鏂扮増鍗冨崈闈欏惉Mac鐗圴9.1.1 瀹樻柟鏈€鏂扮増
Mac缃戠粶鐩存挱杞欢(MacTV)v0.121 瀹樻柟鏈€鏂扮増Mac缃戠粶鐩存挱杞欢(MacTV)v0.121 瀹樻柟鏈€鏂扮増
Adobe Fireworks CS6 Mac鐗圕S6瀹樻柟绠€浣撲腑鏂囩増Adobe Fireworks CS6 Mac鐗圕S6瀹樻柟绠€浣撲腑鏂囩増
鍥惧舰鍥惧儚
AutoCAD2015 mac涓枃鐗堟湰v1.0 瀹樻柟姝e紡鐗�AutoCAD2015 mac涓枃鐗堟湰v1.0 瀹樻柟姝e紡鐗�
Adobe Photoshop cs6 mac鐗坴13.0.3 瀹樻柟涓枃鐗�Adobe Photoshop cs6 mac鐗坴13.0.3 瀹樻柟涓枃鐗�
Mac鐭㈤噺缁樺浘杞欢(Sketch mac)v3.3.2 涓枃鐗�Mac鐭㈤噺缁樺浘杞欢(Sketch mac)v3.3.2 涓枃鐗�
Adobe After Effects cs6 mac鐗坴1.0涓枃鐗�Adobe After Effects cs6 mac鐗坴1.0涓枃鐗�
Adobe InDesign cs6 mac1.0 瀹樻柟涓枃鐗�Adobe InDesign cs6 mac1.0 瀹樻柟涓枃鐗�
搴旂敤杞欢
Mac鐗堝揩鎾�1.1.26 瀹樻柟姝e紡鐗圼dmg]Mac鐗堝揩鎾�1.1.26 瀹樻柟姝e紡鐗圼dmg]
Mac璇诲啓NTFS(Paragon NTFS for Mac)12.1.62 瀹樻柟姝e紡鐗�Mac璇诲啓NTFS(Paragon NTFS for Mac)12.1.62 瀹樻柟姝e紡鐗�
杩呴浄10 for macv3.4.1.4368 瀹樻柟鏈€鏂扮増杩呴浄10 for macv3.4.1.4368 瀹樻柟鏈€鏂扮増
Mac涓嬫渶寮哄ぇ鐨勭郴缁熸竻鐞嗗伐鍏�(CleanMyMac for mac)v3.1.1 姝e紡鐗�Mac涓嬫渶寮哄ぇ鐨勭郴缁熸竻鐞嗗伐鍏�(CleanMyMac for mac)v3.1.1 姝e紡鐗�
鑻规灉BootCamp5.1.5640 瀹樻柟鏈€鏂扮増鑻规灉BootCamp5.1.5640 瀹樻柟鏈€鏂扮増

首页西西教程数据库教程 → SQL server2008、ACCESS 2007、ORACLE的EXCEL2007导入、导出具体实现

SQL server2008、ACCESS 2007、ORACLE的EXCEL2007导入、导出具体实现

相关文章发表评论 来源:西西整理时间:2012/5/26 21:52:49字体大小:A-A+

作者:佚名点击:259次评论:0次标签: SqlServer

  • 类型:数据库类大小:40.7M语言:中文 评分:6.6
  • 标签:
立即下载

DataPie功能:可以实现SQL server2008、ACCESS 2007、ORACLE数据库的EXCEL2007导入、导出以及存储过程运算。源码及安装包下载地址:http://datapie.codeplex.com/

本篇文章,主要介绍下DataPie中多数据库导入导出功能的实现,以及获取不同数据库架构信息的一些方法。

1.IDBUtility接口。

主要包含导入、导出、基本SQL操作方法的定义。具体方法的用途看其名称基本可以知道。

using System;

using System.Data;

using System.Collections;

using System.Collections.Generic;

namespace DataPie.DBUtility

{

    public interface IDBUtility

    {

        #region 执行SQL操作              

        /// <summary>

        /// 运行SQL语句

        /// </summary>

        /// <param name="SQL"></param>

        int ExecuteSql(string SQL);

        #endregion

        #region 返回DataTable对象

        /// <summary>

        /// 运行SQL语句,返回DataTable对象

        /// </summary>

        DataTable ReturnDataTable(string SQL, int StartIndex, int PageSize);

        /// <summary>

        /// 运行SQL语句,返回DataTable对象

        /// </summary>

        DataTable ReturnDataTable(string SQL);

        #endregion

        #region 存储过程操作

        int RunProcedure(string storedProcName);

        #endregion

        #region 获取数据库Schema信息

        /// <summary>

        /// 获取SQL SERVER中数据库列表

        /// </summary>

        IList<string> GetDataBaseInfo();

        IList<string> GetTableInfo();

        IList<string> GetColumnInfo(string TableName);

        IList<string> GetProcInfo();

        IList<string> GetViewInfo();

        int ReturnTbCount(string tb_name);

        #endregion

        #region 批量导入数据库

        /// <summary>

        /// 批量导入数据库

        /// </summary>

        bool SqlBulkCopyImport(IList<string> maplist, string TableName, DataTable dt);

        #endregion

    }

}

2.SQL SERVER数据库对该接口的具体实现方法

        /// <summary>

        /// 运行SQL语句,返回DataTable对象

        /// </summary>

        public DataTable ReturnDataTable(string SQL)

        {

            using (SqlConnection connection = new SqlConnection(connectionString))

            {

                DataTable dt = new DataTable();

                try

                {

                    connection.Open();

                    SqlDataAdapter command = new SqlDataAdapter(SQL, connection);

                    command.Fill(dt);

                }

                catch (System.Data.SqlClient.SqlException ex)

                {

                    throw new Exception(ex.Message);

                }

                return dt;

            }

        }

        /// <summary>

        /// 运行SQL语句,返回DataTable对象

        /// </summary>

        public DataTable ReturnDataTable(string SQL, int StartIndex, int PageSize)

        {

            using (SqlConnection connection = new SqlConnection(connectionString))

            {

                DataTable dt = new DataTable();

                try

                {

                    connection.Open();

                    SqlDataAdapter command = new SqlDataAdapter(SQL, connection);

                    command.Fill(StartIndex, PageSize, dt);

                }

                catch (System.Data.SqlClient.SqlException ex)

                {

                    throw new Exception(ex.Message);

                }

                return dt;

            }

        }

// 返回制定表名的行数 

        public int ReturnTbCount(string tb_name)

        {

            using (SqlConnection connection = new SqlConnection(connectionString))

            {

                try

                {

                    string SQL = "select  count(*)   from " + tb_name;

                    connection.Open();

                    SqlCommand cmd = new SqlCommand(SQL, connection);

                    int count = int.Parse(cmd.ExecuteScalar().ToString());

                    return count;

                }

                catch (System.Data.SqlClient.SqlException ex)

                {

                    throw new Exception(ex.Message);

                }

            }

        }

#region 架构信息

        /// <summary>

        /// 根据条件,返回架构信息

        /// </summary>

        /// <param name="collectionName">集合名称</param>

        /// <param name="restictionValues">约束条件</param>

        /// <returns>DataTable</returns>

        public static DataTable GetSchema(string collectionName, string[] restictionValues)

        {

            using (SqlConnection connection = new SqlConnection(connectionString))

            {

                DataTable dt = new DataTable();

                try

                {

                    dt.Clear();

                    connection.Open();

                    dt = connection.GetSchema(collectionName, restictionValues);

                }

                catch

                {

                    dt = null;

                }

                return dt;

            }

        }

        /// <summary>

        /// 返回指定名称的架构信息

        /// </summary>

        /// <param name="collectionName">集合名称</param>

        /// <returns>DataTable</returns>

        public static DataTable GetSchema(string collectionName)

        {

            using (SqlConnection connection = new SqlConnection(connectionString))

            {

                DataTable dt = new DataTable();

                try

                {

                    dt.Clear();

                    connection.Open();

                    dt = connection.GetSchema(collectionName);

                }

                catch

                {

                    dt = null;

                }

                return dt;

            }

        }

        public IList<string> GetDataBaseInfo()

        {

            IList<string> DatabaseList = new List<string>();

            DataTable dt = GetSchema("Databases");

            int num = dt.Rows.Count;

            if (dt.Rows.Count > 0)

            {

                foreach (DataRow _DataRowItem in dt.Rows)

                {

                    DatabaseList.Add(_DataRowItem["database_name"].ToString());

                }

            }

            return DatabaseList;

        }

        public IList<string> GetTableInfo()

        {

            IList<string> tableList = new List<string>();

            string[] rs = new string[] { null, null, null, "BASE TABLE" };

            DataTable dt = GetSchema("tables", rs);

            int num = dt.Rows.Count;

            if (dt.Rows.Count > 0)

            {

                foreach (DataRow _DataRowItem in dt.Rows)

                {

                    tableList.Add(_DataRowItem["table_name"].ToString());

                }

            }

            return tableList;

        }

        public IList<string> GetColumnInfo(string TableName)

        {

            string[] restrictions = new string[] { null, null, TableName };

            DataTable tableinfo = GetSchema("Columns", restrictions);

            IList<string> List = new List<string>();

            int count = tableinfo.Rows.Count;

            if (count > 0)

            {

                //for (int i = 0; i < count; i++)

                //{

                //    List.Add(tableinfo.Rows[i]["Column_Name"].ToString());

                //}

                foreach (DataRow _DataRowItem in tableinfo.Rows)

                {

                    List.Add(_DataRowItem["Column_Name"].ToString());

                }

            }

            return List;

        }

        public IList<string> GetProcInfo()

        {

            IList<string> List = new List<string>();

            DataTable dt = GetSchema("Procedures");

            int num = dt.Rows.Count;

            if (dt != null && dt.Rows.Count > 0)

            {

                foreach (DataRow _DataRowItem in dt.Rows)

                {

                    if (_DataRowItem["routine_type"].ToString().ToUpper() != "FUNCTION")

                    { List.Add(_DataRowItem["routine_name"].ToString()); }

                }

            }

            return List;

        }

        public IList<string> GetFunctionInfo()

        {

            IList<string> List = new List<string>();

            DataTable dt = GetSchema("Procedures");

            int num = dt.Rows.Count;

            if (dt != null && dt.Rows.Count > 0)

            {

                foreach (DataRow _DataRowItem in dt.Rows)

                {

                    if (_DataRowItem["routine_type"].ToString().ToUpper() == "FUNCTION")

                    { List.Add(_DataRowItem["routine_name"].ToString()); }

                }

            }

            return List;

        }

        public IList<string> GetViewInfo()

        {

            IList<string> List = new List<string>();

            string[] rs = new string[] { null, null, null, "BASE TABLE" };

            DataTable dt = GetSchema("views");

            int num = dt.Rows.Count;

            if (dt.Rows.Count > 0)

            {

                foreach (DataRow _DataRowItem in dt.Rows)

                {

                    List.Add(_DataRowItem["table_name"].ToString());

                }

            }

            return List;

        }

        #endregion

        public bool SqlBulkCopyImport(IList<string> maplist, string TableName, DataTable dt)

        {

            using (SqlConnection connection = new SqlConnection(connectionString))

            {

                connection.Open();

                using (SqlBulkCopy bulkCopy = new SqlBulkCopy(connection))

                {

                    bulkCopy.DestinationTableName = TableName;

                    foreach (string a in maplist)

                    {

                        bulkCopy.ColumnMappings.Add(a, a);

                    }

                    try

                    {

                        bulkCopy.WriteToServer(dt);

                        return true;

                    }

                    catch (Exception e)

                    {

                        throw e;

                    }

                }

            }

        }

3.ACCESS2007数据库对该接口的具体实现方法

其中大部分的方法实现基本相似。但ACCEE2007本身不支持存储过程,但支持单个插入、删除、更新等语句,在联合查询(union)中,往往默认进入了存储过程架构下,所以导致ACCESS在实现IDBUtility接口时,需要进行一些特殊的处理。其中,本工具把删除和更新操作默认为存储过程,对查询和联合查询定义为视图。具体实现的代码如下:

        public bool IF_Proc(string sql)

        {

            if (sql.ToUpper().Contains("DELETE") || sql.ToUpper().Contains("UPDATE"))

                return true;

            else if (sql.ToUpper().Contains("SELECT") && sql.ToUpper().Contains("INTO"))

                return true;

            else return false;

        }

        public IList<string> GetProcInfo()

        {

            IList<string> List = new List<string>();

            DataTable dt = GetSchema("Procedures");

            int num = dt.Rows.Count;

            if (dt != null && dt.Rows.Count > 0)

            {

                foreach (DataRow _DataRowItem in dt.Rows)

                {

                    if (IF_Proc(_DataRowItem["PROCEDURE_DEFINITION"].ToString()))

                    {

                        List.Add(_DataRowItem["PROCEDURE_NAME"].ToString());

                    }

                }

            }

            return List;

        }

        public IList<string> GetFunctionInfo()

        {

            IList<string> List = new List<string>();

            DataTable dt = GetSchema("Procedures");

            int num = dt.Rows.Count;

            if (dt != null && dt.Rows.Count > 0)

            {

                foreach (DataRow _DataRowItem in dt.Rows)

                {

                    if (_DataRowItem["PROCEDURE_TYPE"].ToString().ToUpper() == "FUNCTION")

                    { List.Add(_DataRowItem["PROCEDURE_NAME"].ToString()); }

                }

            }

            return List;

        }

        public IList<string> GetViewInfo()

        {

            IList<string> List = new List<string>();

            string[] rs = new string[] { null, null, null, "BASE TABLE" };

            DataTable dt = GetSchema("views");

            int num = dt.Rows.Count;

            if (dt.Rows.Count > 0)

            {

                foreach (DataRow _DataRowItem in dt.Rows)

                {

                    List.Add(_DataRowItem["table_name"].ToString());

                }

            }

            //添加被架构默认为存储过程的视图

            dt = GetSchema("Procedures");

            num = dt.Rows.Count;

            if (dt != null && dt.Rows.Count > 0)

            {

                foreach (DataRow _DataRowItem in dt.Rows)

                {

                    if (!IF_Proc(_DataRowItem["PROCEDURE_DEFINITION"].ToString()))

                    {

                        List.Add(_DataRowItem["PROCEDURE_NAME"].ToString());

                    }

                }

            }

            return List;

        }

        public int ReturnTbCount(string tb_name)

        {

            using (OleDbConnection connection = new OleDbConnection(connectionString))

            {

                try

                {

                    string SQL = "select  count(*)   from " + tb_name;

                    connection.Open();

                    OleDbCommand cmd = new OleDbCommand(SQL, connection);

                    int count = int.Parse(cmd.ExecuteScalar().ToString());

                    return count;

                }

                catch (System.Data.SqlClient.SqlException ex)

                {

                    throw new Exception(ex.Message);

                }

            }

        }

        #endregion

//批量插入数据方法的实现

        public bool SqlBulkCopyImport(IList<string> maplist, string TableName, DataTable dt)

        {

            try

            {

                using (OleDbConnection connection = new OleDbConnection(connectionString))

                {

                    connection.Open();

                    OleDbDataAdapter adapter = new OleDbDataAdapter("select * from " + TableName + "  where 1=0", connection);

                    OleDbCommandBuilder builder = new OleDbCommandBuilder(adapter);

                    int rowcount = dt.Rows.Count;

                    for (int n = 0; n < rowcount; n++)

                    {

                        dt.Rows[n].SetAdded();

                    }

                    //adapter.UpdateBatchSize = 1000;

                    adapter.Update(dt);

                }

                return true;

            }

            catch (Exception e)

            {

                throw e;

            }

        }

4.ORACEL数据库对该接口的具体实现方法

ORACLE数据库查询数据库schema的信息,用的是ORACEL自带的Oracle.DataAccess.Client库,其中有一些架构信息与微软在.Net2.0中提供的方法不一致。具体的实现,可以参见源码,在此不列出了。

相关评论

阅读本文后您有什么感想? 已有人给出评价!

  • 8 喜欢喜欢
  • 3 顶
  • 1 难过难过
  • 5 囧
  • 3 围观围观
  • 2 无聊无聊

热门评论

最新评论

发表评论 查看所有评论(0)

昵称:
表情: 高兴 可 汗 我不要 害羞 好 下下下 送花 屎 亲亲
字数: 0/500 (您的评论需要经过审核才能显示)