限制使用TableAdapter返回的行(键入的DataSet)

时间:2009-11-04 13:26:29

标签: .net sql tableadapter rowcount

有没有人知道限制使用类型化TableAdapter时返回的行数的最佳方法?选项似乎是:

  1. 将“top X”作为参数传递(在我们使用SQLS2008之前不能这样做
  2. 在调用tableadapter方法之前发出动态SQL语句:set rowcount X,然后set rowcount 0向后发送。{/ li>
  3. 我还没有想到的其他事情:)。
  4. 非常感谢提前。

5 个答案:

答案 0 :(得分:2)

你可以使用TOP n,但是你必须像这样使用括号:

SELECT TOP (100) * FROM ...

您也可以按如下方式对其进行参数设置:

DECLARE @count INT
SET @count = 100
SELECT TOP (@count) * FROM field_company

答案 1 :(得分:1)

这对我来说很好。

SELECT DISTINCT TOP (@count) FLD1, FLD2 FROM mytable WITH (nolock)

该参数与TableAdapter中的任何其他参数一起生成。

答案 2 :(得分:0)

我使用参数化存储过程实现了这一点。

create procedure dbo.spFoo 
    @NoOfRows int = 200

AS


declare @sql varchar(2000)
select @sql =
'select top ' + Cast(@NoOfRows as varchar) + ' * FROM   Foo'

exec(@sql)

答案 3 :(得分:0)

我找到了更好的方法。

您无法参数化“TOP”值,但可以参数化“SET ROWCOUNT X”值。

因此,这有效:

create procedure test_SelectTopFromTable (@rowCount int) as
begin
    set rowcount @rowCount
    select * from table
    set rowcount 0
end

exec test_SelectTopFromTable 100

但是我确实需要处理发生的异常,这会阻止set rowcount 0语句运行。我会继续挖掘。

<强>更新
我的老板告诉我如何使它工作(这很简单,我有点尴尬)但我会让他发布他的答案,而不是让它看起来像我自己发现。 :)

答案 4 :(得分:0)

TableadApter使用SqlDataAdapter,已经具有此功能

怎么做:

点击填充() FillByXXX()方法

myTradesTableAdapter.Fill(...)

按F12 - 它会显示设计师生成的源代码复制此方法。

转到DataSet设计器,单击表适配器并按 F7 - 它将为TableAdapters命名空间创建/打开代码。< / p>

粘贴Fill()方法修改,如下例所示:

namespace MyApp.DsMyDataTableAdapters {

public partial class MyTradesTableAdapter
{
    //// copy-paste method from generated Fill()
    //// and make new name: Fill() ==> FillTop()
    //// use the same params and add new one: int topN
    public virtual int FillTop(             //
         DsMyData.MyTradesDataTable dataTable,
         int someParameterId,
         // ...
         int topN)  // add new param
    {
        // original code:
        this.Adapter.SelectCommand = this.CommandCollection[0];
        this.Adapter.SelectCommand.Parameters[1].Value = someParameterId;

        if ((this.ClearBeforeFill == true))
        {
            dataTable.Clear();
        }


        // modified code
        int returnValue = 0;
        if (topN > 0)                  // validate topN
        {
            // get topN rows
            returnValue = this.Adapter.Fill(0, topN, dataTable);   

        }
        else 
        {
            // get all rows (original code) in case topN = 0 or negative
            returnValue = this.Adapter.Fill(dataTable);
        }
        return returnValue;
    }

    // ....
}

然后您可以使用

int somePrm = 123;
myTradesTableAdapter.Fill(ds.myTradesTable, somePrm) // original - get all rows
myTradesTableAdapter.FillTop(ds.myTradesTable, somePrm, 100) // new - get 100 rows