客户提出对报表填报值进行过的修改信息希望能保存到数据库中,形成记录以备查询操作记录。

原理分析:

填报值 进行 修改时 只需通过异步方式触发 将相关数据保存入库即可。

这里我们可以分别用_bindingEditor(),_cellValueChanged,以及ajax 实现上面的需求。

操作步骤:

第一、 利用光标定位事件 获取 单元格 旧值 赋值给公共变量最终传递给值修改事件(在_cellValueChanged中单元格的值已经发生了改变 无法获取到旧值)。

var tempValue="";

function _bindingEditor( cell ){

var table = _lookupTable( cell );

if( ! _submitEditor( table ) ) return; //

var editor = _lookupEditor( table, cell );

table.currEditor = editor;

_setEditorStyle(editor,cell );

tempValue+=cell.value+'&'; //旧值通过 公共变量传递到 触发事件中

};

第二、 在 值修改事件中获取旧值 最终异步保存数据

function _cellValueChanged(cell){

var strs= new Array();

strs=tempValue.split("&");

var oldValue=strs[strs.length-2];

tempValue=strs[strs.length-1]+'&';

var newValue=cell.value;

doSave(oldValue,newValue);

}

第三 简单ajax 保存数据

function doSave(oldValue,newValue){

$.ajax({

type: "POST",

url: "save.jsp",

data: "oldValue="+oldValue+"&newValue="+newValue,

success: function(){

alert("数据已保存!");

}

});

}

后台业务逻辑由 save.jsp完成。

……

Statement stmt =conn.createStatement();

//要执行的sql语句

String sql = "INSERT INTO updatelog (id,username, oldvalue,newvalue,updatetime) VALUES ('"+id+"','"+name+"','"+oldValue+"','"+newValue+"','"+date1+"') ";

System.out.println("sql="+sql);

int t = stmt.executeUpdate(sql);

……