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 > สอบถามครับ เรื่องการแจกรหัสใน Datagridview ครับ ไม่รู้จะทำยังไงดีครับ



 

สอบถามครับ เรื่องการแจกรหัสใน Datagridview ครับ ไม่รู้จะทำยังไงดีครับ

 



Topic : 117093



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



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




นี่เป็นโค้ดของการบันทึกข้อมูลจาก datagridview น่ะครับ

เป้นการบันทึกข้อมูลจากตาราง Datagridview แบบที่เดียวรวดครับ แต่ผมต้องการให้ขณะที่มัน ลูปบันทึก

ผมต้องการแอดรหัสใส่ข้อมูลแต่ละเร็คคอร์ดครับ รบกวนผู้รู้แนะนำหน่อยครับ ว่าต้องแก้ไขยังไงบ้างครับ ขอบคุณครับ

Code (VB.NET)
        strsql = "INSERT INTO GoodsReceive_Detail (re_id_m,re_id_detail,name_re_m,type_id,type_id_sub) VALUES (@re_id_m,@re_id_detail,@name_re_m,@type_id,@type_id_sub)"

        For i As Integer = 0 To DataGridView1.RowCount - 1
            If Not DataGridView1.Rows(i).IsNewRow Then
                connectdb()
                cm = New SqlCommand(strsql, cn)
                With cm
                    .Parameters.Add(New SqlParameter("@re_id_m", txtRe_id_m.Text))
                    .Parameters.Add(New SqlParameter("@re_id_detail", txtre_id_detail.Text))
                    .Parameters.Add(New SqlParameter("@name_re_m", DataGridView1.Rows(i).Cells(2).Value))
                    .Parameters.Add(New SqlParameter("@type_id", DataGridView1.Rows(i).Cells(3).Value))
                    .Parameters.Add(New SqlParameter("@type_id_sub", DataGridView1.Rows(i).Cells(4).Value))
                End With
                cm.ExecuteNonQuery()
                cm.Parameters.Clear()
                closedb()
            End If
        Next

        MessageBox.Show("บันทึกข้อมูลรายการรับ เรียบร้อยแล้ว", "", MessageBoxButtons.OK, MessageBoxIcon.Information)

        Me.Dispose()


ผมมี Sub ที่สำหรับตรวจสอบค่าก่อน แล้วเพิ่มค่าให้ แล้วค่อยไปบันทึกอีกทีครับ

Code (VB.NET)
 Sub AutoID()

        Dim S As String

        strsql = "SELECT MAX(RIGHT(re_id_detail,5)) AS max_id FROM GoodsReceive_Detail"
        connectdb()
        cm = New SqlCommand(strsql, cn)
        rs = cm.ExecuteReader

        rs.Read()
        If Not rs.HasRows Then
            S = "000001"
        Else
            i = rs.Item("max_id")
            i += 1
            S = i.ToString("000000")
        End If
        closedb()

        txtre_id_detail.Text = txt4.Text & S

    End Sub


รวบกวนช่วยดูให้หน่อยนะครับ ติดนานมากตัวนี้ ควรแก้ยังไงดีครับ



Tag : .NET, Ms SQL Server 2005, VS 2005 (.NET 2.x)







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2015-06-11 17:45:22 By : nameball View : 918 Reply : 5
 

 

No. 1



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



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









แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-06-12 09:03:46 By : nameball
 


 

No. 2



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



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


เอา function นี้ไปรันใน sql server น่ะ
ปล. เลือก Database ให้ถูกด้วยล่ะ

Code (SQL)
create function fnGetDocNo() returns varchar(5) as
begin
	declare @value varchar(5)
	declare @result varchar(5)
	select @value = max(re_id_detail) from GoodsReceive_Detail;

	if(@value is null) 
		set @result = '00001'
		else
		set @result = right('0000'+cast(@value+1 as varchar(5)),5);

	return @result;
end;


insert ก็น่าจะเขียนประมาณนี้ล่ะ
Code (VB.NET)
strsql = "INSERT INTO GoodsReceive_Detail (re_id_m,re_id_detail,name_re_m,type_id,type_id_sub) VALUES (@re_id_m,@re_id_detail,@name_re_m,@type_id,@type_id_sub)"

For i As Integer = 0 To DataGridView1.RowCount - 1
    If Not DataGridView1.Rows(i).IsNewRow Then
        connectdb()
        cm = New SqlCommand(strsql, cn)
        With cm
            .Parameters.Add(New SqlParameter("@re_id_m", txtRe_id_m.Text))
            .Parameters.Add(New SqlParameter("@re_id_detail", "fnGetDocNo()")) '-----เรียกใช้ function fnGetDocNo จ้า
            .Parameters.Add(New SqlParameter("@name_re_m", DataGridView1.Rows(i).Cells(2).Value))
            .Parameters.Add(New SqlParameter("@type_id", DataGridView1.Rows(i).Cells(3).Value))
            .Parameters.Add(New SqlParameter("@type_id_sub", DataGridView1.Rows(i).Cells(4).Value))
        End With
        cm.ExecuteNonQuery()
        cm.Parameters.Clear()
        closedb()
    End If
Next

MessageBox.Show("บันทึกข้อมูลรายการรับ เรียบร้อยแล้ว", "", MessageBoxButtons.OK, MessageBoxIcon.Information)

Me.Dispose()

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-06-12 09:53:27 By : ipstarone
 

 

No. 3



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



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


ขอบคุณ คุณ ipstarone สำหรับแนวทางนะครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-06-12 10:29:20 By : nameball
 


 

No. 4



โพสกระทู้ ( 4,440 )
บทความ ( 23 )



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

Code (VB.NET)
strsql = "INSERT INTO GoodsReceive_Detail (re_id_m,re_id_detail,name_re_m,type_id,type_id_sub) VALUES (@re_id_m,@re_id_detail,@name_re_m,@type_id,@type_id_sub)"

For i As Integer = 0 To DataGridView1.RowCount - 1
    If Not DataGridView1.Rows(i).IsNewRow Then
AutoID()'Sub ที่สำหรับตรวจสอบค่าก่อน แล้วเพิ่มค่าให้ แล้วค่อยไปบันทึกอีกทีครับ
        connectdb()
    
        cm = New SqlCommand(strsql, cn)
        With cm
            .Parameters.Add(New SqlParameter("@re_id_m", txtRe_id_m.Text))
            .Parameters.Add(New SqlParameter("@re_id_detail", txtre_id_detail.Text))
            .Parameters.Add(New SqlParameter("@name_re_m", DataGridView1.Rows(i).Cells(2).Value))
            .Parameters.Add(New SqlParameter("@type_id", DataGridView1.Rows(i).Cells(3).Value))
            .Parameters.Add(New SqlParameter("@type_id_sub", DataGridView1.Rows(i).Cells(4).Value))
        End With
        cm.ExecuteNonQuery()
        cm.Parameters.Clear()
        closedb()
    End If

Next

MessageBox.Show("บันทึกข้อมูลรายการรับ เรียบร้อยแล้ว", "", MessageBoxButtons.OK, MessageBoxIcon.Information)

Me.Dispose()

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-06-12 10:34:20 By : lamaka.tor
 


 

No. 5



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



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


ตอบความคิดเห็นที่ : 4 เขียนโดย : lamaka.tor เมื่อวันที่ 2015-06-12 10:34:20
รายละเอียดของการตอบ ::
ขอบคุณครับ

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-06-12 13:31:26 By : nameball
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : สอบถามครับ เรื่องการแจกรหัสใน Datagridview ครับ ไม่รู้จะทำยังไงดีครับ
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ 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 อัตราราคา คลิกที่นี่