zoukankan      html  css  js  c++  java
  • C# 将DataTable存储到DBF文件中

    (准备)生成一个DataTable

     1 /// <summary>
     2 /// 生成一个数据表
     3 /// </summary>
     4 /// <returns></returns>
     5 static DataTable GetTable()
     6 {
     7     try
     8     {
     9         DataTable dt = new DataTable("Characters");
    10                  
    11         dt.Columns.Add("Column0");
    12         dt.Columns.Add("Column1");
    13         dt.Columns.Add("Column2");
    14         dt.Columns.Add("Column3");
    15  
    16         dt.Rows.Add("abc", "def", "ghi", "jkl");
    17         dt.Rows.Add("def", "ghi", "jkl", "mno");
    18         dt.Rows.Add("ghi", "jkl", "mno", "pqr");
    19         dt.Rows.Add("jkl", "mno", "pqr", "stu");
    20  
    21         Console.WriteLine("Set DataTable: " + dt.TableName);
    22         foreach (DataRow dr in dt.Rows)
    23         {
    24             foreach (object  obj in dr.ItemArray)
    25             {
    26                 Console.Write(obj.ToString() + " ");
    27             }
    28             Console.WriteLine();
    29         }
    30         Console.WriteLine("Mission complete!");
    31  
    32         return dt;
    33     }
    34     catch
    35     {
    36         return null;
    37     }
    38 }

    函数:将DataTable的内容输出到DBF文件

     1 /// <summary>
     2 /// 将数据表写入到DBF文件中
     3 /// </summary>
     4 /// <param name="dt"></param>
     5 static void WriteToDbf(DataTable dt)
     6 {
     7     Console.WriteLine("Writing to: " + dt.TableName + ".dbf ...");
     8  
     9     //连接字符串
    10     string sConn =
    11         "Provider=Microsoft.Jet.OLEDB.4.0; " +
    12         "Data Source=" + System.IO.Directory.GetCurrentDirectory() + "; " +
    13         "Extended Properties=dBASE IV;";
    14     OleDbConnection conn = new OleDbConnection(sConn);
    15     conn.Open();
    16  
    17     try
    18     {
    19         //如果存在同名文件则先删除
    20         if (File.Exists(dt.TableName + ".dbf"))
    21         {
    22             Console.WriteLine("Delete file: " + dt.TableName + ".dbf ...");
    23             File.Delete(dt.TableName + ".dbf");
    24         }
    25  
    26         OleDbCommand cmd;
    27  
    28         //建立新表
    29         StringBuilder sbCreate = new StringBuilder();
    30         sbCreate.Append("CREATE TABLE " + dt.TableName + ".dbf (");
    31         for (int i = 0; i < dt.Columns.Count; i++)
    32         {
    33             sbCreate.Append(dt.Columns[i].ColumnName);
    34             sbCreate.Append(" char(25)");
    35             if (i != dt.Columns.Count - 1)
    36             {
    37                 sbCreate.Append(", ");
    38             }
    39             else
    40             {
    41                 sbCreate.Append(')');
    42             }
    43         }
    44  
    45         Console.WriteLine("
    Creating Table ...");
    46         Console.WriteLine(sbCreate.ToString());
    47         cmd = new OleDbCommand(sbCreate.ToString(), conn);
    48         cmd.ExecuteNonQuery();
    49  
    50         //插入各行
    51         StringBuilder sbInsert = new StringBuilder();
    52         foreach (DataRow dr in dt.Rows)
    53         {
    54             sbInsert.Clear();
    55             sbInsert.Append("INSERT INTO " + dt.TableName + ".dbf (");
    56             for (int i = 0; i < dt.Columns.Count; i++)
    57             {
    58                 sbInsert.Append(dt.Columns[i].ColumnName);
    59                 if (i != dt.Columns.Count - 1)
    60                 {
    61                     sbInsert.Append(", ");
    62                 }
    63             }
    64             sbInsert.Append(") VALUES (");
    65             for (int i = 0; i < dt.Columns.Count; i++)
    66             {
    67                 sbInsert.Append("'" + dr[i].ToString() + "'");
    68                 if (i != dt.Columns.Count - 1)
    69                 {
    70                     sbInsert.Append(", ");
    71                 }
    72             }
    73             sbInsert.Append(')');
    74  
    75             Console.WriteLine("
    Inserting lines ...");
    76             Console.WriteLine(sbInsert.ToString());
    77             cmd = new OleDbCommand(sbInsert.ToString(), conn);
    78             cmd.ExecuteNonQuery();
    79         }
    80     }
    81     catch (Exception ex)
    82     {
    83         Console.WriteLine(ex.Message);
    84     }
    85  
    86     conn.Close();
    87 }

    Main函数中的调用

    1 static void Main(string[] args)
    2 {
    3     DataTable dt = GetTable(); //生成一个数据表
    4     WriteToDbf(dt); //将数据表输出到DBF表中
    5  
    6     Console.ReadLine();
    7 }

    运行结果

    转自:http://my.oschina.net/Tsybius2014/blog/282797

  • 相关阅读:
    jquery笔记
    JavaScript 运动框架 Step by step(转)
    js中获取页面元素方法总结
    图片缩放效果IE和火狐兼容模式
    js循环运动效果实现
    网页捕捉错误
    (图文介绍)Virtualbox下实现Ubuntu虚拟机和win7主机文件共享(很简单,亲自试用,按此步骤一般都会成功)
    FFT算法实现(fft算法)快速傅里叶变换算法实现
    $_SESSION跨页面问题
    暂别ACM,转移阵地
  • 原文地址:https://www.cnblogs.com/China3S/p/5205456.html
Copyright © 2011-2022 走看看