DataTable.Select使用小心得

最近在博客园代码的重构中, 我发觉用DataTable.Select进行XML数据的查询也是挺方便的。
比如我们根据Url中参数值查询XML数据中相应节点的数据。
假如我们有这样的Xml数据文件Catalog.xml:
<Navigation>
      
<Catalog title="非技术区" url="default.aspx?cate=2" rss="MainFeed.aspx?cate=2" visible="true"  cate="2"/>
      
<Catalog title="转载区" url="default.aspx?cate=7" rss="MainFeed.aspx?cate=7"  visible="true"  cate="7"/>
</Navigation>
通过DataTable.Select查询Xml数据的方法是:
DataSet myds=new DataSet();
myds.ReadXml(
"Catalog.xml");
if(Request.QueryString["cate"]!=null)
            
{
                querystr
="cate="+Request.QueryString["cate"];
            }

           
            
 DataRow[] row
=myds.Tables[0].Select(querystr);
 
if(row.Length>0)
            
{
                url
=row[0]["url"].ToString();
            }

            

一开始我用上面的方法查询能得正确的结果,但当Catalog.xml某个节点的cate>10时,比如cate=10, 通过myds.Tables[0].Select("cate=10")就查询不到cate=10的节点。一开始百思不得其解, 因为我认为cate在myds中是被作为int类型处理的。后来,我想到是不是当cate变成两位数时, DataSet把cate作为字符串处理?我将代码改成:
    querystr="cate='"+Request.QueryString["cate"]+"'";
问题就解决了。

posted @ 2004-07-12 20:13 dudu 阅读(10760) 评论(13)  编辑 收藏 网摘 所属分类: ASP.NET 1.1

  回复  引用  查看    
#1楼 2004-07-12 21:00 | Evernory      
myds.Tables[0].Select("cate='10'")
应该也可以的
  回复  引用  查看    
#2楼 2004-07-12 23:07 | 笨笨蜗牛      
dudu也会犯这样的错?

在XML里面不都是字符串的数据吗?
如果你要使cate的内容为整数,需要定义XML的SHEMA的。
  回复  引用  查看    
#3楼 2004-07-12 23:14 | dudu      
可为什么cate<10时, 按整数进行查询能得到正确的结果.
  回复  引用  查看    
#4楼 2004-07-16 20:40 | 笨笨蜗牛      
这是字符串比较的问题和整数自动转字符串的问题。

比如:

int i;

string str;

如果要把i转换为字符串后给str,必须:

str=i.ToString();

但这样也可以:

str=i;

另外,还可以:

str="abc"+i;

其等同于:

str="abc"+i.ToString();
  回复  引用    
#5楼 2004-09-28 10:44 | zhaoma@hotmail.com [未注册用户]
请教:
如何在查询条件里使用between?

Dim tmpRow As DataRow()
Dim tmpFilter As String = " GroupId =3 and ('" + Format(Now(), "yyyy-MM-dd") + "' Between BeginDate and EndDate))"
tmpRow = _ItemDS.Tables(0).Select(tmpFilter, " ItemId Desc ")

异常详细信息: System.Data.EvaluateException: 表达式包含不支持的运算符“Between”。

  回复  引用    
#6楼 2005-01-17 21:45 | LC [未注册用户]
我想知道在条件中能否用日期类型比较,,我的msn:lch5577@hotmail.com
  回复  引用  查看    
#7楼 2005-04-20 13:24 | 吴正杰      
对于字符串  3 > 21
对于整数   3<21

所以出现您说的 <10 的情况下可以
  回复  引用    
#8楼 2005-08-09 10:44 | lsmwell [未注册用户]
呵呵,我错的比你们郁闷~!我的是这样写的querystr="id="+id+"";
结果第一条是对的,第二条就错了~!我的XML里的ID 是INT的~!
搞了半天才明白~!原来是这样写就可以了
querystr="id='"+id+"'";
就是加了个单引号~!嘿嘿
  回复  引用    
#9楼 2005-09-21 09:00 | READER [未注册用户]
GOOD
  回复  引用    
#10楼 2005-10-14 11:20 | hyphappy [未注册用户]
我也遇到类似的问题。AA是字符串类型的,"AA=789" ,"AA=799","AA=499"能够查出来结果。但是"AA=1038"就查不出结果,必须改成"AA='1038'"才可以。
  回复  引用    
#11楼 2005-12-17 15:26 | oo [未注册用户]
http://dudu.cnblogs.com/archive/2004/07/12/23537.html

执行 SQL 语句的方式,也有一些不方便,因为带参数的 SQL 语句的参数值也常常是拼接到字符串中,于是便有了诸如“单引号问题”这样的麻烦。

  回复  引用  查看    
#12楼 2006-02-18 10:42 | 红马天下      
我定义XML的SHEMA,数据类型为整数,但是也出现问题。奇怪的是"FileID=4"可以查询,而"FileID=3"不可以查询
  回复  引用  查看    
#13楼 2007-06-25 16:31 | 流浪浪      
DataTable.Select的使用查询还是不错的

在DataSet中用过




标题  
姓名  
主页
Email (博主才能看到) 
验证码 *  看不清,换一张 [登录][注册]
内容(请不要发表任何与政治相关的内容)  
  登录  使用高级评论  新用户注册  返回页首  恢复上次提交      
该文被作者在 2004-07-12 20:16 编辑过
Google站内搜索

China-pub 计算机图书网上专卖店!6.5万品种 2-8折!
近千种 9-95 新二手计算图书火热销售中!
开发者征途系统新作:《设计模式——基于C#的工程化实现及扩展》

相关文章:

相关链接: