当我使用Zend Framework的数据库组件时,我们尝试抽象LIMITMySQL,PostgreSQL和SQLite支持的子句的功能.也就是说,创建查询可以这样做:
$select = $db->select();
$select->from('mytable');
$select->order('somecolumn');
$select->limit(10, 20);
Run Code Online (Sandbox Code Playgroud)
当数据库支持时LIMIT,这将生成如下SQL查询:
SELECT * FROM mytable ORDER BY somecolumn LIMIT 10, 20
Run Code Online (Sandbox Code Playgroud)
对于不支持的数据库品牌来说,这更复杂LIMIT(顺便说一句,该子句不是标准SQL语言的一部分).如果可以生成行号,则将整个查询作为派生表,并在外部查询中使用BETWEEN.这是Oracle和IBM DB2的解决方案.Microsoft SQL Server 2005具有类似的行号功能,因此可以这样编写查询:
SELECT z2.*
FROM (
SELECT ROW_NUMBER OVER(ORDER BY id) AS zend_db_rownum, z1.*
FROM ( ...original SQL query... ) z1
) z2
WHERE z2.zend_db_rownum BETWEEN @offset+1 AND @offset+@count;
Run Code Online (Sandbox Code Playgroud)
但是,Microsoft SQL Server 2000没有此ROW_NUMBER()功能.
所以我的问题是,你能想出一种方法来模拟LIMITMicrosoft SQL Server 2000中的功能,只使用SQL吗?不使用游标或T-SQL或存储过程.它必须支持LIMITcount和offset 两个参数.使用临时表的解决方案也是不可接受的.
编辑:
MS SQL …
我有一个从数据库中检索数据并将其添加到列表中的函数.我的列表已准备好并显示数据,但我希望在该列表上进行分页,以便每页显示有限的记录.但不知道如何做到这一点.
这是我的数据层功能的代码.
public List<demodto> executereader(List<demodto> Ldemo,SqlCommand cmdshow, string tablename)
{
SqlConnection cn;
try
{
cn = this.getconnection();
cmdshow.Connection = cn;
cn.Open();
SqlDataReader rd = cmdshow.ExecuteReader();
while (rd.Read())
{
demodto dtoobj1 = new demodto();
dtoobj1.ID = Convert.ToInt32(rd[0].ToString());
dtoobj1.Name = rd[1].ToString();
dtoobj1.PhNo = Convert.ToInt32(rd[2].ToString());
dtoobj1.Address = rd[3].ToString();
dtoobj1.Gender = rd[4].ToString();
dtoobj1.Email = rd[5].ToString();
dtoobj1.Emptype = rd[6].ToString();
Ldemo.Add(dtoobj1);
}
cn.Close();
return Ldemo;
}
catch (Exception ex2)
{
throw new DataException("error....." + ex2.Message);
}
}
Run Code Online (Sandbox Code Playgroud)
这是DTO课程..
public class demodto
{
public Int32 ID{get;set;}
public …Run Code Online (Sandbox Code Playgroud) 我不知道如何解决这个问题,尝试了一整天但没有成功修复分页。我正在使用 jQuery 数据表,为了显示我的大量数据,我正在使用服务器端。
作为测试,仅调用表中的 10 行数据。然后在传递到表之前,我使用此解决方案重组了dataSrc内的数据。表格显示成功,但分页和筛选器显示不正确。
任何人都可以帮忙这个吗?
下面是我的代码。
阿贾克斯
$('#example').DataTable({
"processing": true,
"serverSide": true,
"ajax": {
type: "POST",
contentType: "application/json; charset=utf-8",
url: "datatables.aspx/GetData",
'data': function (data) {
return JSON.stringify(data);
},
"dataSrc": function (data) {
var json = $.parseJSON(data.d);
var myData = {};
myData.draw = parseInt(json.otherData[0].draw);
myData.recordsTotal = parseInt(json.otherData[0].recordsTotal);
myData.recordsFiltered = parseInt(json.otherData[0].recordsFiltered);
myData.data = json.searchData;
return myData.data;
}
},
"columns": [
{ "data": "Username" }
]
}
});
Run Code Online (Sandbox Code Playgroud)
C#
[WebMethod]
[ScriptMethod(UseHttpGet = false)]
public static string GetData(int draw, …Run Code Online (Sandbox Code Playgroud) 我正在使用firebird数据库,它似乎没有像sql server那样的ROWNUM或ROW_NUMBER(),所以我不能按照这里解释的程序.
我有一个查询,其结果数据集大于我的系统内存可以容纳的数据集.我正在尝试以较小的块加载数据集.我有一系列通用查询,我无法修改它们可能是任何东西.我知道我能做到
select first 5000 * from
(-my actual query here-)
Run Code Online (Sandbox Code Playgroud)
获得前5000条记录.但是我怎样才能获得接下来的5000条记录.
谢谢
sql ×3
c# ×2
ajax ×1
asp.net ×1
datatables ×1
firebird ×1
firebird2.1 ×1
list ×1
mysql ×1
sql-server ×1
t-sql ×1