VB.net 如何查询某值在DataSet的哪一行哪一列?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了VB.net 如何查询某值在DataSet的哪一行哪一列?相关的知识,希望对你有一定的参考价值。

我有一个DataSet ,里面有一个字符“A”,但我不知道“A”在哪里一行哪一列,如何查询出“A”在DataSet里的哪一行哪一列?

行列循环查询就可以了阿

假如 DataSet1是你的 DataSet,见下面的代码

    Dim db As DataTable = DataSet1.Tables("表名")
        Dim c As Integer = db.Columns.Count - 1
        Dim r As Integer = db.Rows.Count - 1
        For i = 0 To r
            For j = 0 To c
                If db.Rows(r).Item(i) = "A" Then
                    MsgBox("行是:" & i & "列是:" & j)
                End If
            Next
        Next

参考技术A DataSet的功能:浏览、排序、搜索、过滤、处理分级数据、缓存更改等。还可以与XML数据互换。DataSet中可包括多个 DataTable,可将多个查询结构存到一个DataSet中,方便操作,而DataTable中又包括多个DataRow、DataColumn,可 通过这些 DataRow、DataColumn来查看、操作其中的数据,而需将操作结果返回给数据库的话,则可以调用DataAdapter的Update方法。
DataSet的操作:
DataSetds=new DataSet();
DataTabledt=new DataTable("newTable");
ds.Tables.Add(dt);
DataSetds=new DataSet();
DataTabledt=ds.Tables.Add("newTable");
上述两种方法都可以在DataSet中添加一个DataTable,看需要而进行选择。添加DataTable后,需向其中添加行和列。
DataSetds=new DataSet();
DataTabledt=ds.Tables.Add("newTables");
DataColumncol=dt.Columns.Add("newColumn",typeof(int));
col.AllowDBNull=false;
col.MaxLength=4;
col.Unique=true;
上述代码向DataSet中的DataTable中添加名为”newColumn”,类型为int且不为空,最大长度为4和唯一性为真的列。
dt.PrimaryKey=newDataColumn[]dt.Columns["ID"]
这段代码是继续上面代码的,为一个DataTable中添加一个主键列,主键列是一个数据组,如有多个主键,只需在数组中添加一个列即可。如下:
dt.PrimaryKey=newDataColumns[]dt.Columns["OrderID"],dt.Columns["ProductID"]
添加外键:
ForeignKeyConstraintfk;
fk=newForeignKeyConstraint(ds.Tables["Customers"].Columns["CustomerID"],ds.Tables["Orders"].Columns["CustomerID"]);
ds.Tables["Orders"].Constraints.Add(fk);
上述代码假如已经为Cusomers表和Orders创建了主键,此句为添加外键约束。
上述是根据Customers表和Orders表的CustomerID来创建约束。
下面介绍修改DataRow中的内容:
DataRowdr=ds.Tables["Customer"].Rows.Find("ANTON");
if(dr==null)
else

dr.BeginEdit();
dr["CompanyName"]="newValue";
dr["ContactName"]="newValue2";
dr.EndEdit();

上面代码通过Row集合的Find方法来在DataTable中的行进行定位,找到"ANTON"行,再修改"ANTON"行中 CompanyName列和ContactName列的值。通过BeginEdit和EndEdit来缓存对行的修改,还可调用 CancelEdit为取消修改。
判断某列是否为空值:
DataRowdr=ds.Tables["Customers"].Rows.Find("aaa");
if(dr.IsNull("ContactName");
..
else
dr["ContactName"]=DBNull.Value
这里判断ContactName列是否为空,如果不是则为其赋空值,呵,很无厘头的做法,这里只为演示为列赋空值的做法。
删除DataRow:
有两种方法可以删除DataRow,Delete方法和Remove方法和RemoveAt方法。其区别是Delete方法实际上不是从 DataTable 中删除掉一行,而是将其标志为删除,仅仅是做个记号,而Remove方法则是真正的从DataRow中删除一行,RemoveAt方法是根本行的索引来删 除。列:
DataRowdr=ds.Tables["table"].Rows.Find("a");
ds.Tables["table"].Remove(dr);

ds.Tables["table"].Remove(index);
dr 为"a"所在的行,查出后将其删除,index为 "a"所在的索引号。关于DataSet中的其用法,参照MSDN
DataRowdr=ds.Tables["Customers"].Rows.Find("aaa");
if(dr.IsNull("ContactName");
..
else
dr["ContactName"]=DBNull.Value
这里判断ContactName列是否为空,如果不是则为其赋空值,呵,很无厘头的做法,这里只为演示为列赋空值的做法。
usingSystem.Data;
usingSystem;
usingSystem.Windows.Forms;
classDataT

static DataTable dt;// = new DataTable();
static DataSet ds;
static void method1()

dt = new DataTable("Name");
ds = new DataSet();
dt.Columns.Add(newDataColumn("ID", typeof(Int32)));
dt.Columns.Add(newDataColumn("Name", typeof(string)));
dt.Columns.Add(newDataColumn("Sex", typeof(string)));
dt.Columns.Add(newDataColumn("Addr", typeof(string)));

static void add(int id,string name,stringsex,string addr)

DataRow dr = dt.NewRow();
dr["id"] = id;
dr["Name"] = name;
dr["Sex"] = sex;
dr["Addr"] = addr;
dt.Rows.Add(dr);

static void Main()

DataT DT = new DataT();
method1();
add(100,"Join","Male","北京");
add(101,"Lily","feMale","北京");
add(102,"JIM","Male","北京");
ds.Tables.Add(dt);
foreach(DataRow dr in dt.Rows)

MessageBox.Show(dr["ID"].ToString()+ " " + dr["Name"].ToString() + " " +dr["Sex"].ToString() + " " +dr["Addr"].ToString(),"Message");
Console.WriteLine(dr["ID"].ToString()+ " " + dr["Name"].ToString()+ " " +dr["Sex"].ToString() + " " +dr["Addr"].ToString());

Try

foreach(DataTable dt2 in ds.Tables)
foreach(DataRow dr in dt2.Rows)
Console.WriteLine(dr["ID"].ToString()+ " " + dr["Name"].ToString() + " " + dr["Sex"].ToString()+ " " + dr["Addr"].ToString());

catch(Exception ex)

Console.WriteLine("dkfjksdjfk");


即时更新datagridview

请问怎么即时更新datagridview中的数据内容啊?我用了Timer控件,每一秒触发一次,将dataset的表清空再填充一次,然后将datagridview重新绑定到这上面。虽然实现了即时刷新,但是这样会造成datagridview不断的闪烁,而且datagridview的游标会自动跑到第一行。怎么解决呢请问。VB.NET

参考技术A 不可能。只有重新查询。

以上是关于VB.net 如何查询某值在DataSet的哪一行哪一列?的主要内容,如果未能解决你的问题,请参考以下文章

vb.net 更改dataset表中的内容

VB.Net 用 dataset1 表行填充 DataGridview

如何确定 VB.Net DataRow 中是不是存在列

vb.net访问sql server数据库(SqlDataReader和DataSet两种方式)

如何在 vb.net 中实现交易方式?

如何在 VB.NET 中更新 DataTable 中的一行?