永发信息网

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

答案:2  悬赏:0  手机版
解决时间 2021-03-07 22:24
  • 提问者网友:几叶到寒
  • 2021-03-06 21:41
VB.net 如何查询某值在DataSet的哪一行哪一列?
最佳答案
  • 五星知识达人网友:佘樂
  • 2021-03-06 23:13
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");
}
}
}
全部回答
  • 1楼网友:孤老序
  • 2021-03-07 00:37

行列循环查询就可以了阿
假如 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
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯