DataGridView绑定数据源
给DataGridView绑定数据源比較简单,方法主要有两种:
1、直接在控件属性中绑定数据源,这样的方法最简单,但它是直接连接数据库的,这样就和传DataTable的后果差点儿相同了,所以还是尽量避开吧。
2、通过代码将实体集合作为DataGridView的数据源,如今以《添加删除用户》窗口为例来简介下
窗口界面
功能介绍:当用户级别改变时,表格控件中显示该用户级别的用户信息
编辑控件:右击控件选中“加入列”——进行列的加入和编辑,编辑时须要用的仅仅有三个
(1)是列名,这个可改可不改(2)是与实体中相应的属性名称(3)是表头信息,这三个也能够在代码中写。假设不设置Name属性,在载入数据的时候将自己主动改为作为数据源的实体的属性名,在删除不须要字段的时候能够用得着。
U层代码
Private Sub cboLevel_SelectedIndexChanged(sender As Object, e As EventArgs) Handles cboLevel.SelectedIndexChanged
Dim euserIn As New E_UserInfo
Dim bselectUser As New B_AddRemoveUser
Dim userList As New List(Of E_UserInfo)
'Dim userBindList As New BindingList(Of E_UserInfo) '将BindingList作为数据源遇到问题,先省略 euserIn.Level = cboLevel.GetItemText(cboLevel.SelectedItem) '获取用户级别组合框的当前文本,并传递给E层
userList = bselectUser.SelectUserInfo(euserIn) '将查询到的信息保存在euserStore中 '假设集合中没有记录,退出该过程
If userList.Count = 0 Then
Exit Sub
End If dtgUserInfo.AutoGenerateColumns = False '不同意自己主动加入列
dtgUserInfo.DataSource = userList '把泛型集合当做DataGridView的数据源 '删除不须要显示的字段
dtgUserInfo.Columns.Remove("Password")
dtgUserInfo.Columns.Remove("Level") '将DataGridView的标题改为中文,在控件属性中已经设置,这里就能够省去了
'dtgUserInfo.Columns(0).HeaderText = "username"
'dtgUserInfo.Columns(1).HeaderText = "姓名"
'dtgUserInfo.Columns(4).HeaderText = "开户人" End Sub
B层代码
Imports Entity.entity
Imports DAL.dal
Imports System.Collections
Public Class B_AddRemoveUser
Public Function SelectUserInfo(ByVal user As E_UserInfo) As IList
Dim userList As New List(Of E_UserInfo)
Dim dUser As New D_UserDAO userList = dUser.SelectUserInfo(user) '将用户信息传入D层 Return userList '返回用户信息
End Function Public Function DeleteUser(ByVal user As E_UserInfo) As Boolean
Dim dUser As New D_UserDAO
Return dUser.deleteUser(user) '返回数据库删除用户是否成功
End Function
End Class
D层代码
Public Function SelectUserInfo(ByVal user As E_UserInfo) As IList
Dim mySqlHelper As New SqlHelper '实例化SqlHelper
Dim dt As New DataTable '定义一个DataTable数据表
Dim cmdText As String = "Select UserID, UserName, Operator From T_UserInfo Where Level=@Level"
Dim paras As SqlParameter() = {New SqlParameter("@Level", user.Level)} '将參数传入SqlHelper
dt = mySqlHelper.ExecSelect(cmdText, CommandType.Text, paras) '运行查询 Dim myList As New List(Of E_UserInfo) '定义一个集合用来保存转化后的泛型集合
myList = ConvertHelper.ConvertToList(Of E_UserInfo)(dt) '调用实体转换类,将DataTable转换为泛型集合 Return myList '返回实体集合
End Function
这样就是能用DataGridView显示我们须要的信息了,这样的方法easy忽略导致出错的地方有两个:1、数据库表中的字段名和实体中的属性名不一样。2、实体的属性名和DataGridView中自己定义的数据名不一样。如果是由于第2种出错,那仅仅能说太粗心了。如今给出第1种的解决方法,先如果一个情景:数据库表中“username”的字段名是“UserNo”,实体中对应的属性名是“UserID”,这样就导致了信息不匹配的问题,所以须要转化一下,最简单的就是利用As把上边D层的查询代码改为
"Select UserNo As UserID , UserName, Operator From T_UserInfo Where Level=@Level"
As对数据库字段的转换功能很有意思,本来想用数据库演示一下的,仅仅是SQL软件还没好就算了吧……
DataGridView绑定数据源的更多相关文章
- C# DataGridView绑定数据源的几种常见方式
开始以前,先认识一下WinForm控件数据绑定的两种形式,简单数据绑定和复杂数据绑定. 1. 简单的数据绑定 例1 using (SqlConnection conn = new SqlConnect ...
- DataGridView绑定数据源的几种方式
使用DataGridView控件,可以显示和编辑来自多种不同类型的数据源的表格数据. 将数据绑定到DataGridView控件非常简单和直观,在大多数情况下,只需设置DataSource属性即可.在绑 ...
- 章鱼哥出品—VB.NET DataGridView绑定数据源 "与货币管理器的位置关联的行不能设置为不可见" 问题的解决
DtaGridView绑定数据源后.假设想让数据条件显示的话,直接使用 My_Row.Visible = False就会出错.错误类型是 "与货币管理器的位置关联的行不能设置为不可见&qu ...
- DataGridView绑定数据源后添加行
本文链接:https://blog.csdn.net/u012386475/article/details/88639799 在已经绑定数据源时,无法以Add的方式方式添加行,会报错 解决方法一: D ...
- 【转】DataGridView绑定数据源的几种方式
第一种:DataSet ds=new DataSet (); this.dataGridView1.DataSource=ds.Table[0]; 第二种:DataTable dt=new DataT ...
- C# 关于DataGridView 绑定数据源时列名窜位置 的处理
只需要写一句话:dataGridView1.AutoGenerateColumns = false; 代码提示中的解释:获取或设置一个值,该值指示在设置System.Windows.Forms.Dat ...
- c# datagridview绑定数据源(BindingList<class>)中的现象 待查
现象1: using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; ...
- C# DataGridView绑定数据源
第一种: DataSet ds=new DataSet (); ]; 第二种: DataTable dt=new DataTable(); this.dataGridView1.DataSource= ...
- C# Winform中DataGridView绑定后DataGridViewCheckBoxColumn无法显示的问题
在控件DataGridView绑定数据源后,发现DataGridViewCheckBoxColumn不能显示当前的check值.经过一番努力,现将完整代码奉献出来,仅供参考. 错误代码: /*禁止自动 ...
随机推荐
- I2C操作笔记——以 AT24C04为例
1.前言 对于大多数project师而言,I2C永远是一个头疼的问题.相比UART和SPI而言,I2C的时序要复杂一些,I2C组合变化也丰富一些.在这里以AT24C04为例说明I2C使用过程中 ...
- Python 收集Twitter时间序列数据
CODE: #!/usr/bin/python # -*- coding: utf-8 -*- ''' Created on 2014-7-18 @author: guaguastd @name: c ...
- Python的控制结构(转)
首先我的工作第一语言是c/c++(面向对象子集).选择学习python一方面是因为看很多人都说python开发效率高,所以想验证一下:另一方面,Eric S. Raymond在文章:如何成为一名黑客 ...
- ReferenceError: Error #1069: 在 spark.components.RadioButtonGroup 上找不到属性 label,且没有默认值
1.错误描写叙述 ReferenceError: Error #1069: 在 spark.components.RadioButtonGroup 上找不到属性 label,且没有默认值. at Ch ...
- 寻找失踪的整数数组(Find the missing integer)
排列a包含N分子,其元素属于[0,N]之间,且不存在反复的元素.请你找出数组中缺失的元素(由于[0,N]之间有N+1个元素.而数组仅仅能存储N个元素.所以必定缺少一个元素).当中对数组的操作满足下列的 ...
- cocos2d-x2.2.3和android平台环境的搭建
准备工作:1.我只是将cocos2d-x移植到android平台,所以默认为大家已经将android平台搭建完成了(eclipse和android SDK已经配置好,java环境搭建好) 2.下载an ...
- CCNA CCNP CCIE所有实验名称完整版
实验1:通过Console端口访问Cisco路由器 实验2:通过Telnet访问Cisco路由器 实验3:配置终端服务器 实验4:通过浏览器访问路由器 实验5:模式切换.上下文帮助及查看有关信 ...
- HDU 2451 Simple Addition Expression(组合数学)
主题链接:http://acm.hdu.edu.cn/showproblem.php?pid=2451 Problem Description A luxury yacht with 100 pass ...
- leetcode:linked_list_cycle_II
一. 题目 给定一个链表,假设链表中有环则返回环的開始节点,否则返回NULL.要求不用额外的空间完毕. 二. 分析 在I中,我们推断环的存在,即用slow和fast两个指针,设定步长f ...
- 【原创】最近写的一个比较hack的小爬虫
目标:爬取爱漫画上面自己喜欢的一个漫画 分析阶段: 0.打开爱漫画主页,迎面就是一坨js代码..直接晕了 1.经过抓包和对html源码的分析,可以发现爱漫画通过另外一个域名发送图片,而当前域名中通过j ...