access如何创建查询_如何在Access中模拟SqlServer存储过程翻页

更新时间:2019-11-08 来源:模拟经营 点击:

【www.hzclsc.cn--模拟经营】

DECLARE @PageUpperBound int
SET @PageLowerBound = @PageSize * @PageIndex - @PageSize
SET @PageUpperBound = @PageLowerBound + @PageSize + 1

Create Table #IDs
(
TempID int IDENTITY (1, 1) NOT NULL,
EntryID int not null
)
Insert into #IDs(EntryID) select DISTINCT [ID] from view_Content where CategoryID=@CategoryID and blogID=@BlogID order by [ID] desc
SELECT vc.*
FROM View_Content vc
INNER JOIN #IDS tmp ON (vc .[ID] = tmp.EntryID)
WHERE tmp.TempID @PageLowerBound
AND tmp.TempID @PageUpperBound and vc.Hiding=0
ORDER BY tmp.TempID
SELECT @Count=COUNT(*) FROM #IDS
SELECT @Count=COUNT(*) FROM #IDS
DROP TABLE #IDS
return @Count
GO

在Access中由于不支持存储过程,不能建立临时表只能在程序中实现
Access中实现如下,这也是我在myblog Access版中使用的:
public List DayBook GetPagedPost(PagedPost p, out int TotalRecords)
{
List DayBook list = new List DayBook

using (OleDbConnection conn = GetOleDbConnection())
{
StringBuilder sql = new StringBuilder();
sql.AppendFormat( select [ID] from blog_Content as p //构造查询条件
if (p.CategoryID 0)
{
sql.AppendFormat( ,blog_Categories AS c, blog_Links AS l WHERE c.CategoryID=l.CategoryID and (p.ID=l.PostID ) and c.CategoryID={1} and p.BlogID={0} ,p.BlogID, p.CategoryID);
}
else
{
sql.AppendFormat( where p.blogID={0} , p.BlogID);
}
if (p.PostType != PostType.Undeclared)
{
sql.AppendFormat( and p.PostType={0} , (int)p.PostType);
}
sql.Append( order by p.[DateUpdated] desc
// NetDiskContext.Current.Context.Response.Write(sql.ToString());
//NetDiskContext.Current.Context.Response.End();
OleDbCommand MyComm = new OleDbCommand(sql.ToString(), conn);
List int IDs = new List int //获取主题ID列表
conn.Open();
using (OleDbDataReader dr = MyComm.ExecuteReader())
{
while (dr.Read())
{
IDs.Add((int)dr[0]);
}
}
TotalRecords=IDs.Count;//返回记录总数
if (TotalRecords 1)
return list;
int pageLowerBound = p.PageSize * p.PageIndex - p.PageSize;//记录索引
int pageUpperBound = pageLowerBound + p.PageSize ;
StringBuilder sb = new StringBuilder();
if (TotalRecords = pageLowerBound)
for (int i = pageLowerBound; i TotalRecords i pageUpperBound; i++)
{
sb.AppendFormat( {0}, , IDs[i]);//构造ID in() 条件,取其中一页
}
else return list; //如没有记录返回空表
if(sb.Length 1)
sb.Remove(sb.Length - 1, 1);//删除最后一个逗号
MyComm.CommandText = string.Format( SELECT b.* , c.Account as Account FROM blog_Content b, Blog_Config c where b.BlogID=c.BlogID and b.[ID] in ({0}) order by b.dateadded desc , sb.ToString());
using (OleDbDataReader dr = MyComm.ExecuteReader())
{
while (dr.Read())
{
list.Add(DataHelp.LoadDayBook(dr));
}
}
return list;
}
}

本文来源:http://www.hzclsc.cn/danjiyouxi/38194.html

为您推荐

【茂伸奇谈happy end】茂伸奇谈常见问题及解决方法

茂伸奇谈(茂伸奇谈-Monobeno-)日前已经发售,那么许多玩家在游戏中遇到的一些问题该怎么解决呢?下面就来分享一下茂伸奇谈常见问题及解决方法。茂伸奇谈常见问题及解决方法《茂伸奇谈-Monobeno模拟游戏

2021-02-25 18:54:41  

【欧洲卡车模拟2方向盘设置】欧洲卡车模拟2方向盘180度设置教程 欧洲卡车模拟2方向盘180度怎么设置

您的位置:首页 → 单机游戏 → 模拟游戏 → 欧洲卡车模拟2方向盘180度设置教程 欧洲卡车模拟2方向盘180度怎么设置 欧洲卡车模拟2方向盘180度设置教程 欧洲卡车模拟2方向盘180度怎么设置时模拟游戏

2021-02-25 18:54:41  

欧洲卡车模拟2配置要求|欧洲卡车模拟2低配置画面设置优化方法 欧洲卡车模拟2画面怎么设置

您的位置:首页 → 单机游戏 → 模拟游戏 → 欧洲卡车模拟2低配置画面设置优化方法 欧洲卡车模拟2画面怎么设置 欧洲卡车模拟2低配置画面设置优化方法 欧洲卡车模拟2画面怎么设置时间:2018 2 2模拟游戏

2020-12-20 11:05:28  

【深海迷航秘籍代码】深海迷航秘籍怎么用 深海迷航秘籍代码大全

深海迷航秘籍怎么用?深海迷航游戏中使用秘籍可以快速的完成任务,增加物品收益,本文带来了秘籍代码及使用方法,有需要的玩家欢迎收藏。下面就一起来看看深海迷航秘籍代码大全吧。f3 f8同时打开,勾选掉禁用控模拟游戏

2020-12-20 07:04:16  

夏色祭|夏色心跳日志PSV版发售日期一览 夏色心跳日志PSV版什么时候出

夏色心跳日志(ナツイロココロログ)是一款著名的恋爱模拟游戏,日前即将登录PSV平台,下面就来分享一下夏色心跳日志PSV版发售日期。夏色心跳日志PSV版发售日期一览dramatic create社今天宣

2020-12-19 11:04:43   夏色奇迹   夏色祭中之人