设为首页 收藏本站
查看: 1194|回复: 0

[经验分享] 一个基于SharePoint查询的小例子

[复制链接]

尚未签到

发表于 2015-9-29 07:31:17 | 显示全部楼层 |阅读模式
这几天自己做练习,写了一个基于SharePoint列表的查询,做之前是没有头绪的,做完之后才觉得是一件很简单的事情。写在日志里记录下自己的成长。
前台代码:

DSC0000.gif <asp:TextBox ID="txtSearch" runat="server"></asp:TextBox>
<asp:Button ID="btnSearch" runat="server" Text="搜索" OnClick="btnSearch_Click"/>
<asp:LinkButton ID="lbtnA" runat="server" OnClick="lbtnA_Click">A</asp:LinkButton>
<asp:GridView ID="gvwAbb" runat="server" AutoGenerateColumns="False" AllowPaging="True"  PageSize="2" OnPageIndexChanging="gvwAbb_PageIndexChanging">
    <Columns>
        <asp:TemplateField>
            <HeaderTemplate>
            Name
            </HeaderTemplate>
            <ItemTemplate>
                <a href='<%#Eval("LinkFileName") %>'><%#Eval("Name") %></a>
            </ItemTemplate>
        </asp:TemplateField>  
        <asp:BoundField HeaderText="创建者/Creator" DataField="Creator" />
        <asp:BoundField HeaderText="创建时间/CreateTime" DataField="CreateTime" />
    </Columns>
    <EmptyDataTemplate>
        暂时没有符合条件的数据<br />
        There is no data now
    </EmptyDataTemplate>
</asp:GridView>

后台代码:

public partial class SearchAndShowControl : System.Web.UI.UserControl
DSC0001.gif DSC0002.gif     DSC0003.gif {
DSC0004.gif         protected void Page_Load(object sender, EventArgs e)
DSC0005.gif DSC0006.gif         {
            if (!IsPostBack)
            {
                queryAbbField = myList.Fields["splist"].InternalName;

DSC0007.gif             }
        }

        private SPList myList = GetSPList();
        private static string queryAbbField = string.Empty;//静态变量存储查询的Field,其实是一个常量更好;

        private void gvwBind(SPList mylist)
        {
            gvwAbb.DataSource = Search(mylist, ViewState["Query"].ToString());//ViewState["Query"]查询语句
            gvwAbb.DataBind();
        }
        protected void gvwAbb_PageIndexChanging(object sender, GridViewPageEventArgs e)
        {
            gvwAbb.PageIndex = e.NewPageIndex;
            this.gvwBind(myList);           

        }

        protected void rblView_SelectedIndexChanged(object sender, EventArgs e)
        {
            if (Convert.ToInt32(rblView.SelectedValue) == 0)
            {               
                ViewState["Query"] = @"<OrderBy><FieldRef Name='Created_x0020_Date' Ascending='FALSE' /></OrderBy>";//查询语句
                this.gvwBind(myList);
            }
            if (Convert.ToInt32(rblView.SelectedValue) == 1)
            {
                string queryCreatorField = myList.Fields["Creator"].InternalName;
                ViewState["Query"] = @"<Where><Eq><FieldRef Name='" + queryCreatorField + "' /><Value Type='Text'>" + this.Page.User.Identity.Name + "</Value></Eq></Where><OrderBy><FieldRef Name='Created_x0020_Date' Ascending='FALSE' /></OrderBy>";
                this.gvwBind(myList);
            }

        }
        protected void btnSearch_Click(object sender, EventArgs e)
        {
            if (txtSearch.Text != string.Empty)
            {
                ViewState["Query"] = @"<Where><Contains><FieldRef Name='" + queryAbbField + "' /><Value Type='Text'>" + txtSearch.Text + "</Value></Contains></Where><OrderBy><FieldRef Name='Created_x0020_Date' Ascending='FALSE' /></OrderBy>";
                this.gvwBind(myList);
            }
            else
            {
                ViewState["Query"] = @"<OrderBy><FieldRef Name='Created_x0020_Date' Ascending='FALSE' /></OrderBy>";
                this.gvwBind(myList);
            }
            
        }
//一共26个英文字母,查询queryAbbField域以某个字母开始的,并且按创建时间倒序排序,这里只显示A的,其他都一样。
        protected void lbtnA_Click(object sender, EventArgs e)
        {
            ViewState["Query"] = @"<Where><BeginsWith><FieldRef Name='" + queryAbbField + "' /><Value Type='Text'>a</Value></BeginsWith></Where><OrderBy><FieldRef Name='Created_x0020_Date' Ascending='FALSE' /></OrderBy>";
            this.gvwBind(myList);
        }



        public static SPList GetSPList()//获得当前的SPList
        {
            SPSite mysite = new SPSite(http://ComputerName/sites/cn);
            SPWeb myweb = SPContext.Current.Web;
            SPList mylist = myweb.Lists["splist"];

            return mylist;
        }
//定义了一个类Message,定义一些属性,Name,Creator等等。        

        public static List<Message> Search(SPList mylist, string myquery)
        {
            SPQuery query = new SPQuery();
            query.Query = myquery;
            SPListItemCollection myitems = mylist.GetItems(query);

            return AddList(myitems);
        }
        

        public static List<Message> AddList(SPListItemCollection items)
        {
            List<Message> messages = new List<Message>();
            foreach (SPListItem item in items)
            {
                Message msg = new Message();
                msg.Abbreviation = item["Name"].ToString();
                msg.ForeignName = item["Department"].ToString();
                msg.Creator = item["Creator"].ToString();
                msg.CreateTime = Convert.ToDateTime(item["创建时间"]);
                msg.LinkFileName = item.File.ServerRelativeUrl;

                messages.Add(msg);
            }
            return messages;
DSC0008.gif         }

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-120137-1-1.html 上篇帖子: SharePoint Server 2010安装过程 下篇帖子: Wss3入门(3):为SharePoint Blog分类添加文章计数
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表