datagridview 选中行列表有两行记录,如何根据id过滤出其中一条记录?

C# sql数据库如何查下一条记录_百度知道
C# sql数据库如何查下一条记录
点查看下一条 就能从数据库中得到下一个记录 已绑定好了 就是SQL语句
我有更好的答案
按默认排序
this。然后后台绑定这个视图的数据;
分别查看上一条.MOVEPRE(),具体怎么做要看你的项目需求了~你可以把查询条件查询出来的所有记录再单独存到一个视图中.MOVENEXT()。在按钮 查看上一条
查看下一条的单击事件分别 用this我给你提供个思路
首先获得当前选项的表示ID 然后在此ID上加一或者减一就是下一条记录,当然还有判断下一条是否存在以免读取异常。
select top 1 * from 你的表 where 字段ID&1
点下一条 ID就+1
怎么不用DataGridView来显示
其他类似问题
您可能关注的推广回答者:回答者:
sql数据库的相关知识
等待您来回答
下载知道APP
随时随地咨询
出门在外也不愁SQL 分组后获取其中一个字段最大值的整条记录 - sz_bdqn的专栏
- 博客频道 - CSDN.NET
9302人阅读
&----------------------------------------------
--有id,name,createDate的一张表testTable
--根据name分组,获取每组中createDate最大的那条记录(整条)查询出来
----------------------------------------------
创建一张表,语句如下:
CREATE TABLE [dbo].[testTable]
[id] [int] NOT NULL IDENTITY(1, 1),
[name] [nchar] (10) COLLATE Chinese_PRC_CI_AS NULL,
[counts] [int] NULL,
[createDate] [datetime] NULL
-- Constraints and Indexes
ALTER TABLE [dbo].[testTable] ADD CONSTRAINT [PK_testTable] PRIMARY KEY CLUSTERED ([id])
插入测试数据:
insert into testTable(id,name,counts,createDate) values(1,'A
',20,'01 14 PM')
insert into testTable(id,name,counts,createDate) values(2,'A
',10,'02 14 PM')
insert into testTable(id,name,counts,createDate) values(3,'B
',20,'03 14 PM')
insert into testTable(id,name,counts,createDate) values(4,'B
',40,'04 14 PM')
insert into testTable(id,name,counts,createDate) values(5,'B
',10,'05 14 PM')
insert into testTable(id,name,counts,createDate) values(6,'C
',20,'06 14 PM')
insert into testTable(id,name,counts,createDate) values(7,'C
',40,'07 14 PM')
查询SQL语句:
select * from (
select id,name,counts,createDate,row_number() over(partition by name order by createDate desc) rn
from testTable
) t where t.rn &=1
结果如下:
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:596049次
积分:9861
积分:9861
排名:第644名
原创:392篇
转载:87篇
评论:162条
(11)(2)(3)(2)(7)(3)(3)(3)(6)(6)(3)(8)(10)(8)(7)(40)(8)(1)(7)(6)(2)(1)(1)(12)(11)(11)(18)(6)(4)(11)(10)(1)(1)(7)(1)(1)(3)(43)(30)(3)(8)(3)(6)(8)(3)(8)(6)(13)(4)(1)(6)(1)(1)(4)(10)(4)(7)(7)(3)(12)(21)(21)(1)数据表格 - DataGrid
继承$.fn.panel.defaults,使用$.fn.datagrid.defaults重载默认值。.
数据表格显示的数据以表格的形式,并提供了丰富的选择,排序,分组和编辑数据的支持。这个数据表格被设计以缩短开发时间,并要求开发商没有具体的知识。它是轻量级的,功能丰富的。单元格合并,多列标题,冻结列和页脚是其功能只是一小部分。
依赖组件(Dependencies)
使用方法(Usage Example)
从现有的表单元素创建数据表格,定义在html中的行,列和数据。
&class="easyui-datagrid"&&
&&&&&&&&&&
&&&&&&&&&&&&&data-options="field:'code'"Code&&
&&&&&&&&&&&&&data-options="field:'name'"Name&&
&&&&&&&&&&&&&data-options="field:'price'"Price&&
&&&&&&&&&&
&&&&&&&&&&
&&&&&&&&&&&&001name12323&&
&&&&&&&&&&
&&&&&&&&&&
&&&&&&&&&&&&002name24612&&
&&&&&&&&&&
通过&TABLE&标记创建的DataGrid。嵌套的&TH&标签定义的列的表。
&class="easyui-datagrid"&style="width:400height:250px"&&
&&&&&&&&data-options="url:'datagrid_data.json',fitColumns:true,singleSelect:true"&&
&&&&&&&&&&
&&&&&&&&&&&&&data-options="field:'code',width:100"Code&&
&&&&&&&&&&&&&data-options="field:'name',width:100"Name&&
&&&&&&&&&&&&&data-options="field:'price',width:100,align:'right'"Price&&
&&&&&&&&&&
使用JavaScript创建数据表格。
&id="dg"&&
$('#dg').datagrid({ &&
&&&&url:'datagrid_data.json', &&
&&&&columns:[[ &&
&&&&&&&&{field:'code',title:'Code',width:100}, &&
&&&&&&&&{field:'name',title:'Name',width:100}, &&
&&&&&&&&{field:'price',title:'Price',width:100,align:'right'} &&
查询数据填充数据表格。
$('#dg').datagrid('load',&{ &&
&&&&name:&'easyui', &&
&&&&address:&'ho'&&
数据更改与服务器交互,刷新当前数据。
$('#dg').datagrid('reload');&&&&&&
数据表格属性(DataGrid Properties)
属性继承控制面板,以下是数据表格独有的属性。
名称类型描述默认值
数据表格列配置对象,查看列属性以获取更多细节。
frozenColumns
跟列属性一样,但是这些列固定在左边,不会滚动。
fitColumns
设置为true将自动使列适应表格宽度以防止出现水平滚动。
autoRowHeight
定义设置行的高度,根据该行的内容。设置为false可以提高负载性能。
array,selector
数据表格顶部面板的工具栏。可能的值:1)数组,每个工具选项和链接按钮相同。2)选择显示的工具栏。在一个&div&的标签定义工具栏:
$('#dg').datagrid({
toolbar: '#tb'
&div id="tb"&
&a href="#" class="easyui-linkbutton" data-options="iconCls:'icon-edit',plain:true"/a&
&a href="#" class="easyui-linkbutton" data-options="iconCls:'icon-help',plain:true"/a&
通过数组定义工具栏:
$('#dg').datagrid({
toolbar: [{
iconCls: 'icon-edit',
handler: function(){alert('edit')}
iconCls: 'icon-help',
handler: function(){alert('help')}
设置为true将交替显示行背景。
请求远程数据的方法类型。
设置为true,当数据长度超出列宽时将会自动截取。
表明该列是一个唯一列。
一个用以从远程站点请求数据的超链接地址。
当从远程站点载入数据时,显示的一条快捷信息。
Processing, please wait &
pagination
设置true将在数据表格底部显示分页工具栏。
rownumbers
设置为true将显示行数。
singleSelect
设置为true将只允许选择一行。
checkOnSelect
如果为true,该复选框被选中/取消选中,当用户点击某一行上。如果为false,该复选框仅检查/取消选中,当用户点击完全的复选框。此属性是1.3版本。
selectOnCheck
如果设置为true,单击一个复选框,将始终选择行。如果为false,不会选择行选中该复选框。此属性是1.3版本。
pagePosition
&定义的分页栏的位置。可用的值有
'top','bottom','both'。此属性是可自1.3版本。
pageNumber
当设置分页属性时,初始化分页码。
当设置分页属性时,初始化每页记录数。
当设置分页属性时,初始化每页记录数列表。
[10,20,30,40,50]
queryParams
当请求远程数据时,发送的额外参数。
$('#dg').datagrid({
queryParams: {
name: 'easyui',
subject: 'datagrid'
当数据表格初始化时以哪一列来排序。
定义排序顺序,可以是'asc'或者'desc'(正序或者倒序)。
remoteSort
定义是否通过远程服务器对数据排序。
showFooter
定义是否显示行底(如果是做统计表格,这里可以显示总计等)。
返回样式,如:'background:red',function有2个参数:index:行索引,从0开始.row:对应于该行记录的对象。
$('#dg').datagrid({
rowStyler: function(index,row){
if (row.listprice&80){
return 'background-color:#6293BB;color:#';
定义如何从远程服务器加载数据。返回false可以取消该操作。这个函数接受以下参数:param:
参数对象传递到远程服务器。success(data):
回调函数将被调用成功检索的数据。error():回调函数将被调用失败时检索数据。
json loader
loadFilter
返回过滤的数据显示。该函数需要一个参数'data',表示原始数据。您可以更改源数据的标准数据格式。此函数必须返回标准数据对象中包含的&total&和&rows&的属性。
// removing 'd' object from asp.net web service json output
$('#dg').datagrid({
loadFilter: function(data){
if (data.d){
return data.d;
定义当编辑一行时的编辑模式。
predefined editors
定义数据表格的视图。
default view
列属性(Column Properties)
数据表格的列是一个对象数组,即这个对象中的元素也是一个数组(js中数组是对象)。 对象数组中的每一个元素都是可配置的对象,每个可配置对象定义一个列。
columns:[[ &&
&&&&{field:'itemid',title:'Item&ID',rowspan:2,width:80,sortable:true}, &&
&&&&{field:'productid',title:'Product&ID',rowspan:2,width:80,sortable:true}, &&
&&&&{title:'Item&Details',colspan:4} &&
&&&&{field:'listprice',title:'List&Price',width:80,align:'right',sortable:true}, &&
&&&&{field:'unitcost',title:'Unit&Cost',width:80,align:'right',sortable:true}, &&
&&&&{field:'attr1',title:'Attribute',width:100}, &&
&&&&{field:'status',title:'Status',width:60} &&
名称类型描述默认值
表明一个单元格跨几行。
表明一个单元格跨几列。
表明如何对其列数据,可选值:'left','right','center'。
设置为true允许对该列排序。
设置为true允许该列被缩放。
设置为true将隐藏列。
设置为true将显示复选框。
格式化单元格函数,有3个参数:value:字段的值。rowData:行数据。rowIndex:行索引。
$('#dg').datagrid({
columns:[[
{field:'userId',title:'User', width:80,
formatter: function(value,row,index){
if (row.user){
return row.user.
单元格样式函数,返回样式字符串装饰表格如'background:red',function有3个参数:value:字段值。rowData:行数据。rowIndex:行索引。
$('#dg').datagrid({
columns:[[
{field:'listprice',title:'List Price', width:80, align:'right',
styler: function(value,row,index){
if (value & 20){
return 'background-color:#ffee00;color:';
T自定义字段排序函数,有2个参数:a:该列的第一个值。b:该列的第二个值。
$('#dg').datagrid({
remoteSort: false,
columns: [[
{field:'date',title:'Date',width:80,sortable:true,align:'center',
sorter:function(a,b){
a = a.split('/');
b = b.split('/');
if (a[2] == b[2]){
if (a[0] == b[0]){
return (a[1]&b[1]?1:-1);
return (a[0]&b[0]?1:-1);
return (a[2]&b[2]?1:-1);
string,object
表明编辑类型。如果属性是字符串类型表示编辑类型,如果是对象则包含2个参数:type:字符串,编辑类型,可选值:text,textarea,checkbox,numberbox,validatebox,datebox,combobox,combotree。options:对象,对象于编辑类型的编辑器属性。
编辑器(Editor)
使用$.fn.datagrid.defaults.editors重载默认值。
每个编辑器都有以下方法:
名称属性描述
container, options
初始化编辑器并返回目标对象。
注销编辑器。
获取编辑框的值。
target , value
设置编辑框的值。
target , width
调整编辑器
如下代码将定义一个文本编辑器:
$.extend($.fn.datagrid.defaults.editors,&{
&&&&text:&{ &&
&&&&&&&&init:&function(container,&options){ &&
&&&&&&&&&&&&var&input&=&$('&input&type="text"&class="datagrid-editable-input"&').appendTo(container);
&&&&&&&&&&&&return& &&
&&&&&&&&}, &&
&&&&&&&&getValue:&function(target){ &&
&&&&&&&&&&&&return&$(target).val(); &&
&&&&&&&&}, &&
&&&&&&&&setValue:&function(target,&value){ &&
&&&&&&&&&&&&$(target).val(value); &&
&&&&&&&&}, &&
&&&&&&&&resize:&function(target,&width){ &&
&&&&&&&&&&&&var&input&=&$(target); &&
&&&&&&&&&&&&if&($.boxModel&==&true){ &&
&&&&&&&&&&&&&&&&input.width(width&-&(input.outerWidth()&-&input.width()));
&&&&&&&&&&&&}&else&{
&&&&&&&&&&&&&&&&input.width(width); &&
&&&&&&&&&&&&} &&
&&&&&&&&} &&
数据表格视图(DataGrid View)
使用$.fn.datagrid.defaults.view重载默认值。
视图是一个告诉数据表格如何呈现行记录的对象,对象必须定义以下方法:
名称属性描述
target, container, frozen
当数据载入时调用。target: DOM对象,数据网格对象。container: 行记录容器。frozen:
是否呈现固定容器。
renderFooter
target, container, frozen
这是一个可选函数用以展现行底。
target, fields, frozen, rowIndex, rowData
这是一个可选函数,它可以被render函数调用。
refreshRow
target, rowIndex
定义如何刷新指定的行。
onBeforeRender
target, rows
在视图被呈现之前触发。
onAfterRender
在视图被程序之后触发。
事件(Events)
事件继承控制面板,以下是数据表格独有的属性。
名称属性描述
onLoadSuccess
当数据载入成功时触发。
onLoadError
当载入远程数据发生错误时触发。
onBeforeLoad
在请求载入数据之前触发,如果返回false将取消载入。
onClickRow
rowIndex, rowData
当用户点击行时触发,参数如下:rowIndex:被点击的行索引,从0开始。rowData:对应于被点击的行的记录。
onDblClickRow
rowIndex, rowData
当用户双击一行时触发,参数如下:rowIndex:被点击的行索引,从0开始。rowData:对应于被点击的行的记录。
onClickCell
rowIndex, field, value
当用户点击单元格时触发。
onDblClickCell
rowIndex, field, value
当用户双击单元格时触发。
// when double click a cell, begin editing and make the editor get focus
$('#dg').datagrid({
onDblClickCell: function(index,field,value){
$(this).datagrid('beginEdit', index);
var ed = $(this).datagrid('getEditor', {index:index,field:field});
$(ed.target).focus();
onSortColumn
sort, order
当用户对列排序时触发,参数如下:sort:排序字段名称。order:排序顺序。
onResizeColumn
field, width
当用户调整列宽时触发。
rowIndex, rowData
当用户选择一行是触发,参数如下:rowIndex:被选择的行索引,从0开始。rowData:对应于被选择行的记录。
onUnselect
rowIndex, rowData
当用户取消选择一行时触发,参数如下:rowIndex:被取消选择的行索引,从0开始。rowData:对应于被取消选择行的记录。
onSelectAll
当用户选择所有行时触发。
onUnselectAll
当用户取消选择所有行时触发。
rowIndex,rowData
当用户选中行时触发,参数包含:rowIndex:选中行的索引,从0开始rowData:选中的行对应的记录此属性是1.3版本。
rowIndex,rowData
当用户取消选中行时触发,参数包含:rowIndex:取消选中行的索引,从0开始rowData:未经检查的行对应的记录此属性是1.3版本。
onCheckAll
当用户检查所有行时触发。此属性是1.3版本。
onUncheckAll
用户取消所有行时触发。此属性是1.3版本。
onBeforeEdit
rowIndex, rowData
当用户开始编辑一行时触发,参数如下:rowIndex:正在编辑的行索引,从0开始。rowData:对应于正在编辑的行的记录。
onAfterEdit
rowIndex, rowData, changes
当用户编辑完成时触发,参数如下:rowIndex:正在编辑的行索引,从0开始。rowData:对应于正在编辑的行的记录。changes:被改变的字段内容,对应方式为字段:值。
onCancelEdit
rowIndex, rowData
当用户取消编辑行时触发,参数如下:rowIndex:正在编辑的行索引,从0开始。rowData:对应于正在编辑的行的记录。
onHeaderContextMenu
当数据表格的列标题被鼠标右键单击时触发。
onRowContextMenu
e, rowIndex, rowData
当一行被鼠标右键单击时触发。
方法(Methods)
名称属性描述
返回属性对象。
返回页面对象。
返回控制面板对象。
getColumnFields
返回列字段,如果设置了frozen属性为true,将返回固定列的字段名。示例:
var opts = $('#dg').datagrid('getColumnFields'); // get unfrozen columns
var opts = $('#dg').datagrid('getColumnFields', true); // get frozen columns
getColumnOption
返回特定的列属性。
缩放和布局。
载入并显示第一页的记录,如果传递了'param'参数,它将会覆盖查询参数属性的值。通过传递一些参数,通常做一个查询,这个方法可以被称为从服务器加载新数据。
$('#dg').datagrid('load',{
code: '01',
name: 'name01'
重载记录,跟'load'方法一样但是重载的是当前页的记录而非第一页。
reloadFooter
重载行底记录。 示例:
// update footer row values and then refresh
var rows = $('#dg').datagrid('getFooterRows');
rows[0]['name'] = 'new name';
rows[0]['salary'] = 60000;
$('#dg').datagrid('reloadFooter');
// update footer rows with new data
$('#dg').datagrid('reloadFooter',[
{name: 'name1', salary: 60000},
{name: 'name2', salary: 65000}
显示载入状态。
隐藏载入状态。
fitColumns
让列宽自动适应数据表格的宽度。
fixColumnSize
固定列尺寸。如果&field' 参数未指定,将所有列的大小固定。
$('#dg').datagrid('fixColumnSize', 'name');
// fix the 'name' column size
$('#dg').datagrid('fixColumnSize');
// fix all columns size
fixRowHeight
固定特定列的高度。如果&index' 参数未指定,将所有列的高度固定。
autoSizeColumn
自动调整列宽,以适应内容。此方法是1.3版本特有的。
载入本地数据,旧记录将被移除。
返回已载入数据。
返回当前页的记录。
getFooterRows
返回行底记录。
getRowIndex
返回指定行的索引,row参数可以是行记录或者是一个id字段的值。
getChecked
返回所有行的复选框已被选中。此方法是1.3版本特有的。
getSelected
返回第一个被选择的行记录或null。
getSelections
返回所有被选择的行,当没有记录被选择时,将返回一个空数组。
clearSelections
取消所有的已选择项。
选择所有页面的行。
unselectAll
取消选择所有页面的行。
选择一行,行索引从0开始。
selectRecord
通过传递id参数来选择一行。
unselectRow
取消选择一行。
检查所有页面的行。此方法是1.3版本特有的。
uncheckAll
取消检查所有当前页面的行。此方法是1.3版本特有的。
检查行,行索引从0开始。此方法是1.3版本特有的。
uncheckRow
取消检查行,行索引从0开始。此方法是1.3版本特有的。
开始编辑一行。
结束编辑。
cancelEdit
取消编辑。
getEditors
获取指定行的编辑器,每个编辑器有如下属性:actions:编辑器可以做的行为。target:目标编辑器jQuery对象。field:字段名。type:编辑器类型。
获取特定的编辑器,options参数有2个属性:index:行索引。field:字段名。
// get the datebox editor and change its value
var ed = $('#dg').datagrid('getEditor', {index:1,field:'birthday'});
$(ed.target).datebox('setValue', '5/4/2012');
refreshRow
刷新一行。
validateRow
校验指定的行,如果有效返回true。
更新指定的行,param参数包含如下属性:index:要更新的行索引。row:新的行数据。
$('#dg').datagrid('updateRow',{
name: 'new name',
note: 'new note message'
添加一行。 新的行会被添加到最后一个位置:
$('#dg').datagrid('appendRow',{
name: 'new name',
note: 'some messages'
插入一个新行,param参数包含如下属性:index:要插入的行索引,如果没有定义则在最后面添加一个新行。row:行数据。
// insert a new row at second row position
$('#dg').datagrid('insertRow',{
index: 1, // index start with 0
name: 'new name',
note: 'some messages'
删除一行。
getChanges
获取从最后一次提交开始的被修改的所有行,type参数表明修改的类型,可选值:inserted,deleted,updated等 。当没有传递type参数时,返回所有被修改的行。
acceptChanges
提交所有修改的数据,提交后的数据将不能再修改或者回滚。
rejectChanges
回滚自创建以来或自上次调用AcceptChanges,所有的变化数据。
mergeCells
合并单元格,options参数包含如下属性:index:行索引。field:字段名。rowspan:整合单元格要跨的行数。colspan:整合单元格要跨的列数。
showColumn
显示特定的列。
hideColumn
隐藏特定的列。
/////////////////////////////////////////////
//初始化数据
function initGrid()
$('#grid').datagrid({
width:'100%',
height:'auto',
nowrap: true,
striped: true,
fitColumns:false,
url:'${contextPath}/cardGift/cardGift.do?method=getCardGiftList&activeId=${information.cardGiftActive.activeId}',
queryParams:queryParam,
remoteSort:false,
//Grid对应的主键列
idField:'',
singleSelect:true,
columns:[[
{field:'serial',title:'',width:15,checkbox:true},
{field:'activeName',title:'活动名称',width:50,sortable:true},
{field:'giftGoodId',title:'赠品商品编码',width:80},
{field:'goodsName',title:'商品名称',width:120},
{field:'giftCodeTotal',title:'赠品码生成数量',width:100},
{field:'genCodeNumber',title:'已生成赠品码数量',width:100},
{field:'startTime',title:'赠品发放起始时间',width:125},
{field:'endTime',title:'赠品发放结束时间',width:125},
{field:'memo',title:'备注',width:120}
pagination:true,
rownumbers:true,
id:'btnClearSelections',
text:'修改活动商品',
iconCls:'icon-edit',
handler:function(){
editData();
id:'btnDel',
text:'删除活动商品',
iconCls:'icon-no',
handler:function(){
deleteData();
id:'btnClearSelections',
text:'清除选择',
iconCls:'icon-cut',
handler:function(){
$('#grid').datagrid('clearSelections');
//设置选中值
document.addForm.reset();
$('#giftCodeTotal').val("0");
$('#memoData').html("");
$('#submitBtn').html("确认提交");
$('#submitBtn').attr('onclick',"addSubmit('insert');");
onLoadError:function(){
XW_dialog.alert('','加载数据失败!');
//设置分页控件
var p = $('#grid').datagrid('getPager');
$(p).pagination(PAGE_TEMPLATE);
function editData(){
var row = $('#grid').datagrid("getSelections");
if($(row).length & 1 || $(row).length & 1)
XW_dialog.alert('',"请选择要查看的记录,只能选取单行!");
//设置默认选中
$('#goodsSelect').combogrid('grid').datagrid('selectRecord',row[0].giftGoodId);
$('#goodsSelect').hide();
//设置选中值
$('#giftCodeTotal').val(row[0].giftCodeTotal);
$('#memoData').html(row[0].memo);
$('#submitBtn').html("更新");
$('#submitBtn').attr('onclick',"addSubmit('update');");
$('#resetBtn').hide();
function deleteData(){
var data = $('#grid').datagrid("getSelections");
var delurl = "${contextPath}/cardGift/cardGift.do?method=deleteCardGift&activeId="+data[0].activeId+"&giftGoodId="+data[0].giftGoodId;
//发送删除请求
type: "POST",
dataType:'json',
url: delurl,
success: function(msg){
if(msg.success)
//保存回调函数使用的数据
XW_dialog.addData('callbackData',msg.map);
//删除成功
XW_dialog.tips(msg.errorMsg, 3);
deleteCallBack();
XW_dialog.alert('',msg.errorMsg);
//删除记录回调函数,默认调用刷新记录方法,
function deleteCallBack(){
reloadGrid("grid");
阅读(...) 评论()在dataGridView如何删除选定的某行记录?
[问题点数:20分]
在dataGridView如何删除选定的某行记录?
[问题点数:20分]
不显示删除回复
显示所有回复
显示星级回复
显示得分回复
只显示楼主
相关帖子推荐:
本帖子已过去太久远了,不再提供回复功能。}

我要回帖

更多关于 datagridview绑定数据 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信