zoukankan      html  css  js  c++  java
  • GRIDVIEW中实现上移下移的存储过程

    建一个表  t_hoteladvertise
    有如下字段:
    ID  自动增长(主要)
    SortID  INT (主要)
    Title  NVARCHAR(50)
    代码:

    CREATE proc sp_ehotel_DownAdvertise
    @ID INT
    as
    DECLARE @SortID int
    DECLARE @TempSortID INT
    DECLARE @TempID INT
    BEGIN  TRAN
    SELECT @SortID=SortID  from t_hoteladvertise where [ID]=@ID
    SELECT @TempSortID=max(SortID) from t_hoteladvertise where SortID>@SortID
    SELECT @TempID=[ID] from t_hoteladvertise WHERE SortID=@TempSortID
    if @@error>0 or @@rowcount<>1
    goto NeedRollBack
    UPDATE t_hoteladvertise SET SortID=@SortID WHERE [ID]=@TempID
    if @@error>0 or @@rowcount<>1
    goto NeedRollBack
    UPDATE t_hoteladvertise SET SortID=@TempSortID where [ID]=@ID
    NeedRollBack:
    if @@error>0 or @@rowcount<>1
      rollback tran
    else
    commit tran
    GO

    CREATE proc sp_ehotel_UpAdvertise
    @ID INT
    as
    DECLARE @SortID int
    DECLARE @TempSortID INT
    DECLARE @TempID INT
    BEGIN  TRAN
    SELECT @SortID=SortID  from t_hoteladvertise where [ID]=@ID
    SELECT @TempSortID=max(SortID) from t_hoteladvertise where SortID<@SortID
    SELECT @TempID=[ID] from t_hoteladvertise WHERE SortID=@TempSortID
    if @@error>0 or @@rowcount<>1
    goto NeedRollBack
    UPDATE t_hoteladvertise SET SortID=@SortID WHERE [ID]=@TempID
    if @@error>0 or @@rowcount<>1
    goto NeedRollBack
    UPDATE t_hoteladvertise SET SortID=@TempSortID where [ID]=@ID
    NeedRollBack:
    if @@error>0 or @@rowcount<>1
      rollback tran
    else
    commit tran
    GO
    代码段:
    代码:

    protected void GridView1_RowCommand(object sender, GridViewCommandEventArgs e)
        {
            SqlConnection conn = new SqlConnection();
           if (e.CommandName == "down")
            {
                int IndexID = Convert.ToInt32(e.CommandArgument);
                try
                {
                    XMLData.OpenDatabase(conn);
                    XMLData.ExecuteNonQuery(conn, "SP_EHOTEL_UPADVERTISE", IndexID);
                    Label2.Visible = true;
                    Label2.Text = "下移成功!";


                }
                catch (Exception)
                {
                    Response.Write("<script language='javascript'>alert('下移出错,点取消返回');</" + "script>");
                }
                finally
                {
                    XMLData.CloseDatabase(conn);
                    BindAdvertise();
                }
            }
            if (e.CommandName == "up")
            {
                int IndexID = Convert.ToInt32(e.CommandArgument);
                try
                {
                    XMLData.OpenDatabase(conn);
                    XMLData.ExecuteNonQuery(conn, "SP_EHOTEL_DOWNADVERTISE", IndexID);
                    Label2.Visible = true;
                    Label2.Text = "上移成功!";
                }


                catch (Exception)
                {
                    Response.Write("<script language='javascript'>alert('上移出错,点取消返回');</" + "script>");
                }
                finally
                {
                    XMLData.CloseDatabase(conn);
                    BindAdvertise();
                }
            }
        }

  • 相关阅读:
    U3D中的一些方法和属性
    Animation
    官哥雷达模组样品,特列出技术指标,欢迎高手捧场
    BGA256芯片植球全过程体验(原创)
    最高分辨率行间转移CCD图像传感器
    PYTHON5000:CMOS图象传感器演示
    四张图表让你搞懂电离辐射及常用的量
    TVP5150 PAL/NTSC ccd cmos 模拟摄像头视频 转换 VGA输出
    CyAPI环境搭建
    usb fx2 cy68013 Cyapi使用心得
  • 原文地址:https://www.cnblogs.com/sntetwt/p/2172884.html
Copyright © 2011-2022 走看看