站长百科 | 数字化技能提升教程 数字化时代生存宝典
首页
数字化百科
电子书
建站程序
开发
服务器
办公软件
开发教程
服务器教程
软件使用教程
运营教程
热门电子书
WordPress教程
宝塔面板教程
CSS教程
Shopify教程
导航
程序频道
推广频道
网赚频道
人物频道
网站程序
网页制作
云计算
服务器
CMS
论坛
网店
虚拟主机
cPanel
网址导航
WIKI使用导航
WIKI首页
最新资讯
网站程序
站长人物
页面分类
使用帮助
编辑测试
创建条目
网站地图
站长百科导航
站长百科
主机侦探
IDCtalk云说
跨境电商导航
WordPress啦
站长专题
网站推广
网站程序
网站赚钱
虚拟主机
cPanel
网址导航专题
云计算
微博营销
虚拟主机管理系统
开放平台
WIKI程序与应用
美国十大主机
编辑“
SPB-附录-查询条件类在SpaceBuilder中的作用
”
人物百科
|
营销百科
|
网赚百科
|
站长工具
|
网站程序
|
域名主机
|
互联网公司
|
分类索引
跳转至:
导航
、
搜索
警告:
您没有登录。如果您做出任意编辑,您的IP地址将会公开可见。如果您
登录
或
创建
一个账户,您的编辑将归属于您的用户名,且将享受其他好处。
反垃圾检查。
不要
加入这个!
<span style="text-align:center; border:1px solid #000; float:right; padding:6px;"><strong>导航:</strong> [[SpaceBuilde二次开发手册|上一页]]</span> <div style="clear:both;"></div> 在获取实体集合时情况较多: '''例如''':以文件为例,列出一些获取实体集合的情况: #只获取某个每个人的文件集合 #获取每个标签下的文件集合 #获取每个类别下的文件集合 #获取某个页面的文件集合 #获取私有的文件集合 #获取某个人每隔标签下的文件集合 #获取某个人每个类别下的文件集合 #获取某个标签下某个页面的文件结合…. 以上的情况,以及他们的组合将会产生很多种情况,而且这些情况是变化的;所以SpaceBuilder使用了查询条件类封装了这些变化;我们看一下文件查询条件类 - FileThreadQuery: <pre> namespace SpaceBuilder.File { /// <summary> /// 文件查询类 /// </summary> public class FileThreadQuery { #region Query Properties /// <summary> /// 拥有者UserID /// </summary> public int OwnerUserID = -1; /// <summary> /// 站点类型 /// </summary> public int SiteCategoryID = -1; ….. ….. private int pageIndex = 1; /// <summary> /// 当前显示的页码号 /// </summary> public int PageIndex { …. } #endregion /// <summary> /// 缓存使用的标识键,在缓存体系中名称唯一,以区别于其他的缓存对象 /// </summary> public string CacheKey { get { return string.Format("FileThreads::OwnerUserID: {0}-SiteCategoryID{1}-IncludeSiteCategoryDescendant{2} -UserCategoryID:{3}-OnlyPublic:{4}-AuditingStatusForDisplay: {5}-UncategorizedOnly:{6}-TagName:{7}-SubjectKeywords: {8}-PI:{9}-PS:{10}-SO:{11}-SB:{12}-IP:{13}-MaxRecords:{14}-IncludeTags:{15}", OwnerUserID,SiteCategoryID,IncludeSiteCategoryDescendant, UserCategoryID, OnlyPublic, AuditingStatusForDisplay.ToString(), UnuserCategorizedOnly, TagName, SubjectKeywords, PageIndex, PageSize, (int)SortOrder, (int)SortBy, EnablePaging, MaxRecords, IncludeTags); } } } } </pre> 由于代码太多,只截取了部分内容,如上面的代码所示;实际FileThreadQuery包括哪些查询条件请看源码(File项目中的FileThreadQuery.cs);FileThreadQuery中的各个属性代表了各种查询条件,通过赋值不同的查询条件;实现不同查询条件的组合:例如,获取某个人某个标签下的文件集合: <pre> FileThreadQuery query = new FileThreadQuery(); query.OwnerUserID = currentDomainUser.UserID; query.TagName = tagName; PagingDataSet<FileThread> threads = FileThreads.GetThreads(query); </pre> 也就是说,FileThreadQuery封装了各种查询条件以及他们的组合;在表现层,我们获取符合某些条件的文件集合只要配置查询条件类 FileThreadQuery即可。 大家可能注意到了,在FileThreadQuery中还有个特殊的属性:CacheKey: <pre> /// <summary> /// 缓存使用的标识键,在缓存体系中名称唯一,以区别于其他的缓存对象 /// </summary> public string CacheKey { get { return string.Format("FileThreads::OwnerUserID: {0}-SiteCategoryID{1}-IncludeSiteCategoryDescendant{2} -UserCategoryID:{3}-OnlyPublic:{4}-AuditingStatusForDisplay: {5}-UncategorizedOnly:{6}-TagName:{7}-SubjectKeywords:{8}- PI:{9}-PS:{10}-SO:{11}-SB:{12}-IP:{13}-MaxRecords:{14}-IncludeTags:{15}", OwnerUserID,SiteCategoryID,IncludeSiteCategoryDescendant, UserCategoryID, OnlyPublic, AuditingStatusForDisplay.ToString(), UnuserCategorizedOnly, TagName, SubjectKeywords, PageIndex, PageSize, (int)SortOrder, (int)SortBy, EnablePaging, MaxRecords, IncludeTags); } } </pre> 它不是查询条件,而是缓存标识;在从数据库中取出数据库后,为了减轻[[数据库]]的负担,我们将查询到得内容放入缓存;而不同的缓存块都有唯一标识相互区别,就是使用的FileThreadQuery中的这个CacheKey。 以上介绍了,为什么使用FileThreadQuery以及如何使用;那么,在数据访问层获取数据集合的时候FileThreadQuery是如何起作用的?获取文件集合的方法:GetThreads在类SqlFileThreadProvider中的实现:(解析FileThreadQuery,组装[[sql]]语句) [[Image:Spacebuilder0034.jpg]] ==参考资料== *[http://doc.spacebuilder.cn SpaceBuilder官方] [[category:SpaceBuilder|S]]
摘要:
请注意,您对站长百科的所有贡献都可能被其他贡献者编辑,修改或删除。如果您不希望您的文字被任意修改和再散布,请不要提交。
您同时也要向我们保证您所提交的内容是您自己所作,或得自一个不受版权保护或相似自由的来源(参阅
Wordpress-mediawiki:版权
的细节)。
未经许可,请勿提交受版权保护的作品!
取消
编辑帮助
(在新窗口中打开)