zoukankan      html  css  js  c++  java
  • C# 操纵海量数据表的小技巧》写给新手



    问题描述:一个数据库中的某张表A有5,6万条记录。我们要对该表的每条记录做相同的处理,并将处理结果保存到表B。
    这时我们不能采用SqlDataReader读一条记录,处理,储存到表B的方案。因为sqldatareader对数据库连接具有独占性,所以我们就不能储存记录到表B了。还有一种方案是可行的,就是在内存中采用datatable数据结构映射一张A的虚表A‘,这种方法固然可行。但是这样做无疑是耗内存的。于是我们采取以下方案(这里的表Article就对应于上文抽象模型中的表A)
          DataBaseManipulation dbm=new DataBaseManipulation();
                string conStr = "server=(local);database=ArticleCollection;uid=sa;pwd=123456";
                string table = "Article";
                SqlConnection conn = new SqlConnection(conStr);//建立连接
              

    int ArticleLastIndex = dbm.GetTableLastIndex(table, conn, "ArticleId");
                int lastindex = 0;

                while (lastindex < ArticleLastIndex)
                {
                    string select = string.Format("select top 100 ArticleId,AuthorString,WorkPlaceString From Article  Where ArticleId>{0} ORDER BY ArticleId", lastindex);
                    SqlDataAdapter adapter = new SqlDataAdapter(select, conn);
                    DataTable dt = new DataTable();
                    adapter.Fill(dt);
                 
                   int lastAuthorIndex = dbm.GetTableLastIndex("Author", conn, "AuthorId");

                    for (int i = 0; i < dt.Rows.Count; i++)
                    {
                        //处理每条记录
                       .........................................................
                      //将每条记录处理的结果保存至Author表中(Author表相当于上文抽象建模中的表B)

                    }
                     lastindex = int.Parse(dt.Rows[dt.Rows.Count - 1]["ArticleId"].ToString());
                }
    //数据库操纵的类

    using System;
    using System.Collections.Generic;
    using System.Text;
    using System.Data;
    using System.Data.SqlClient;

    namespace CreateAuthorEntity
    {
        class DataBaseManipulation
        {
            public int GetDataBaseTableCount(string table, SqlConnection conn, string des)
            {
                string findCount = string.Format("SELECT COUNT({0})  FROM {1}", des, table);
                conn.Open();
                SqlCommand command = new SqlCommand(findCount, conn);
                SqlDataReader reader = command.ExecuteReader();
                reader.Read();
                int count = reader.GetInt32(0);
                reader.Close();
                conn.Close();
                return count;

            }
            public int GetTableLastIndex(string table, SqlConnection conn, string des)
            {
                int lastIndex;
                string findLastIndex = string.Format("SELECT MAX({0}),COUNT({0}) FROM {1}", des, table);
                conn.Open();
                SqlCommand command = new SqlCommand(findLastIndex, conn);
                SqlDataReader reader = command.ExecuteReader();
                reader.Read();
                if (reader.GetInt32(1) == 0)
                {
                    lastIndex = 0;
                }
                else
                {
                    lastIndex = reader.GetInt32(0);
                }
                reader.Close();
                conn.Close();
                return lastIndex;


            }
        }
    }



     


  • 相关阅读:
    【GC概述以及查看堆内存使用】Java内存管理和GC学习
    Spring的发展【一】
    struts ValueStack 详解
    Mybatis常见面试题(转)
    【Java基础】Java运算符优先级
    【Java基础】基本类型与运算【重要】
    【Java基础】JAVA不可变类(immutable)机制与String的不可变性
    【Java基础】Java基本数据类型与位运算
    【Tomcat】tomcat配置多域名和虚拟路径
    【Tomcat】Tomcat替换猫的图片
  • 原文地址:https://www.cnblogs.com/finallyliuyu/p/1532730.html
Copyright © 2011-2022 走看看