DataSetToAccess

我们在做SmartClent应用时,总会用到服务器数据到本机数据的读写,为了简化应用,偶就写了个DataSet更新到ACCESS数据库的类,大家拍拍。
  1 ExpandedBlockStart.gif ContractedBlock.gif /**/ /***************************************
  2InBlock.gif*版权所有DvStudioDevGroups
  3InBlock.gif*创建人:David DvSoft@126.com
  4InBlock.gif*时间:  2006-08-20
  5InBlock.gif*版本:  v0.01
  6ExpandedBlockEnd.gif****************************************/

  7 None.gif using  System;
  8 None.gif using  System.Data;
  9 None.gif using  System.Data.OleDb;
 10 None.gif namespace  DvStudioSmartPOS
 11 ExpandedBlockStart.gifContractedBlock.gif dot.gif {
 12ExpandedSubBlockStart.gifContractedSubBlock.gif    /**//// <summary>
 13InBlock.gif    /// DataSetToAccess 的摘要说明。
 14InBlock.gif    /// 从传入的DataSet中将数据更新的Access的表中;
 15ExpandedSubBlockEnd.gif    /// </summary>

 16InBlock.gif    public class DataSetToAccess
 17ExpandedSubBlockStart.gifContractedSubBlock.gif    dot.gif{
 18InBlock.gif        private string ErrInfo = "";
 19InBlock.gif        public string ErrString
 20ExpandedSubBlockStart.gifContractedSubBlock.gif        dot.gif{
 21InBlock.gif            get
 22ExpandedSubBlockStart.gifContractedSubBlock.gif            dot.gif{
 23InBlock.gif                return ErrInfo;
 24ExpandedSubBlockEnd.gif            }

 25ExpandedSubBlockEnd.gif        }

 26InBlock.gif        public DataSetToAccess()
 27ExpandedSubBlockStart.gifContractedSubBlock.gif        dot.gif{
 28InBlock.gif            //
 29InBlock.gif            // TODO: 在此处添加构造函数逻辑
 30InBlock.gif            //
 31ExpandedSubBlockEnd.gif        }

 32ExpandedSubBlockStart.gifContractedSubBlock.gif        /**//// <summary>
 33InBlock.gif        /// 返回 连接字符串
 34InBlock.gif        /// </summary>
 35ExpandedSubBlockEnd.gif        /// <returns>返回 连接字符串</returns>

 36InBlock.gif        private string GetConnectStr()
 37ExpandedSubBlockStart.gifContractedSubBlock.gif        dot.gif{
 38InBlock.gif            DvStudioSmartPOS.GetConnectString ConnectStringObject = new GetConnectString();
 39InBlock.gif            return ConnectStringObject.GetConnectStr();
 40ExpandedSubBlockEnd.gif        }

 41ExpandedSubBlockStart.gifContractedSubBlock.gif        /**//// <summary>
 42InBlock.gif        /// 返回一个表中的所有列名称的集合
 43InBlock.gif        /// </summary>
 44InBlock.gif        /// <param name="TableName">要查询的表名</param>
 45InBlock.gif        /// <param name="ConnectObject">数据库连接对象</param>
 46ExpandedSubBlockEnd.gif        /// <returns>要查询的表中的所有列名称的集合</returns>

 47InBlock.gif        private string BuildingColumnsStr(string TableName,System.Data.OleDb.OleDbConnection ConnectObject)
 48ExpandedSubBlockStart.gifContractedSubBlock.gif        dot.gif{
 49InBlock.gif            System.Data.DataSet NewDataSet = new DataSet();
 50InBlock.gif            System.Data.OleDb.OleDbDataAdapter UpdateDataAdapter = new OleDbDataAdapter("Select * From " + TableName + " Where 1=2",ConnectObject);
 51InBlock.gif            UpdateDataAdapter.Fill(NewDataSet);
 52InBlock.gif            string ReturnStr = "";
 53InBlock.gif            for(int i = 0;i < NewDataSet.Tables[0].Columns.Count;i++)
 54ExpandedSubBlockStart.gifContractedSubBlock.gif            dot.gif{
 55InBlock.gif                string ColumnsNameStr = NewDataSet.Tables[0].Columns[i].ColumnName;
 56InBlock.gif                ReturnStr = ReturnStr + ColumnsNameStr.Trim() + ",";
 57ExpandedSubBlockEnd.gif            }

 58InBlock.gif            ReturnStr = ReturnStr.Remove(ReturnStr.Length-1,1);
 59InBlock.gif            return ReturnStr;
 60ExpandedSubBlockEnd.gif        }

 61ExpandedSubBlockStart.gifContractedSubBlock.gif        /**//// <summary>
 62InBlock.gif        /// 将数据更新到Access表中
 63InBlock.gif        /// </summary>
 64InBlock.gif        /// <param name="TempDataSet">1、传入的DataSet对象</param>
 65InBlock.gif        /// <param name="TableName">2、要更新的表名</param>
 66ExpandedSubBlockEnd.gif        /// <returns>返回布尔型变量,是否更新成功</returns>

 67InBlock.gif        public bool DataSetUpdaerToAccess(System.Data.DataSet TempDataSet,string TableName)
 68ExpandedSubBlockStart.gifContractedSubBlock.gif        dot.gif{
 69InBlock.gif            System.Data.OleDb.OleDbConnection ConnectObject = new OleDbConnection(GetConnectStr());
 70InBlock.gif            System.Data.OleDb.OleDbDataAdapter UpdateDataAdapter = new OleDbDataAdapter("Select " + BuildingColumnsStr(TableName,ConnectObject) +" From " + TableName + " Where 1=2",ConnectObject);
 71InBlock.gif            System.Data.OleDb.OleDbCommandBuilder CMDBuilder = new OleDbCommandBuilder(UpdateDataAdapter);
 72InBlock.gif            UpdateDataAdapter.InsertCommand = CMDBuilder.GetInsertCommand();
 73InBlock.gif            UpdateDataAdapter.DeleteCommand = CMDBuilder.GetDeleteCommand();
 74InBlock.gif            UpdateDataAdapter.UpdateCommand = CMDBuilder.GetUpdateCommand();
 75InBlock.gif            if(TempDataSet.Tables[TableName].Rows.Count < 1)
 76ExpandedSubBlockStart.gifContractedSubBlock.gif            dot.gif{
 77InBlock.gif                return true;
 78ExpandedSubBlockEnd.gif            }

 79InBlock.gif            else
 80ExpandedSubBlockStart.gifContractedSubBlock.gif            dot.gif{
 81InBlock.gif                try
 82ExpandedSubBlockStart.gifContractedSubBlock.gif                dot.gif{
 83InBlock.gif                    TempDataSet.Tables[TableName].Columns.Remove("总页数");
 84InBlock.gif                    TempDataSet.Tables[TableName].Columns.Remove("总行数");
 85InBlock.gif                    TempDataSet.Tables[TableName].Columns.Remove("总金额");
 86ExpandedSubBlockEnd.gif                }

 87InBlock.gif                catch(Exception e)
 88ExpandedSubBlockStart.gifContractedSubBlock.gif                dot.gif{
 89InBlock.gif                    ErrInfo = e.ToString();
 90ExpandedSubBlockEnd.gif                }

 91InBlock.gif                System.Data.DataSet NewDataSet = new DataSet();
 92InBlock.gif                UpdateDataAdapter.Fill(NewDataSet);
 93InBlock.gif                NewDataSet.Tables[0].TableName = TableName;
 94InBlock.gif                for(int i = 0;i < TempDataSet.Tables[TableName].Rows.Count;i++)
 95ExpandedSubBlockStart.gifContractedSubBlock.gif                dot.gif{
 96InBlock.gif                    DataRow AddRow =  NewDataSet.Tables[TableName].NewRow();
 97InBlock.gif                    for(int j = 0;j < NewDataSet.Tables[TableName].Columns.Count;j++)
 98ExpandedSubBlockStart.gifContractedSubBlock.gif                    dot.gif{
 99InBlock.gif                        string ColumnsNameStr = NewDataSet.Tables[TableName].Columns[j].ColumnName;
100InBlock.gif                        if(TempDataSet.Tables[TableName].Rows[i][ColumnsNameStr].ToString().Trim().Length > 0)
101ExpandedSubBlockStart.gifContractedSubBlock.gif                        dot.gif{
102InBlock.gif                            AddRow[ColumnsNameStr] = TempDataSet.Tables[TableName].Rows[i][ColumnsNameStr];
103ExpandedSubBlockEnd.gif                        }

104ExpandedSubBlockEnd.gif                    }

105InBlock.gif                    NewDataSet.Tables[TableName].Rows.Add(AddRow);
106ExpandedSubBlockEnd.gif                }

107InBlock.gif                try
108ExpandedSubBlockStart.gifContractedSubBlock.gif                dot.gif{
109InBlock.gif                    ConnectObject.Open();
110ExpandedSubBlockEnd.gif                }

111InBlock.gif                catch(Exception e)
112ExpandedSubBlockStart.gifContractedSubBlock.gif                dot.gif{
113InBlock.gif                    ErrInfo = e.ToString();
114ExpandedSubBlockEnd.gif                }

115InBlock.gif                try
116ExpandedSubBlockStart.gifContractedSubBlock.gif                dot.gif{
117InBlock.gif                    UpdateDataAdapter.Update(NewDataSet.Tables[TableName]);
118ExpandedSubBlockEnd.gif                }

119InBlock.gif                catch(Exception e)
120ExpandedSubBlockStart.gifContractedSubBlock.gif                dot.gif{
121InBlock.gif                    ErrInfo = e.ToString();
122InBlock.gif                    ConnectObject.Close();
123InBlock.gif                    return false;
124ExpandedSubBlockEnd.gif                }

125InBlock.gif                ConnectObject.Close();
126InBlock.gif                return true;
127ExpandedSubBlockEnd.gif            }

128ExpandedSubBlockEnd.gif        }

129ExpandedSubBlockEnd.gif    }

130ExpandedBlockEnd.gif}

131 None.gif
功能还不太完善,大家多拍砖;

转载于:https://www.cnblogs.com/sdav/archive/2006/08/26/486740.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值