数据窗口中对记录进行单选或多选,进行删除操作
2015-01-14 11:10
246 查看
1、多选
在数据窗口控件的clicked事件中写入如下代码:
long lng_currentrow,lng_j
if row=0 then
return
else
lng_currentrow=row //当前鼠标点中行
end if
if keydown(keyshift!) then //按下SHIFT键
if i_lng_lastrow=0 then //上次没选中任何行
this.selectrow(lng_currentrow,true)
i_lng_lastrow=lng_currentrow //i_lng_lastrow为实例变量,记录上次点击行
else
this.selectrow(0,false) //全都不选中
if lng_currentrow>i_lng_lastrow then
for lng_j=i_lng_lastrow to lng_currentrow
this.selectrow(lng_j,true)
end for
else
for lng_j=i_lng_lastrow to lng_currentrow step -1
this.selectrow(lng_j,true)
end for
end if
end if
else
i_lng_lastrow=lng_currentrow
if keydown(keycontrol!) then //按下CTRL键
if this.isselected(lng_currentrow) then
this.selectrow(lng_currentrow,false)
else
this.selectrow(lng_currentrow,true)
end if
else //无任何键按下
this.selectrow(0,false)
this.selectrow(lng_currentrow,true)
end if
end if
在窗口的open事件中写入如下代码:
dw_1.object.datawindow.readonly=true
2、删除
long ll_Row, ll_Cnt
ll_Cnt = dw_1.RowCount()
if ll_Cnt > 0 then
for ll_Row = ll_Cnt to 1 step -1
if dw_1.IsSelected(ll_Row) then dw_1.deleterow(ll_Row)
next
// end for
end if
if messagebox("提示","确认删除吗?", Question!, YesNo!) = 1 then
dw_1.Update()
commit;
else //恢复删除的数据到数据窗口
long ll_rows
integer li_ret
ll_rows=dw_1.deletedcount() //统计在删除缓冲区的数据行
li_ret=dw_1.rowsmove(1,ll_rows,delete!,dw_1,1,primary!) //把要恢复删除的行从删除缓冲区移到主缓冲区
if li_ret=-1 then ll_rows=0 //当删除缓冲区数据为空时返回0
return ll_rows
end if
在数据窗口控件的clicked事件中写入如下代码:
long lng_currentrow,lng_j
if row=0 then
return
else
lng_currentrow=row //当前鼠标点中行
end if
if keydown(keyshift!) then //按下SHIFT键
if i_lng_lastrow=0 then //上次没选中任何行
this.selectrow(lng_currentrow,true)
i_lng_lastrow=lng_currentrow //i_lng_lastrow为实例变量,记录上次点击行
else
this.selectrow(0,false) //全都不选中
if lng_currentrow>i_lng_lastrow then
for lng_j=i_lng_lastrow to lng_currentrow
this.selectrow(lng_j,true)
end for
else
for lng_j=i_lng_lastrow to lng_currentrow step -1
this.selectrow(lng_j,true)
end for
end if
end if
else
i_lng_lastrow=lng_currentrow
if keydown(keycontrol!) then //按下CTRL键
if this.isselected(lng_currentrow) then
this.selectrow(lng_currentrow,false)
else
this.selectrow(lng_currentrow,true)
end if
else //无任何键按下
this.selectrow(0,false)
this.selectrow(lng_currentrow,true)
end if
end if
在窗口的open事件中写入如下代码:
dw_1.object.datawindow.readonly=true
2、删除
long ll_Row, ll_Cnt
ll_Cnt = dw_1.RowCount()
if ll_Cnt > 0 then
for ll_Row = ll_Cnt to 1 step -1
if dw_1.IsSelected(ll_Row) then dw_1.deleterow(ll_Row)
next
// end for
end if
if messagebox("提示","确认删除吗?", Question!, YesNo!) = 1 then
dw_1.Update()
commit;
else //恢复删除的数据到数据窗口
long ll_rows
integer li_ret
ll_rows=dw_1.deletedcount() //统计在删除缓冲区的数据行
li_ret=dw_1.rowsmove(1,ll_rows,delete!,dw_1,1,primary!) //把要恢复删除的行从删除缓冲区移到主缓冲区
if li_ret=-1 then ll_rows=0 //当删除缓冲区数据为空时返回0
return ll_rows
end if
相关文章推荐
- 在数据窗口中进行行选择操作
- PowerBuilder数据窗口实现单选与多选
- SQL删除、查找重复数据记录等操作
- 使用Struts2和jQuery EasyUI实现简单CRUD系统(六)——复选框进行多选删除操作
- 对于ListView中一次选择多条记录进行删除操作
- UITableView的编辑操作(移动&添加&删除-单选删除,或多选删除)
- js实现对选中的多条记录进行删除操作
- JPA学习笔记---JPA数据的操作:增加,删除,修改,获取,使用JPQL进行查询
- python对MySQL进行数据的插入、更新和删除之后需要commit,数据库才会真的有数据操作。(待日后更新)
- CSS+HTML实例集合三,用户自定义创建表格并删除指定行、列,对表格中的数据进行排序,radio单选摁扭之调查问卷、之选择题
- 实现对地址栏中的历史记录进行删除的操作,以及运行对话框的历史运行记录的删除.
- C#对DataGridView中的数据进行添加、修改、删除操作
- C#对DataGridView中的数据进行添加、修改、删除操作
- 通过Delete触发器对数据进行删除操作
- DataGridView进行添加、修改、删除数据操作-C#
- 对DataGridView进行添加、修改、删除数据操作----C#
- js实现对选中的多条记录进行删除操作
- 第2章_基本数据类型和基本操作_编程练习Exercise2.7通过创建窗口进行大小写的切换
- 复合数据窗口的子数据窗口进行相关编程操作
- 在不涉及数据库的情况下,对DataGridView中的数据进行删除操作