C# asp.net WebForm 的三层架构配合ListView实现增删改查源码

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C# asp.net WebForm 的三层架构配合ListView实现增删改查源码相关的知识,希望对你有一定的参考价值。

因为对listview不太熟悉 所以需要借助源码来进行了解 大家谁有源码呀?我要的不是简单的增删改查 还有行编辑 是用事件实现的 比如说updating inserting等等 还有一个问题就是怎么在后台的事件中获得当前被编辑的实体对象(比如说在更新模板中我删除了一个字段,这样在更新的时候肯定会报错 所以就需要在updating事件中获得这个对象 然后在手动的赋值) 希望有对listview比较熟悉的知友能提供源码 或许提供思路也行 如果提供源码的知友希望能让功能全面一点(也就是能被使用的事件多一点 即使是没意义的也行)

如果满意的话 分都不是问题 您随便说 我修改财富就是了 谢谢大家了

C# asp.net WebForm 的三层架构配合ListView实现增删改查源码:
1、用Access新建一个表MResume,人事管理表:
ID 姓名 性别 出生日期 工作年限 证件类型 证件号 居住地 Email 手机号码 家庭电话 图片 自我评价
2、控件的使用:bindingNavigator(实现分页功能), dataGridView(显示数据)
在C# WinForm 中有这一个app.config的文件,这个文件的作用可以当作web程序中的webconfig文件。
这里面可以记录数据库连接字符串
Access下数据库连接函数:
public static OleDbConnection GetConnection()

OleDbConnection conn = null;
string strconnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + AppDomain.CurrentDomain.BaseDirectory + "database\\chinabase.mdb;Persist Security Info=True";
try

conn = new OleDbConnection(strconnectionString);

catch (Exception ex)

throw ex;

return conn;

3、把数据库中的数据读到dataGridView让这个控件来显示数据:
private void ResumeTest_Load(object sender, EventArgs e)

//手动代码把数据库中的数据显示出来
OleDbConnection conn = GetConnection();
string sqlText = "select 姓名,性别,出生日期,工作年限,证件类型,证件号,居住地,Email,手机号码,家庭电话,自我评价 from MResume order by id asc";
OleDbCommand cmd = new OleDbCommand(sqlText, conn);
try

conn.Open();
//int i = cmd.ExecuteNonQuery();
DataTable dt = new DataTable();
OleDbDataAdapter oda = new OleDbDataAdapter(sqlText, conn);
DataSet ds = new DataSet();
// oda.Fill(dt);
// dataGridView1.DataSource = dt;
oda.Fill(ds, "ds");

dtInfo.Clear();

//dtInfo = null;
dtInfo = ds.Tables[0];
InitDataSet(dtInfo); //初始化数据

catch (Exception ex)

MessageBox.Show(ex.ToString());

finally

conn.Close();

//设置GridView样式
// SetUpDataGridView();
dataGridView1.SelectionMode = DataGridViewSelectionMode.FullRowSelect; //使用户能够选择行
this.dataGridView1.EditMode = DataGridViewEditMode.EditProgrammatically; //双击不能修改了,这是通过编程的方式来修改单元格内容的
this.ComboxSelect.Items.Add("请选择类别");
this.ComboxSelect.Items.Add("姓名");
this.ComboxSelect.Items.Add("性别");
this.ComboxSelect.SelectedText = "请选择类别";

更新代码如下:
private void 修改ToolStripMenuItem_Click(object sender, EventArgs e)

dataGridView1_DoubleClick(sender, e);
//类似于dataGridView的更新操作,也就是双击操作

private void dataGridView1_CellMouseDown(object
DataGridViewCellMouseEventArgs e)

//判断如果点击的是鼠标右键
if (e.Button == MouseButtons.Right)

//判断鼠标点击在数据行上
if (e.RowIndex >= 0)

dataGridView1.ClearSelection();
dataGridView1.Rows[e.RowIndex].Selected = true;
dataGridView1.CurrentCell
dataGridView1.Rows[e.RowIndex].Cells[e.ColumnIndex];



删除代码如下:
public bool deletDataGridViewOneLine(object sender, EventArgs e)

bool result = false;
Int32 selectedRowCount
dataGridView1.Rows.GetRowCount(DataGridViewElementStates.Selected);
int selectedRow = dataGridView1.SelectedRows[0].Index; //获得选中的某行
string MName = dataGridView1.Rows[selectedRow].Cells[0].Value.ToString().Trim();
// MessageBox.Show(MName.ToString());
DialogResult dr = MessageBox.Show("确定要删除这条记录吗?", "提示", MessageBoxButtons.YesNo, MessageBoxIcon.Question);
if (dr == DialogResult.Yes)

if (MName != null && MName != "")

OleDbConnection conn = GetConnection();

string sqlText = "delete from MResume where 姓名=@MName";

OleDbCommand cmd = new OleDbCommand(sqlText, conn);

cmd.Parameters.AddWithValue("@MName", MName);
try

conn.Open();
int i = cmd.ExecuteNonQuery();
result = true;

catch (Exception ex)

MessageBox.Show("发生异常:" + ex.ToString(), "提示");

查询代码如下:

private void btnSelect_Click(object sender, EventArgs e)

//首先进行模糊查询
string strComboxSelect = ComboxSelect.Text.Trim();
string strSearch = txtSearch.Text.Trim();
if(strComboxSelect.Equals("请选择类别"))

MessageBox.Show("请选择类别!","提示");
return;

if (strSearch == "" || strSearch == null)

MessageBox.Show("请输入查询内容!", "提示");
return;

//手动代码把数据库中的数据显示出来
OleDbConnection conn = GetConnection();
string sqlText = "select 姓名,性别,出生日期,工作年限,证件类型,证件号,居住地,Email,手机号码,家庭电话,自我评价 from MResume where " + strComboxSelect + " like '%"+@strSearch+"%'";
OleDbCommand cmd = new OleDbCommand(sqlText, conn);
cmd.Parameters.AddWithValue("@strSearch", strSearch);
try

conn.Open();
//int i = cmd.ExecuteNonQuery();
DataTable dt = new DataTable();
OleDbDataAdapter oda = new OleDbDataAdapter(sqlText, conn);
oda.Fill(dt);
dataGridView1.DataSource = dt;

catch (Exception ex)

MessageBox.Show(ex.ToString());
参考技术A

半成品...看看吧

追问

webForm和winform 还是有区别的 我要的是webForm

追答

。。。没注意,web哪来的ListView啊?我怎么想,列表页面数据绑定也只有GridView和DataList还有reapter啊!这个是半年前的半成品了,拿去看吧

追问

亲 我要的是listview好不? 因为.net控件我真的是不想看 所以我只想掌握这一个控件 据说这一个控件是其他的所有数据控件的集合

参考技术B http://www.cnblogs.com/shangxia/archive/2011/12/01/2270373.html本回答被提问者采纳

以上是关于C# asp.net WebForm 的三层架构配合ListView实现增删改查源码的主要内容,如果未能解决你的问题,请参考以下文章

ASP.NET MVC 的三层架构 + EF数据模型

ASP.NET MVC 的三层架构 + EF数据模型

asp.net中的三层架构是啥意思?mvc设计模式是啥?它们之间有关系吗?

如何在asp.net C# Webform中制作像网格一样的Excel

Asp.net中WebForm 与 MVC的架构区别

沐雪微信|asp.net 微信源码 多用户平台 c# webform 源码