有没有人知道限制使用类型化TableAdapter时返回的行数的最佳方法?选项似乎是:
set rowcount X
,然后set rowcount 0
向后发送。{/ li>
非常感谢提前。
答案 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