如何让winfrom的datagridview行数据上下移动

zl4460072 2010-03-19 02:51:12
我百度了半天也没有正确的方法,特来求教啦
代码:

private void button1_Click(object sender, EventArgs e)
{
string connStr = "server=localhost;database=zilong;uid=root;pwd=4460072";
using (MySqlConnection conn = new MySqlConnection(connStr))
{
ds = new DataSet();
string sql = "select * from student ";
MySqlDataAdapter da = new MySqlDataAdapter(sql,conn);
da.Fill(ds,"stu");
dataGridView1.DataSource = ds;
dataGridView1.DataMember = "stu";
}
}

private void button2_Click(object sender, EventArgs e)
{
string s = dataGridView1.CurrentRow.Index.ToString();
label1.Text = s;
....
}

怎么样按了button2可以让当前选中的行数据整体移动呢???
...全文
476 18 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
18 条回复
切换为时间正序
请发表友善的回复…
发表回复
chenjunhui00 2011-07-20
  • 打赏
  • 举报
回复
[Quote=引用 14 楼 wxm3630478 的回复:]
打不开,帮你全部复制下来
C# code

/*DataGridView 实现行[Row]的上下移动,我这里用到了SelectedRows[0],而没用CurrentRow是有原因的
主要是这两段代码:
dataGridView1.Rows[rowIndex - 1].Selected = true;
dataGridView1.Rows[rowIn……
[/Quote]
zouzouol 2010-08-31
  • 打赏
  • 举报
回复
学习,学习
清涵编程 2010-06-15
  • 打赏
  • 举报
回复
学习 了啊
zilong4460072 2010-03-19
  • 打赏
  • 举报
回复

public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}

private DataTable dt;
private void Form1_Load(object sender, EventArgs e)
{
string connStr = "server=localhost;database=zilong;uid=root;pwd=4460072";
using (MySqlConnection conn = new MySqlConnection(connStr))
{
dt = new DataTable();
string sql = "select * from student ";
MySqlDataAdapter da = new MySqlDataAdapter(sql, conn);
da.Fill(dt);
dataGridView1.DataSource = dt;
}
}


//上移
private void button2_Click(object sender, EventArgs e)
{
int rowIndex = dataGridView1.CurrentRow.Index;
if (rowIndex == 0)
{
MessageBox.Show("这已经是第一行了");
return;
}
List<string> list = new List<string>();
for (int i = 0; i < dataGridView1.Columns.Count; i++)
{
list.Add(dataGridView1.SelectedRows[0].Cells[i].Value.ToString()); //把当前选中行的数据存入list数组中
}
for (int j = 0; j < dataGridView1.Columns.Count; j++)
{
dataGridView1.Rows[rowIndex].Cells[j].Value = dataGridView1.Rows[rowIndex - 1].Cells[j].Value;
dataGridView1.Rows[rowIndex - 1].Cells[j].Value = list[j].ToString();
}
dataGridView1.Rows[rowIndex - 1].Selected = true;
dataGridView1.Rows[rowIndex].Selected = false;


}
}
wxm3630478 2010-03-19
  • 打赏
  • 举报
回复
打不开,帮你全部复制下来

/*DataGridView 实现行[Row]的上下移动,我这里用到了SelectedRows[0],而没用CurrentRow是有原因的
主要是这两段代码:
dataGridView1.Rows[rowIndex - 1].Selected = true;
dataGridView1.Rows[rowIndex].Selected = false;
这两行代码大家因该都能看懂,移上去的哪行选中状态,移下去的的取消选中状态.
如果我用dataGridView1.CurrentRow.Cell[0].Value 他取得的值仍然是rowIndex索引行的值

要使用SelectedRows[0] ,就必须设置这个属性:dataGridView1.SelectionMode = DataGridViewSelectionMode.FullRowSelect;

实现原理:就是上下两行,把单元格中的值进行交换...呵呵表面上看去是向上,下移动了

不知道大家还有什么好的选中方法没...请多多指教

*/

private void Form3_Load(object sender, EventArgs e)
{
//........得到DataTable的代码省略....
dataGridView1.DataSource = dt;
}

private void button1_Click(object sender, EventArgs e) //向上移动
{
int rowIndex = dataGridView1.SelectedRows[0].Index; //得到当前选中行的索引

if(rowIndex == 0)
{
MessageBox.Show("已经是第一行了!");
return;
}

List<string> list = new List<string>();
for (int i = 0; i < dataGridView1.Columns.Count; i++)
{
list.Add(dataGridView1.SelectedRows[0].Cells[i].Value.ToString()); //把当前选中行的数据存入list数组中
}

for (int j = 0; j < dataGridView1.Columns.Count; j++)
{
dataGridView1.Rows[rowIndex].Cells[j].Value = dataGridView1.Rows[rowIndex - 1].Cells[j].Value;
dataGridView1.Rows[rowIndex - 1].Cells[j].Value = list[j].ToString();
}
dataGridView1.Rows[rowIndex - 1].Selected = true;
dataGridView1.Rows[rowIndex].Selected = false;
}

private void button2_Click(object sender, EventArgs e) //向下移动
{
int rowIndex = dataGridView1.SelectedRows[0].Index; //得到当前选中行的索引

if (rowIndex == dataGridView1.Rows.Count -1)
{
MessageBox.Show("已经是最后一行了!");
return;
}

List<string> list = new List<string>();
for (int i = 0; i < dataGridView1.Columns.Count; i++)
{
list.Add(dataGridView1.SelectedRows[0].Cells[i].Value.ToString()); //把当前选中行的数据存入list数组中
}

for (int j = 0; j < dataGridView1.Columns.Count; j++)
{
dataGridView1.Rows[rowIndex].Cells[j].Value = dataGridView1.Rows[rowIndex + 1].Cells[j].Value;
dataGridView1.Rows[rowIndex + 1].Cells[j].Value = list[j].ToString();
}
dataGridView1.Rows[rowIndex + 1].Selected = true;
dataGridView1.Rows[rowIndex].Selected = false;
}

//http://blog.csdn.net/wxm3630478/archive/2009/06/10/4256851.aspx
JOCLI 2010-03-19
  • 打赏
  • 举报
回复
用bindingsource吧
给你段代码,保证你解决问题

BindingSource bs = new BindingSource();
private void ProgramList_Load(object sender, EventArgs e)
{
SqlConnection con = DBCON.SqlConnettion();
string sql="select * from SystemUpdateHis";
SqlDataAdapter sdp = new SqlDataAdapter(sql, con);
con.Open();
DataSet ds = new DataSet();
sdp.Fill(ds, "SystemUpdateHis");
bs.DataSource = ds;
bs.DataMember = "SystemUpdateHis";
con.Close();
dataGridView1.DataSource = bs;
}

private void 下一笔_Click(object sender, EventArgs e)
{
bs.MoveNext();
}

private void 上一笔_Click(object sender, EventArgs e)
{
bs.MovePrevious();
}
zl4460072 2010-03-19
  • 打赏
  • 举报
回复
[Quote=引用 10 楼 wxm3630478 的回复:]
哇 100分 要发个
http://blog.csdn.net/wxm3630478/archive/2009/06/10/4256851.aspx
[/Quote]
这个链接打开了 看不到的阿
zl4460072 2010-03-19
  • 打赏
  • 举报
回复
[Quote=引用 10 楼 wxm3630478 的回复:]
哇 100分 要发个
http://blog.csdn.net/wxm3630478/archive/2009/06/10/4256851.aspx
[/Quote]
话都不说 直接来个链接阿?
wxm3630478 2010-03-19
  • 打赏
  • 举报
回复
zl4460072 2010-03-19
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 criedshy 的回复:]
引用 3 楼 zl4460072 的回复:
我只是想让显示的数据上下移动,而不是数据库里的数据移动,可以实现吗?


可以实现啊
[/Quote]
dataGridView1.Rows.Insert( index + 1, dr );

报错:无法想绑定的datagridview添加数据。。。。
zl4460072 2010-03-19
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 criedshy 的回复:]
引用 3 楼 zl4460072 的回复:
我只是想让显示的数据上下移动,而不是数据库里的数据移动,可以实现吗?


可以实现啊
[/Quote]
你的这个代码实现的是让所选中的行移动吧?
我请教的是行里的数据移动诶,还请再劳驾想象办法哦
zl4460072 2010-03-19
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 criedshy 的回复:]
引用 3 楼 zl4460072 的回复:
我只是想让显示的数据上下移动,而不是数据库里的数据移动,可以实现吗?


可以实现啊
[/Quote]
就这5个字阿。。。
小弟不是来请赐教了嘛。。。。。。
criedshy 2010-03-19
  • 打赏
  • 举报
回复
//下移一行
private void button2_Click( object sender, EventArgs e )
{

DataGridViewRow dr = dataGridView1.CurrentRow;
if ( dr.Index < dataGridView1.Rows.Count - 1 )
{
int index = dr.Index;
dataGridView1.Rows.Remove( dr );
dataGridView1.Rows.Insert( index + 1, dr );

dr.Selected = true;
dataGridView1.CurrentCell = dr.Cells[0];
}
}

//上移一行
private void button3_Click( object sender, EventArgs e )
{

DataGridViewRow dr = dataGridView1.CurrentRow;

if ( dr.Index > 0 )
{
int index = dr.Index;
dataGridView1.Rows.Remove( dr );
dataGridView1.Rows.Insert( index - 1, dr );

dr.Selected = true;
dataGridView1.CurrentCell = dr.Cells[0];
}
}

//首行
private void button4_Click( object sender, EventArgs e )
{
if ( dataGridView1.CurrentRow.Index != 0 )
{
DataGridViewRow dr = dataGridView1.CurrentRow;
dataGridView1.Rows.Remove( dr );
dataGridView1.Rows.Insert(0, dr );

dr.Selected = true;
dataGridView1.CurrentCell = dr.Cells[0];
}
}

//末行
private void button5_Click( object sender, EventArgs e )
{
if ( dataGridView1.CurrentRow.Index <dataGridView1.Rows.Count-1 )
{
DataGridViewRow dr = dataGridView1.CurrentRow;
dataGridView1.Rows.Remove( dr );
dataGridView1.Rows.Insert( dataGridView1.Rows.Count , dr );

dr.Selected = true;
dataGridView1.CurrentCell = dr.Cells[0];
}
}



criedshy 2010-03-19
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 zl4460072 的回复:]
我只是想让显示的数据上下移动,而不是数据库里的数据移动,可以实现吗?
[/Quote]

可以实现啊
zl4460072 2010-03-19
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 changling_wang 的回复:]
换里面的数据就可以了~!
[/Quote]
怎么个换法呀??
zl4460072 2010-03-19
  • 打赏
  • 举报
回复
我只是想让显示的数据上下移动,而不是数据库里的数据移动,可以实现吗?
Return门徒 2010-03-19
  • 打赏
  • 举报
回复
你想把控件的布局方式改变~!太麻烦了吧~!换里面的数据就可以了~!
Return门徒 2010-03-19
  • 打赏
  • 举报
回复
换里面的数据就可以了~!
第2章 QQ企业通    2.1 设计思路 28   2.2 关键技术 28   2.2.1 INI文件的应用 28   2.2.2 线程的应用 30   2.2.3 在Socket中发送大容量的消息 30   2.2.4 将流序列化或反序列化为对象 31   2.2.5 用InnerList列表记录信息 31   2.3 设计过程 32   2.3.1 类库的设计 33   2.3.2 客户端注册模块设计 40   2.3.3 客户端登录模块设计 42   2.3.4 客户端QQ模块设计 43   2.3.5 客户端消息发送模块设计 48   2.3.6 服务器端控制台模块设计 52 第3章 SQL数据表提取器模块    3.1 概述 56   3.2 关键技术 56   3.2.1 如何备份数据库 56   3.2.2 如何还原数据库 57   3.2.3 如何附加数据库 58   3.2.4 如何分离数据库 59   3.2.5 设置数据库模式 59   3.3 设计过程 61   3.3.1 主窗体 61   3.3.2 获取服务器名称 62   3.3.3 获取所有数据库 63   3.3.4 获取所有数据表 64   3.3.5 备份数据库 66   3.3.6 还原数据库 67   3.3.7 附加数据库 68   3.3.8 分离数据库 70   3.3.9 导出表结构 71   3.3.10 导出数据 74 第4章 万能搜索模块    4.1 设计思路 80   4.2 关键技术 80   4.2.1 如何制作一个接口程序 80   4.2.2 实现接口程序的信息互传 80   4.2.3 如何将接口程序加载到其他程序中 82   4.2.4 怎样操作RichtextBox控件的选择文本 82   4.2.5 如何获取数据表中字段的描述信息 83   4.3 设计过程 83   4.3.1 获取数据表中字段的中文信息 84   4.3.2 添加数据表的查询条件 86   4.3.3 向SQL语句中添加括号 89   4.3.4 查询生成后的SQL语句 90   4.3.5 主程序获得接口信息 92 第5章 万能打印模块    5.1 设计思路 94   5.2 关键技术 94   5.2.1 打印设置(PrintDocument类) 94   5.2.2 打印预览对话框(PrintPreview Dialog) 95   5.2.3 打印对话框(PrintDialog) 96   5.2.4 获取指定颜色值和字体样式 97   5.2.5 DataGridView控件的相关应用 97   5.3 设计过程 98   5.3.1 打印信息的设置 98   5.3.2 表格样式的设置 100   5.3.3 打印类的设置 101   5.3.4 打印数据信息 108 第6章 决策分析模块    6.1 设计思路 112   6.2 关键技术 112   6.2.1 游标的基本操作 112   6.2.2 存储过程的基本操作 115   6.2.3 透视表的基本概念 117   6.2.4 统计表的基本操作 117   6.2.5 单击显示右键菜单 118   6.3 设计过程 118   6.3.1 主窗体的初始化 119   6.3.2 透视表的筛选 127   6.3.3 透视表的设计 130   6.3.4 统计表的设计 132 第7章 自定义图表控件    7.1 设计思路 136   7.2 关键技术 137   7.2.1 控件的生成 137   7.2.2 如何在项目中添加控件 137   7.2.3 在“属性”对话框中添加属性 137   7.2.4 用GDI+绘制图形 139   7.2.5 如何在控件上绘制图形 143   7.2.6 获取扇形外弧中心点的位置 143   7.3 设计过程 144   7.3.1 向自定义控件中添加属性 144   7.3.2 获取绘制图表的初始值数据 149   7.3.3 绘制标签框 153   7.3.4 绘制图表中的表格 157   7.3.5 绘制条形图 163   7.3.6 绘制面形图 170   7.3.7 绘制饼形图 174 第8章 电子邮件收发模块    8.1 概述 180   8.2 关键技术 180   8.2.1 Base64编码格式 180   8.2.2 SMTP服务 181   8.2.3 POP3协议 184   8.2.4 使用Jmail组件接收邮件 186   8.2.5 邮件发送类的使用 188   8.2.6 使用正则表达式验证邮件格式 190   8.3 设计过程 191   8.3.1 数据库设计 191   8.3.2 系统登录 191   8.3.3 邮件发送实现 192   8.3.4 为邮件上传多个附件 193   8.3.5 邮件接收实现 194   8.3.6 查看邮件详细信息 196   8.3.7 下载附件的实现 197   8.3.8 删除邮件实现 198   8.3.9 用户管理 198 第9章 短信群发模块    9.1 设计思路 202   9.2 关键技术 202   9.2.1 短信猫中API函数的使用 202   9.2.2 短信猫中的短信接收格式 205   9.2.3 窗体间的互操作 205   9.2.4 锁定模块主窗体 206   9.2.5 使用ADO.NET连接Access数据库 206   9.3 设计过程 207   9.3.1 数据库设计 207   9.3.2 群发短信实现 209   9.3.3 已发送短信管理 213   9.3.4 接收短信实现 215   9.3.5 常用联系人管理 219   9.3.6 常用短语管理 221 第10章 桌面精灵模块    10.1 概述 226   10.2 关键技术 226   10.2.1 阴阳历转换算法 226   10.2.2 调用系统API实现鼠标穿透效果 230   10.2.3 修改注册表控制程序开机自启动 231   10.2.4 通过控制窗体透明度实现日历透明显示效果 231   10.2.5 拖动无标题栏窗体 232   10.2.6 将窗体的关闭位置写入到注册表中 232   10.2.7 将程序图标写入到托盘 232   10.3 设计过程 233   10.3.1 桌面精灵模块公共类设计 233   10.3.2 当前日期的农历、天干地支年、节日及星座显示 235   10.3.3 定时提醒的实现 240   10.3.4 日历窗体效果控制 242   10.3.5 转到某天、某周、某月及某年的实现 243   10.3.6 节日管理 245   10.3.7 提醒管理 249 第11章 文件批量处理器    11.1 概述 256   11.2 关键技术 256   11.2.1 文件流技术 256   11.2.2 文件解压缩技术 258   11.2.3 获取系统文件及文件夹图标 262   11.2.4 获取指定目录下的所有文件及文件夹 265   11.2.5 Word操作技术 266   11.2.6 进度条的显示 266   11.2.7 对ListView控件中的项进排序 267   11.3 设计过程 267   11.3.1 主窗体预览 267   11.3.2 批量复制、剪切文件 268   11.3.3 批量复制、剪切文件夹 270   11.3.4 批量重命名文件 271   11.3.5 批量删除文件及文件夹 275   11.3.6 搜索文件及文件夹 276   11.3.7 批量压缩、解压文件 278   11.3.8 分割、合并文件 280 第12章 图片管理工具模块    12.1 概述 286   12.2 关键技术 286   12.2.1 上下移动ListBox选中项 286   12.2.2 将文件复制到剪切板 287   12.2.3 格式转换 288   12.2.4 图片幻灯片 288   12.2.5 图片旋转 289   12.3 设计过程 290   12.3.1 主窗体 290   12.3.2 打开图片目录 291   12.3.3 图片格式转换 292   12.3.4 设为桌面背景 294   12.3.5 图片特效 296   12.3.6 图片调节 300   12.3.7 图片水印 304   12.3.8 幻灯片放映 306   12.3.9 图片打印 308 、

111,098

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • AIGC Browser
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧