需求:

  我想要实现这样一个效果:用户可以在表中通过右键新建行、删除行(这两个后面再写),编辑数据后进行保存。这里保存需要做一个区分,就是新增的和修改的。他们的区别就是新增的主键为空,而修改的因为原本就存在于数据库中,所以是有主键的。

解决方案:

  方案1:就根据主键的区别来做。保存时,先获取当前行,判断是否有主键,如果没有主键直接保存为新行;如果有主键,修改数据库中原来的数据;

try
{
CasingProgramDAL dalCasingProgram = new CasingProgramDAL();
foreach (DataRow dr in dtCasingProgram.Rows)//循环查找到表中的每一行,判断是否有主键
{
//返回值如果大于0,则保存成功了
dalCasingProgram.SaveData(dr);//调用函数进行保存操作,我这里没有对其返回值进行判断
}
}
catch (Exception ex)
{
XtraMessageBox.Show(ex.Message, Properties.Resources.ErrorTitle);
}
 public int SaveData(DataRow dr)
{
using (DbOperHandler doh = new Common().Doh())
{
doh.Reset(); doh.AddFieldItem("WellID", CODS.Common.Well.JcWellID);
doh.AddFieldItem("CasingProgram", dr["CasingProgram"].ToString().Trim());
doh.AddFieldItem("BitDiameter", dr["BitDiameter"].ToString().Trim());
doh.AddFieldItem("DrillingDepth", dr["DrillingDepth"].ToString().Trim());
doh.AddFieldItem("MudDensity", dr["MudDensity"].ToString().Trim());
doh.AddFieldItem("CasingOD", dr["CasingOD"].ToString().Trim());
doh.AddFieldItem("CasingWallThick", dr["CasingWallThick"].ToString().Trim());
doh.AddFieldItem("CasingTopDepth", dr["CasingTopDepth"].ToString().Trim());
doh.AddFieldItem("CasingShoeDepth", dr["CasingShoeDepth"].ToString().Trim());
doh.AddFieldItem("CementReturnDepth", dr["CementReturnDepth"].ToString().Trim());
if (dr["ID"].ToString() == "")
{
//主键为空,新增记录
return doh.Insert("jcCasingProgram");
}
else
{
//更新记录
doh.ConditionExpress = "ID=" + dr["ID"].ToString().Trim();
return doh.Update("jcCasingProgram");
}
}
}

可是这样做的话,有主键的数据有修改的和没修改的,修改过得需要保存,没修改过得如果也保存的话虽然不会出错,但是终究比较浪费资源。而且如果数据量很大的话,这种弊端更为严重。毕竟用户一次修改量一般不会特别大。所以最好是对有主键的数据进行一下判断,于是有了方案2。

方案2:判断行的当前状态,如果是修改了的(Modified),则保存;否则不保存。

                if (dr["ID"].ToString()=="")
{//主键为空,新增记录
return doh.Insert("jcCasingProgram");
}
if (dr.RowState.ToString() == "Modified")
{//更新记录
doh.ConditionExpress = "ID=" + dr["ID"].ToString().Trim();
return doh.Update("jcCasingProgram");
}
return -;

或者也可以把新增数据的判断由判断其主键是否为空改为判断其当前状态是否为(Added)。

这样的话,就可以实现用户修改表时只对修改过得行进行保存了。

DataTable数据存储问题的更多相关文章

  1. WPF中Grid绑定DataTable数据。

    1.首先引用DocumentFormat.OpenXml.dll 2.然后新建一个OpenExcelHelper类,将Excel转化为Datatable. /// <summary>    ...

  2. Kooboo CMS技术文档之三:切换数据存储方式

    切换数据存储方式包括以下几种: 将文本内容存储在SqlServer.MySQL.MongoDB等数据库中 将站点配置信息存储在数据库中 将后台用户信息存储在数据库中 将会员信息存储在数据库中 将图片. ...

  3. Android之数据存储的五种方法

    1.Android数据存储的五种方法 (1)SharedPreferences数据存储 详情介绍:http://www.cnblogs.com/zhangmiao14/p/6201900.html 优 ...

  4. Android之网络数据存储

    一.网络保存数据介绍 可以使用网络来保存数据,在需要的时候从网络上获取数据,进而显示在App中. 用网络保存数据的方法有很多种,对于不同的网络数据采用不同的上传与获取方法. 本文利用LeanCloud ...

  5. Android之文件数据存储

    一.文件保存数据介绍 Activity提供了openFileOutput()方法可以用于把数据输出到文件中,具体的实现过程与在J2SE环境中保存数据到文件中是一样的.文件可用来存放大量数据,如文本.图 ...

  6. Android之SharedPreferences数据存储

    一.SharedPreferences保存数据介绍 如果有想要保存的相对较小键值集合,应使用SharedPreferences API.SharedPreferences对象指向包含键值对的文件并提供 ...

  7. Atitit 数据存储视图的最佳实际best practice attilax总结

    Atitit 数据存储视图的最佳实际best practice attilax总结 1.1. 视图优点:可读性的提升1 1.2. 结论  本着可读性优先于性能的原则,面向人类编程优先于面向机器编程,应 ...

  8. Android数据存储之SQLCipher数据库加密

    前言: 最近研究了Android Sqlite数据库(文章地址:Android数据存储之Sqlite的介绍及使用)以及ContentProvider程序间数据共享(Android探索之ContentP ...

  9. Android数据存储之GreenDao 3.0 详解

    前言: 今天一大早收到GreenDao 3.0 正式发布的消息,自从2014年接触GreenDao至今,项目中一直使用GreenDao框架处理数据库操作,本人使用数据库路线 Sqlite----> ...

随机推荐

  1. div的默认position值是静态的static

    div的默认position值是静态的static,如果相对父元素使用Position:absolute的话,需要手动在父元素上添加Position.

  2. /etc/profile文件被改坏导致命令不可用

    这几天在装一个软件,设置环境变量的时候,不小心把/etc/profile文件改坏了(就是没配置对),在source /etc/profile后导致所有命令都不可用了.出现如下报错: -bash: xx ...

  3. Groovy 设计模式 -- 迭代器模式

    Iterator Pattern http://groovy-lang.org/design-patterns.html#_flyweight_pattern 迭代器模式,允许顺序访问 聚集对象中的中 ...

  4. MySQL学习3 - 数据表的操作

    本节掌握 一.存储引擎(了解) 二.mysql支持的存储引擎 1.InnoDB 存储引擎 2.MyISAM 存储引擎 3.NDB 存储引擎 4.Memory 存储引擎 5.Infobright 存储引 ...

  5. 1120 机器人走方格 V3(组合数)

    题目实际上是求catalan数的,Catalan[n] = C(2*n,n) / (n+1) = C(2*n,n) % mod * inv[n+1],inv[n+1]为n+1的逆元,根据费马小定理,可 ...

  6. STM32-cJSON库的打包和解析

    这几天使用了一下JSON在STM32103平台上的使用,还是很好用的,在此记录下. JSON是啥我也不总结了,就是直观的看起来是一个有格式的字符串,看起来非常清楚明白,有点像Python中的dicit ...

  7. 【转】Java中文乱码的解决

    在基于Java的编程中,经常会碰到汉字的处里及显示的问题,比如一大堆乱码或问号. 这是因为JAVA中默认的编码方式是UNICODE,而中国人通常使用的文件和DB都是基于GB2312或者BIG5等编码, ...

  8. flutter 新增安卓ios 闪图

    ios 中新增闪图 flutter 中用xcode 打开 ios 项目 ios 在 Asset.xcassets中新增图片 如果 图片名称不一样需要修改配置文件 Contents.json 2.在安卓 ...

  9. pl/sql学习(4): 包package

    本文简单介绍包, 目前来看我用的不多, 除了之前 为了实现 一个procedure 的输出参数是结果集的时候用到过 package. 概念: 包是一组相关过程.函数.变量.常量和游标等PL/SQL程序 ...

  10. Jmeter性能测试之Monitor监控(SSHMon Samples Collector)

    前面写的一篇Monitor监控有缺陷, 这篇文章使用Jmeter4.0+的版本, 使用插件SSHMon Samples Collector来做资源监控 1. 官网下载插件: plugins-manag ...