MVC2中的基本操作(增、删、改、查)

本文介绍了一个基于ASP.NET MVC的应用程序如何实现数据的分页展示及增删改查(CRUD)功能。文章详细展示了控制器中的分页逻辑、页面跳转功能以及数据的创建、读取、更新和删除操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

控制器中代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using MvcApplication1.Models;
using System.Text;

namespace MvcApplication1.Controllers
{
    public class talkController : Controller
    {
        //
        // GET: /talk/
        TalkDataContext dbTalk = new TalkDataContext();
        public static int pageIndex = 1,pageCount;
        public ActionResult Index(string msg)
        {
            if (pageIndex < 1)
            { pageIndex = 1; }
            int pageSize = 3;            
            List<talk> talkList = dbTalk.talk.ToList();
            int totalCount = talkList.Count;
            bool hasRemainder;
            int endNum=pageIndex * pageSize;
           // pageCount = (totalCount % pageSize == 0 )?( totalCount / pageSize ): (totalCount / pageSize + 1);
            if (totalCount % pageSize == 0)
            { pageCount = totalCount / pageSize; hasRemainder = false; }
            else
            { pageCount = totalCount / pageSize + 1; hasRemainder = true; }
            List<talk> newList = new List<talk>();
            if (hasRemainder)
            {
                if (pageIndex == pageCount)
                {
                    endNum = totalCount;
                }
            }           
            for (int i = (pageIndex - 1) * pageSize; i < endNum; i++)
            {
                newList.Add(talkList[i]);
            }
            ViewData["pageIndex"] = pageIndex;
            ViewData["pageCount"] = pageCount;
            ViewData["pageSize"] = pageSize;
            ViewData["totalCount"] = totalCount;
            ViewData["error"] = msg;
            return View(newList);//返回分页器实例到视图
            

        }
        //上一页
        public ActionResult prevPage()
        {
            string errorMsg = "";
            if (pageIndex > 1)
            {
                pageIndex -= 1;
            }
            else
            {
                errorMsg = "已经是第一页了!";
               // Response.Write("<script>alert('已经是第1页了!')</script>");
            }

            return RedirectToAction("Index", "talk", new { msg = errorMsg });
        }
        //下一页
        public ActionResult nextPage()
        {
            if (pageIndex < pageCount)
            {
                pageIndex += 1;
            }
            else
            {
                ViewData["error"] = "已经是第一页了";
               // Response.Write("<script>alert('已经是最后1页了!')</script>");
            }
            return RedirectToAction("Index");
        }
        //首页
        public ActionResult firstPage()
        {
            pageIndex = 1;
            return RedirectToAction("Index");
        }
        //尾页
        public ActionResult lastPage()
        {
            pageIndex = pageCount;
            return RedirectToAction("Index");
        }
        //跳到的页数     
        public ActionResult search()
        {
           string keyWord = Request.Form["keyWord"];
           var talk = dbTalk.talk.Where(m => m.name.IndexOf(keyWord)>=0);//dbTalk.talk.Where(m => m.name.Equals(keyWord) == true);//
           if (talk == null)
           { ViewData["error"] = "未找到相关信息!"; }
           else
           { ViewData["error"] = "Yes!";}
           ViewData.Model = talk;
           return View();
        }
        public ActionResult gotoPage(FormCollection formCollection)
        {
            string pageNum = formCollection["goto"];
            if (!int.TryParse(pageNum, out pageIndex))
            {
                pageIndex = 1;
            }
            else
            {
                if (pageIndex > pageCount || pageIndex < 1)
                { pageIndex = 1; }
            }
            return RedirectToAction("Index");
        }
        public void  Test()
        {
            Response.Write("<script>alert('已经是最后1页了!');location='Index'</script>");          
        }
        // GET: /talk/Details/5
        
        public ActionResult Details(int id)
        {
            var data = dbTalk.talk.First(m=>m.id==id);        
            return View(data);
        }
  
        //
        // GET: /talk/Create

        public ActionResult Create()
        {
            return View();
        } 

        //
        // POST: /talk/Create

        [HttpPost]
        public ActionResult Create(talk m)
        {
            try
            {
                // TODO: Add insert logic here
                talk t = new talk();
                UpdateModel(t,Request.Form.AllKeys);
                dbTalk.talk.InsertOnSubmit(t);
                dbTalk.SubmitChanges();
                //if (string.IsNullOrEmpty(m.name))
                //{
                //    ModelState.AddModelError("error", "用户名不能为空!");                  
                //    return View();
                //}
                //talk t = new talk();
                //t.name = m.name;
                //t.text = m.text;
                //t.time = m.time;
                //dbTalk.talk.InsertOnSubmit(t);
                //dbTalk.SubmitChanges();
                return RedirectToAction("Index");
            }
            catch
            {
                return View();
            }
        }

        //
        // GET: /talk/Delete/5
 
        public ActionResult Delete(int id)
        {
             talk t = dbTalk.talk.First(m => m.id == id);
            //var t=from item in dbTalk.talk where item.id==id select item;
            //talk tt=t.First();
            return View(t);
        }

        //
        // POST: /talk/Delete/5

        [HttpPost]
        public ActionResult Delete(int id, FormCollection collection)
        {
            try
            {
                // TODO: Add delete logic here
                talk t = dbTalk.talk.First(m => m.id == id);
                dbTalk.talk.DeleteOnSubmit(t);
                dbTalk.SubmitChanges();
                return RedirectToAction("Index");
            }
            catch
            {
                return View();
            }
        }

        //
        // GET: /talk/Edit/5
 
        public ActionResult Edit(int id)
        {
            talk t = dbTalk.talk.First(m => m.id == id);
            return View(t);
        }

        //
        // POST: /talk/Edit/5

        [HttpPost]
        public ActionResult Edit(int id, FormCollection collection)
        {
            try
            {
                // TODO: Add update logic here
               talk t= dbTalk.talk.First(m => m.id == id);
                UpdateModel(t, collection.AllKeys);           
                dbTalk.SubmitChanges();
                return RedirectToAction("Index");
            }
            catch
            {
                return View();
            }
        }
    }
}


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值