Register Register Member Login Member Login Member Login Forgot Password ??
PHP , ASP , ASP.NET, VB.NET, C#, Java , jQuery , Android , iOS , Windows Phone
 

Registered : 109,037

HOME > .NET Framework > Forum > asp.net ระบบตระกร้าสินค้า รบกวนช่วยดูการบันทึกค่าที่แสดงใน GridView ให้ทีครับผม



 

asp.net ระบบตระกร้าสินค้า รบกวนช่วยดูการบันทึกค่าที่แสดงใน GridView ให้ทีครับผม

 



Topic : 085556



โพสกระทู้ ( 3 )
บทความ ( 0 )



สถานะออฟไลน์




ผมลองฝึกทำระบบตระกร้าสินค้าตามลิ้งนี้ครับ

https://www.thaicreate.com/free-web-script/asp-net-create-shopping-cart-step-by-step.html

ในหน้า ViewCart.aspx.cs อยากทราบว่าถ้าเราต้องการเพิ่ม "ราคารวม" ลงใน ODt_Price ต้องเขียนยังไงหรอครับ
เพราะ lblTotal ไม่ได้ bind กับ ODt_Price อะครับ

ห

่้ll

Code (ASP)
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data;
using System.Data.SqlClient;
using System.Text;



public partial class Viewcart : System.Web.UI.Page
{
    protected double strTotal = 0;
    protected double strSumTotal = 0;

    protected void Page_Load(object sender, EventArgs e)
    {
        df();
        BindGird();
        this.lblSumTotal.Text = strSumTotal.ToString("#,###.00");
    }
    protected void connect_db()
    {
        try
        {
            dbcon.connecToDB();
            Response.Write("เชื่อมต่อฐานข้อมูลสำเร็จ<br />");
        }
        catch (Exception ex)
        {
            Response.Write("เชื่อมต่อฐานข้อมุลไม่สำเร็จ <br />" + ex);
        }
    }
    protected void df()
    {
        if (Session["cususer"] == null)
        {
            Response.Redirect("Login.aspx");
        }
    }
    protected void BindGird()
    {
        DataTable dt = (DataTable)Session["myCart"];
        this.GridView1.DataSource = dt;
        this.GridView1.DataBind();
    }
    
   
     
    protected void GridView1_RowCommand(object sender, GridViewCommandEventArgs e)
    {
        if (e.CommandName == "Del")
        {
            int RowsID = Convert.ToInt32(e.CommandArgument);
            DataTable dt = null;

            dt = (DataTable)Session["myCart"];

            dt.Rows[RowsID].Delete();

            Session["myCart"] = dt;

            Response.Redirect("ViewCart.aspx");

        }
    }
    protected DataTable getProductDet(string strProductID)
    {
       

           connect_db();
           SqlCommand cmd = new SqlCommand("select * from [Product] WHERE Pro_ID = " + strProductID + " ", dbcon.conn);
           SqlDataReader read = cmd.ExecuteReader();
           DataTable dt = new DataTable();
           dt.Load(read);
           dbcon.closeDB();
           return dt;

    }
    protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
    {
        if (e.Row.RowType == DataControlRowType.DataRow)
        {
            //*** ProductID ***//
            Label lblProductID = (Label)e.Row.FindControl("lblProductID");
            if ((lblProductID != null))
            {
                lblProductID.Text = DataBinder.Eval(e.Row.DataItem, "Pro_ID").ToString();
            }

            DataTable dt = getProductDet(DataBinder.Eval(e.Row.DataItem, "Pro_ID").ToString());

            //*** ProductName ***//
            Label lblProductName = (Label)e.Row.FindControl("lblProductName");
            if ((lblProductName != null))
            {
                lblProductName.Text = dt.Rows[0]["Pro_Name"].ToString();
            }

            //*** Price ***//
            Label lblPrice = (Label)e.Row.FindControl("lblPrice");
            if ((lblPrice != null))
            {
                lblPrice.Text = dt.Rows[0]["Pro_PricePerUnit"].ToString();
            }

            //*** Qty ***//
            Label lblQty = (Label)e.Row.FindControl("lblQty");
            if ((lblQty != null))
            {
                lblQty.Text = DataBinder.Eval(e.Row.DataItem, "ODt_Amount").ToString();
            }

            //*** Total ***//
            Label lblTotal = (Label)e.Row.FindControl("lblTotal");
            if ((lblTotal != null))
            {
                strTotal = Convert.ToDouble(DataBinder.Eval(e.Row.DataItem, "ODt_Amount")) * Convert.ToDouble(dt.Rows[0]["Pro_PricePerUnit"]);
                strSumTotal = Convert.ToDouble(strSumTotal) + strTotal;
                lblTotal.Text = strTotal.ToString("#,###.00");
            }

            //*** Delete ***//
            LinkButton lnkDelete = (LinkButton)e.Row.FindControl("lnkDelete");
            if ((lnkDelete != null))
            {
                lnkDelete.Text = "Delete";
                lnkDelete.CommandName = "Del";
                lnkDelete.CommandArgument = e.Row.RowIndex.ToString();
                lnkDelete.Attributes.Add("OnClick", "return confirm('Delete this row?');");
            }

        }
    }
    protected void lnkClearCart_Click(object sender, EventArgs e)
    {

        Session.Remove("myCart");
        Response.Redirect("Viewcart.aspx");
    }
    protected void lnkCheckOut_Click(object sender, EventArgs e)
    {
        DataTable dt = (DataTable)Session["myCart"];

        if (Session["myCart"] != null)
        {
            if (dt.Rows.Count > 0)
            {
                this.pnlCheckOut.Visible = true;
            }
        }
    }
    protected void btnSave_Click(object sender, EventArgs e)
    {
       
        string str = null;
        DataTable dt2 = null;
        string strOrderID = "0";
        int i = 0;
     
        connect_db();
        
       str = "insert into Orders (Order_Date,Cus_ID,Order_Name,Order_Address,Order_Tel,Order_PriceAll) " + " VALUES " + " (@sOrderDate,@sid,@sName,@sAddress,@sTel,@sss)";
        SqlCommand insert = new SqlCommand(str, dbcon.conn);
        insert.Parameters.AddWithValue("@sOrderDate", DateTime.Now.ToString("MM/dd/yyyy"));
         insert.Parameters.AddWithValue("@sid", txtid.Text);
        insert.Parameters.AddWithValue("@sName", txtName.Text);
        insert.Parameters.AddWithValue("@sAddress", txtAddress.Text);
        insert.Parameters.AddWithValue("@sTel", txtTel.Text);
        insert.Parameters.AddWithValue("@sss", lblSumTotal.Text);
        insert.ExecuteNonQuery();


        str = "SELECT Max(Order_ID) As sOrderID FROM Orders ";
        SqlDataAdapter da = new SqlDataAdapter(str, dbcon.conn);
        DataTable dt1 = new DataTable();
        da.Fill(dt1);
        if (dt1.Rows.Count > 0)
        {
            strOrderID = dt1.Rows[0]["sOrderID"].ToString();
        }
        dt2 = (DataTable)Session["myCart"];
        for (i = 0; i <= dt2.Rows.Count - 1; i++)
        { 


            str = "INSERT INTO OrderDetail (Order_ID,Pro_ID,ODt_Amount,ODt_Price) " + " VALUES " + " ('" + strOrderID + "','" + dt2.Rows[i]["Pro_ID"] + "','" + dt2.Rows[i]["ODt_Amount"] + "')";
            var _with1 = insert;
            _with1.CommandText = str;
            _with1.CommandType = CommandType.Text;
            _with1.ExecuteNonQuery();
            
           
        }
        SqlCommand cmd = new SqlCommand("update [Orders] set Order_Status='please payment' where Order_ID=" + strOrderID + "", dbcon.conn);

            
            cmd.ExecuteNonQuery();
        dbcon.closeDB();

        Session.Remove("myCart");
        Response.Redirect("Vieworder.aspx?Order_ID=" + strOrderID);

       
        }
    
        
    }


ผมลองแก้ตรงส่วนนี้ดู

Code (ASP)
 str = "INSERT INTO OrderDetail (Order_ID,Pro_ID,ODt_Amount,ODt_Price) " + " VALUES " + " ('" + strOrderID + "','" + dt2.Rows[i]["Pro_ID"] + "','" + dt2.Rows[i]["ODt_Amount"] + "','" + strTotal + "')";


ผลออกมาแบบนี้ครับ มันบันทึกราคารวมอันสุดท้ายลงไปอะครับ
hht
กกก

รบกวนช่วบดูให้ผมทีนะครับ ขอบคุณครับ



Tag : .NET









ประวัติการแก้ไข
2012-10-17 18:43:40
Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2012-10-17 18:40:41 By : alee62 View : 1228 Reply : 1
 

 

No. 1



โพสกระทู้ ( 74,058 )
บทความ ( 838 )

สมาชิกที่ใส่เสื้อไทยครีเอท

สถานะออฟไลน์
Twitter Facebook

คุณก็แทรกการคำนวณใน Loop ก่อน Insert ด้วยครับ

Code
dt2 = (DataTable)Session["myCart"]; for (i = 0; i <= dt2.Rows.Count - 1; i++) { strTotal = Convert.ToDouble(DataBinder.Eval(e.Row.DataItem, "ODt_Amount")) * Convert.ToDouble(dt.Rows[0]["Pro_PricePerUnit"]); str = "INSERT INTO OrderDetail (Order_ID,Pro_ID,ODt_Amount,ODt_Price) " + " VALUES " + " ('" + strOrderID + "','" + dt2.Rows[i]["Pro_ID"] + "','" + dt2.Rows[i]["ODt_Amount"] + "')"; var _with1 = insert; _with1.CommandText = str; _with1.CommandType = CommandType.Text; _with1.ExecuteNonQuery(); }


ดู Syntax ให้ถูกด้วยครับ






แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2012-10-18 09:47:00 By : mr.win
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : asp.net ระบบตระกร้าสินค้า รบกวนช่วยดูการบันทึกค่าที่แสดงใน GridView ให้ทีครับผม
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ FTP| ใส่แถวของตาราง ใส่คอลัมน์ตาราง| ตัวยก ตัวห้อย ตัวพิมพ์ดีด| ใส่โค้ด ใส่การอ้างถึงคำพูด| ใส่ลีสต์
smiley for :lol: smiley for :ken: smiley for :D smiley for :) smiley for ;) smiley for :eek: smiley for :geek: smiley for :roll: smiley for :erm: smiley for :cool: smiley for :blank: smiley for :idea: smiley for :ehh: smiley for :aargh: smiley for :evil:
Insert PHP Code
Insert ASP Code
Insert VB.NET Code Insert C#.NET Code Insert JavaScript Code Insert C#.NET Code
Insert Java Code
Insert Android Code
Insert Objective-C Code
Insert XML Code
Insert SQL Code
Insert Code
เพื่อความเรียบร้อยของข้อความ ควรจัดรูปแบบให้พอดีกับขนาดของหน้าจอ เพื่อง่ายต่อการอ่านและสบายตา และตรวจสอบภาษาไทยให้ถูกต้อง

อัพโหลดแทรกรูปภาพ

Notice

เพื่อความปลอดภัยของเว็บบอร์ด ไม่อนุญาติให้แทรก แท็ก [img]....[/img] โดยการอัพโหลดไฟล์รูปจากที่อื่น เช่นเว็บไซต์ ฟรีอัพโหลดต่าง ๆ
อัพโหลดแทรกรูปภาพ ให้ใช้บริการอัพโหลดไฟล์ของไทยครีเอท และตัดรูปภาพให้พอดีกับสกรีน เพื่อความโหลดเร็วและไฟล์ไม่ถูกลบทิ้ง

   
  เพื่อความปลอดภัยและการตรวจสอบ กระทู้ที่แทรกไฟล์อัพโหลดไฟล์จากที่อื่น อาจจะถูกลบทิ้ง
 
โดย
อีเมล์
บวกค่าให้ถูก
<= ตัวเลขฮินดูอารบิก เช่น 123 (หรือล็อกอินเข้าระบบสมาชิกเพื่อไม่ต้องกรอก)







Exchange: นำเข้าสินค้าจากจีน, Taobao, เฟอร์นิเจอร์, ของพรีเมี่ยม, ร่ม, ปากกา, power bank, แฟลชไดร์ฟ, กระบอกน้ำ

Load balance : Server 00
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2024 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
[Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 อัตราราคา คลิกที่นี่