世外桃源

C#、Asp.net相关技术

导航

多表查询与多记录删除

Posted on 2006-04-15 16:23  佚名  阅读(767)  评论(1编辑  收藏  举报
这几天一直没有事做。就在看一些资料,Form的。ASP的。还有SQL的资料。什么都看。什么都是一知半解。却又什么都感兴趣。心里面实在是郁闷的很。没有事做。就先积累知识吧,也就在自己的BLOG上面留些知识

1、在SQL的环境中。在同一语句中无论发出几条几条命令,都是有一个数据包发送到服务器的。这一点可以用SqlConnection的RetrieveStatistics集合中看到结果。
      所以在B/S环境下。如果涉及到读取多个表的数据我们就可以将Sqlcommand的CommandText写成如下形式:
     Select FieldList from SourthTable1;
     Select FieldList from SourthTable2;
     .............
这样通过这个查询生成的SqlDataReader或者SqlDataAdapter就会包括了几个表,减少了与服务器的通讯,节省了系统资源。

SqlDataReader在多表查询情况下,通过NextResult属性来跳转到下一个查询结果表:

do  SqlDataReader.Read()
{
............
}Until SqlDataReader.NextResult()

SqlDataAdapter在依据多表查询的Command和Connection对像建立。执行Fill(SomeTable)以后。会基于提供的表名。生成一系列的如SomeTable1,SomeTable2的表,在实际的使用过程中。我们在使用前须要对它们进行改名。
SqlDataAdapter.TableMapping[0].Name="ElseTable";
.........

多条记录删除:
Delete from SomeTable where PrimaryKey in (some valuelist......),这样做的好处,也是以减少与SQL服务器的回程为基础的,如果一项操作操作执行的频繁,而且只是针对某个字段进行的操作,我们可以将其操作缓存下来。到了一定的数量再发送。