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

温馨提示:内容为网友见解,仅供参考
第1个回答  2016-02-02
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");
}
}
}

VB.net 如何查询某值在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)...

vb.net开发中,如果有条件地从dataset中读取数据?
直接用datatable的Select选项,筛选出来是一个Datarow组,然后再循环它就可以了。Dim dtrs as DataRow() =dataset.datatable.Select("列名 = '条件' ")if dtr.rows >0 Then for each dtr as DataRow in dtrs '你的处理代码~next endif ...

VB.net dataset用法和datagridview
datagridview1.source=DataSet1.Tables(0)'如果只有一个表 或者datagridview1.source=DataSet1.Tables(“table1”)

VB.NET2005怎么在控件中一条一条的显示数据表的记录
我们用datatable\/dataset 保存你查询的结果,然后就可以一条条显示,记录住当前显示的row(行)eg:你的查询保存 datatable1 第一条时,我们就来个 dim dtrow as datarow=datatable.rows(0)textbox1.text=dtrow.item("字段名")'...都是如此 当然也是可能绑定的 CurrencyManager 用于管理显示的行数 ...

vb.net怎么把excel 读到DataSet中?
'获取第一张sheet Dim sheet As Worksheet = workbook.Worksheets(0)'设置range范围 Dim range As CellRange = sheet.Range(sheet.FirstRow, sheet.FirstColumn, sheet.LastRow, sheet.LastColumn)'输出数据, 同时输出列名以及公式值 Dim dt As DataTable = sheet.ExportDataTable(range, True, True...

VB.NET oledb 怎么判断到了数据集的尾?或是第一条?
oledb就不用eof和bof了,使用OleDbDataReader读的话就是一条一条读,从第一条开始 Dim rd As OleDbDataReader If rd.Read = True Then g_ServerInfo.sID = rd("Id")End If 用read判断,没记录了就false了 用DataSet读就更省事了 Dim ds As DataSet ds.Tables("tbInfo").Rows.Count是行数...

vb.net数据库操作
Dim dataset As DataSet dataset = New DataSet() com = New OleDb.OleDbCommand(sql, NewConn) adapter = New OleDbDataAdapter(com) adapter.Fill(dataset) Return dataset.Tables(0) End Function''' ''' 执行查询(返回一个数据集,有参) ''' ''' ''' ''' <returns><\/returns> ''' <remarks...

VB.NET 如何判断dataset里是否存在某个表
if(ds == null) \/\/ds为空 if(ds.Tables.Count == 0) \/\/ds中没有表 if(ds.Tables.Count == 1 && ds.Tables[0].Rows.Count == 0) \/\/ds中的表没有数据

vb.net Access 指定数据
'或者你也可以使用dt.Rows.Item(0).Item(0)这个是第一行第一列的数据 For Each dr In dt.Rows If dr.Item("退卡时间") = "#1899\/12\/30#" Then dr.Item("退卡时间") = DBNull.Value End If Next dt.DataSet.AcceptChanges()'更新Datatable End If '设置显示的数据表 DataGridView1....

dataset清除行 vb.net
在第二次查询之前就应该把DATASET从新实例化一个,数据为空了,第一次的自然就没有了

相似回答