zoukankan      html  css  js  c++  java
  • [置顶] c# 执行多条SQL语句,实现数据库事务 线性表 Hashtable

    菜鸟初尝线性表

    一下是页面源代码

    <%@ Page Title="" Language="C#" MasterPageFile="~/admin/Admin.Master" AutoEventWireup="true"
        CodeBehind="MyDisasterEdit.aspx.cs" Inherits="cn.edu.cidp.zqfxWeb.admin.Edit.MyDisasterEdit" %>

    <asp:Content ID="Content1" ContentPlaceHolderID="ContentPlaceHolderTitle" runat="server">
        <script type="text/javascript" language="javascript">

            function CheckAll(controlId, select) {

                var control = document.getElementById(controlId);
                //alert(select);
                var nodeList = control.getElementsByTagName("input");
                for (var i = 0; i < nodeList.length; i++) {
                    var node = nodeList[i];
                    if (node.type == "checkbox") {
                        node.checked = select;
                    }
                }
            }
        </script>
        <p>
            编辑灾情</p>
    </asp:Content>
    <asp:Content ID="Content2" ContentPlaceHolderID="ContentPlaceHolderBody" runat="server">
        <table align="center">
            <tr>
                <td>
                </td>
            </tr>
            <tr>
                <td>
                    <table>
                        <tr>
                            <td>
                                标题:
                            </td>
                            <td>
                                <asp:TextBox ID="txtDisasterTitle" runat="server" Width="500px"></asp:TextBox>
                            </td>
                        </tr>
                        <tr>
                            <td valign="top">
                                描述:
                            </td>
                            <td>
                                <asp:TextBox ID="txtDisasterDesc" runat="server" Width="500px" Height="200px"></asp:TextBox>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                发生时间:
                            </td>
                            <td>
                                <asp:TextBox ID="txtEventTime" runat="server" Width="500px"></asp:TextBox>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                地区:
                            </td>
                            <td>
                                <asp:TextBox ID="txtRegion" runat="server" Width="500px"></asp:TextBox>
                            </td>
                        </tr>
                        <tr>
                            <%-- 只有地震才有--%>
                            <td colspan="2">
                                <asp:Panel ID="PanelEarthquake" runat="server">
                                    <table>
                                        <tr>
                                            <td>
                                                <table>
                                                    <tr>
                                                        <td>
                                                            震级:
                                                        </td>
                                                        <td>
                                                            <asp:TextBox ID="txtMagnitude" runat="server" Width="150px"></asp:TextBox>
                                                        </td>
                                                    </tr>
                                                </table>
                                            </td>
                                            <td>
                                                <table>
                                                    <tr>
                                                        <td>
                                                            深度:
                                                        </td>
                                                        <td>
                                                            <asp:TextBox ID="txtDepth" runat="server" Width="150px"></asp:TextBox>
                                                        </td>
                                                    </tr>
                                                </table>
                                            </td>
                                        </tr>
                                    </table>
                                </asp:Panel>
                            </td>
                            <tr>
                                <td colspan="2">
                                    <table>
                                        <tr>
                                            <td>
                                                <table>
                                                    <tr>
                                                        <td>
                                                            经度:
                                                        </td>
                                                        <td>
                                                            <asp:TextBox ID="txtLongitude" runat="server" Width="150px"></asp:TextBox>
                                                        </td>
                                                    </tr>
                                                </table>
                                            </td>
                                            <td>
                                                <table>
                                                    <tr>
                                                        <td>
                                                            纬度:
                                                        </td>
                                                        <td>
                                                            <asp:TextBox ID="txtLatitude" runat="server" Width="150px"></asp:TextBox>
                                                        </td>
                                                    </tr>
                                                </table>
                                            </td>
                                        </tr>
                                    </table>
                                </td>
                            </tr>
                        </tr>
                    </table>
                </td>
            </tr>
            <tr>
                <td>
                    <table width="*">
                        <tr>
                            <td>
                                相关灾情:
                            </td>
                        </tr>
                    </table>
                </td>
            </tr>
            <tr>
                <td>
                    <table width="*">
                        <asp:Repeater ID="rptDisasters" runat="server">
                            <HeaderTemplate>
                                <tr>
                                    <td colspan="3">
                                        <input id="cbSelect" type="checkbox" onclick="CheckAll('ContentPlaceHolderBody_gvTexts',this.checked)" />全选
                                    </td>
                                </tr>
                            </HeaderTemplate>
                            <ItemTemplate>
                                <tr>
                                    <td>
                                        <asp:CheckBox ID="SelectThis" runat="server" />
                                        <asp:HiddenField ID="hidId" Value='<%#Eval("DisasterId")%>' runat="server" />
                                    </td>
                                    <td>
                                        <ul style="text-align: left; line-height: 160%;">
                                            <li>[标题]<%# Eval("DisasterTitle")%></li>
                                            <li>[地区]<%# Eval("Region")%></li>
                                            <li>[经度]<%# Eval("Longitude")%>,[纬度]<%#Eval("Latitude")%></li>
                                            <li>[发生时间]<%# Eval("EventTime")%></li>
                                        </ul>
                                    </td>
                                    <td>
                                    </td>
                                </tr>
                            </ItemTemplate>
                        </asp:Repeater>
                    </table>
                </td>
            </tr>
            <tr>
                <td colspan="*" align="center">
                    <asp:Button ID="btnSave" runat="server" Text="关联并保存" onclick="btnSave_Click"></asp:Button>
                    &nbsp;&nbsp;
                    <asp:Button ID="btnCancel" runat="server" Text="取消" onclick="btnCancel_Click"></asp:Button>
                </td>
            </tr>
            <tr>
                <td colspan="*" align="center">
                   <asp:Label ID="lblMSG" runat="server" Font-Bold="True" ForeColor="#CC0000"></asp:Label>
                </td>
            </tr>
        </table>
    </asp:Content>

    补界面截图一张

     

    作为以为已经大三的人来说  第一次写关于线性表的程序 略表惭愧

    用线性的原因呢是应为我要用数据库事物来执行一些操作 ,比如将多条重复的事件归纳为一条时间  而是这些事件关联的新闻Texts,图片Pictures,视频Videos,都要更新,所以就选择了数据库事物,

    最关键的是数据库helper类当中是这样的

    1:

    /// <summary>
            /// 执行多条SQL语句,实现数据库事务。
            /// </summary>
            /// <param name="SQLStringList">多条SQL语句</param>  
            public static int ExecuteSqlTran(List<String> SQLStringList)
            {
                using (MySqlConnection conn = new MySqlConnection(connectionString))
                {
                    conn.Open();
                    MySqlCommand cmd = new MySqlCommand();
                    cmd.Connection = conn;
                    MySqlTransaction tx = conn.BeginTransaction();
                    cmd.Transaction = tx;
                    try
                    {
                        int count = 0;
                        for (int n = 0; n < SQLStringList.Count; n++)
                        {
                            string strsql = SQLStringList[n];
                            if (strsql.Trim().Length > 1)
                            {
                                cmd.CommandText = strsql;
                                count += cmd.ExecuteNonQuery();
                            }
                        }
                        tx.Commit();
                        return count;
                    }
                    catch
                    {
                        tx.Rollback();
                        return 0;
                    }
                }
            }

     

    2:

    /// <summary>
            /// 执行多条SQL语句,实现数据库事务。
            /// </summary>
            /// <param name="SQLStringList">SQL语句的哈希表(key为sql语句,value是该语句的MySqlParameter[])</param>
            public static void ExecuteSqlTran(Hashtable SQLStringList)
            {
                using (MySqlConnection conn = new MySqlConnection(connectionString))
                {
                    conn.Open();
                    using (MySqlTransaction trans = conn.BeginTransaction())
                    {
                        MySqlCommand cmd = new MySqlCommand();
                        try
                        {
                            //循环
                            foreach (DictionaryEntry myDE in SQLStringList)
                            {
                                string cmdText = myDE.Key.ToString();
                                MySqlParameter[] cmdParms = (MySqlParameter[])myDE.Value;
                                PrepareCommand(cmd, conn, trans, cmdText, cmdParms);
                                int val = cmd.ExecuteNonQuery();
                                cmd.Parameters.Clear();
                            }
                            trans.Commit();
                        }
                        catch
                        {
                            trans.Rollback();
                            throw;
                        }
                    }
                }
            }

     一开始我想用哈希表Hashtable把

    结果就有了 如下事件

    解析了之后呢还是不可用

    郁闷了 上网搜到:http://www.cnblogs.com/leischen/archive/2011/12/19/2293939.html

    里面东西是要用到model的

    而我是为了避开model才这样弄的

    所以自己写

    代码如下

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Web;
    using System.Web.UI;
    using System.Web.UI.WebControls;
    using cn.edu.cidp.zqfxLib;
    namespace cn.edu.cidp.zqfxWeb.admin.Edit
    {
        public partial class MyDisasterEdit : MyAdminPage
        {
            int id;
            protected void Page_Load(object sender, EventArgs e)
            {
                if (!IsPostBack)
                {
                    if (Request["ID"] != null || Request["ID"] != "")
                    {
                         id = Convert.ToInt32(Request["ID"]);
                        LoadData(id);

                    }

                }

            }
            public void LoadData(int id)
            {
                if (id > 0)
                {

                    Disasters d = new Disasters();
                    if (!d.Exists(id))
                    {
                        this.lblMSG.Text = "参数不正确";
                        return;
                    }
                    d.GetModel(id);
                    this.txtDisasterTitle.Text = d.DisasterTitle;
                    this.txtDisasterDesc.Text = d.DisasterDesc;
                    this.txtEventTime.Text = d.EventTime.ToString();
                    this.txtLatitude.Text = d.Latitude.ToString();
                    this.txtLongitude.Text = d.Longitude.ToString();
                    this.txtMagnitude.Text = d.Magnitude.ToString();
                    this.txtRegion.Text = d.Region.ToString();
                    this.txtDepth.Text = d.Depth.ToString();
                    if (d.DisasterCategoryId > 0)
                    {
                        // PageUtil.GetDisasterNameByDisterId(d.DisasterCategoryId);
                        if (PageUtil.GetCategoryNameById(Convert.ToInt32(d.DisasterCategoryId)).ToString().Contains("地震"))
                        {
                            this.PanelEarthquake.Visible = true;

                        }
                        else
                            this.PanelEarthquake.Visible = false;
                        
                    }
                    string strWhere = "DisasterTitle like '%{0}%' Longitude like  '%{1}%' Latitude like  '%{2}%' order by UploadUName Desc";
                    strWhere = string.Format(strWhere, d.DisasterTitle, d.Longitude, d.Latitude);
                    Disasters disasters = new Disasters();
                    rptDisasters.DataSource = disasters.GetList(strWhere);
                    rptDisasters.DataBind();

                }
             
                
            }

            protected void btnSave_Click(object sender, EventArgs e)
            {
                Disasters d = new Disasters();
                d.DisasterTitle = this.txtDisasterTitle.Text;
                d.DisasterDesc= this.txtDisasterDesc.Text;
                d.EventTime = Convert.ToDateTime(this.txtEventTime.Text) ;
                d.Latitude  =  Convert.ToDouble(this.txtLatitude.Text);
                d.Longitude =  Convert.ToDouble(this.txtLongitude.Text);
                d.Magnitude = Convert.ToDouble( this.txtMagnitude.Text);
                d.Region = this.txtRegion.Text;
                d.Depth = Convert.ToDouble(this.txtDepth.Text);
               
                if (id > 0)
                {

                    if (!d.Exists(id))
                    {
                        this.lblMSG.Text = "保存失败";
                        return;
                    }
                }
                string  strSql="update disasters set "+
                    "DisasterTitle='"+d.DisasterTitle+"',"+"DisasterDesc='"+d.DisasterDesc+"',"+"Longitude='"+  d.Longitude+"',"+
                    "Latitude='"+d.Latitude+"',"+"Depth='"+d.Depth+"',"+"Magnitude='"+d.Magnitude+"',"+
                    "Region='"+ d.Region+"',"+"EventTime='"+d.EventTime+"',"+" where DisasterId='"+id+"',";
                List<String> SQLStringList=new List<String>();
                SQLStringList.Add(strSql);
                //遍历rptDisasters的选择项 更新AdminAuthFlag=-1 并将关联的图片 视频 disasterId更新为当前有效的DisasterId
                for (int i = 0; i < rptDisasters.Items.Count; i++)
                {

                    int disasterId= Convert.ToInt32(((HiddenField)rptDisasters.Items[i].FindControl("hidId")).Value);
                    CheckBox SelectThis = (CheckBox)rptDisasters.Items[i].FindControl("SelectThis");
                    if (SelectThis.Checked)
                    {
                        SQLStringList.Add("Update Videos set DisasterId='" + id + "' where DisasterId='" + disasterId + "'");
                        SQLStringList.Add("Update Pictures set DisasterId='" + id + "' where DisasterId='" + disasterId + "' ");
                        SQLStringList.Add("Update Texts set DisasterId='" + id + "' where DisasterId='" + disasterId + "'");
                        SQLStringList.Add("Update Disasters set AdminAuthFlag='-1' where DisasterId='" + disasterId + "'");
                       
                    }
                }
                //执行
                int rows = DbHelperMySQL.ExecuteSqlTran(SQLStringList);
                if (rows <= 0)
                {
                    this.lblMSG.Text = "保存失败";
                }


            

               
            }

            protected void btnCancel_Click(object sender, EventArgs e)
            {
                Response.Redirect("../MyAuditDisastersList.aspx");
            }
        }
    }

     

  • 相关阅读:
    Flutter Android ERROR: ensureInitializationComplete must be called after startInitialization
    MySQL 创建用户表和好友表
    Android 广播的使用 文档使用的是 kotlin版本
    Flutter 分段器的使用
    Flutter 计算两个日期之间相差多少天,生成区间随机数
    Flutter 多环境
    Android ListView 的使用 Kotlin
    Android 自定义控件----基础
    Flutter 学习(3)------------通过List或者map循环数据渲染页面。。
    vs2015 编译报错:The project references NuGet package(s) that are missing on this computer...
  • 原文地址:https://www.cnblogs.com/wsq724439564/p/3258209.html
Copyright © 2011-2022 走看看