تقييم الموضوع :
  • 0 أصوات - بمعدل 0
  • 1
  • 2
  • 3
  • 4
  • 5
مشكلة في الترقيم التلقائي للطلبة حسب السنة الدراسية
#1
السلام عليكم 


إخواني لدى ثلاثة سنوات دراسية (الصف الاول . الصف الثاني, الصف الثالث ) و هي قيمة textbox3
اريد عمل رقم دراسي لكل طالب حسب السنة الدراسية 
إذا كان السنة الاولى تبدأ الارقام من 100 
إذا كان السنة الثانية تبدأ الارقام من 200 
و إذا كان السنة الثالثة تبدأ الارقام من 300 
textbox1 هو الترقيم المتسلسل للطلبة 
حاولت عمل الكود التالي و لكن للأسف لم ينجح 
كود :
 Function add_id()
       Dim noa As Integer
       Dim billno As New OleDbCommand("SELECT max(std_no) From stdinfo WHERE (((stdinfo.std_year)=" & TextBox3.Text.Trim & "))", cn)
       'If cn.State = ConnectionState.Open Then con.Close()
       If cn.State = ConnectionState.Closed Then
           cn.Open()
       End If
       If billno.ExecuteScalar IsNot DBNull.Value Then
           noa =1
       Else
           noa = billno.ExecuteScalar + 1
       End If
       Return noa
   End Function


و أستدعيت الدالة هنا 

كود :
Private Sub TextBox3_TextChanged(ByVal sender As Object, ByVal e As System.EventArgs) Handles TextBox3.TextChanged
       If TextBox3.Text = 1 Then
           If add_id() = 1 Then
               TextBox1.Text = 100

           End If
       End If
       If TextBox3.Text = 2 Then
           If add_id() = 1 Then
               TextBox1.Text = 200

           End If

       End If
       If TextBox3.Text = 3 Then
           If add_id() = 1 Then
               TextBox1.Text = 300

           End If
       End If
   End Sub
لكن للأسف دائما الدالة ترجع بيقمة (1) بالرغم من وجود سجل يحمل رقم طالب
الرد }}}
تم الشكر بواسطة:
#2
بعد جهد ليس بقليل .. 
جللت المشلة ولله الحمد 
و الكود التالي يوضح الحل لعل احد المتصغحين يستفيد منه 
كود :
Function add_id()
       Dim noa As Integer
       Dim billno As New OleDbCommand("SELECT max(std_no) From stdinfo WHERE (((stdinfo.std_year)=" & TextBox3.Text.Trim & "))", cn)

       
       Dim total = Convert.ToInt32(IsDBNull(billno.ExecuteScalar))
       If cn.State = ConnectionState.Closed Then
           cn.Open()
       End If
       If IsDBNull(total.ToString) Then
           noa = 1
       Else
           If IsDBNull(billno.ExecuteScalar) Then
               noa = 1
           Else
               noa = total.ToString(billno.ExecuteScalar) + 1
           End If


       End If
       Return noa
   End Function
الرد }}}


المواضيع المحتمل أن تكون متشابهة .
الموضوع : الكاتب الردود : المشاهدات : آخر رد
  مشكلة فى الجريد فيو salah525 10 530 05-11-23, 08:15 PM
آخر رد: justforit
Big Grin مشكلة لسه ماحدش جاوبني عليها cmd.excutenunquery Medo84 1 1,301 27-08-23, 12:47 PM
آخر رد: رضوان الجماعي
  مشكلة عند الاتصال ب sql server 2014 bassant 1 1,003 27-08-23, 12:26 PM
آخر رد: رضوان الجماعي
  [سؤال] مشكلة فى عرض الصورة من ادخل قاعدة البيانات alims 2 1,259 17-11-21, 10:09 AM
آخر رد: سعود
  مشكلة ظهور بياانات حقلين في قاعدة بيانات على شكل علامة استفهام bassant 5 1,632 17-10-21, 02:07 PM
آخر رد: abubasilIraq
  مشكلة عند الاتصال ب sql server 2014 bassant 4 1,412 16-09-21, 02:52 PM
آخر رد: asemshahen5
  [سؤال] مشكلة اضافة التاريخ مع قاعدة بيانات alims 6 2,335 25-01-21, 02:45 AM
آخر رد: alims
  مشكلة في إظهار عمود التاريخ في داتا جريد فيو mofhmy 5 6,555 12-11-20, 12:13 PM
آخر رد: bahaa.elkomy@yahoo.com
Heart مشكلة ال ID في عدم تخزين وترتيب البيانات بشكل منتظم الرائد 5 3,160 18-07-19, 01:42 AM
آخر رد: الرائد
  [سؤال] مشكلة بـ كود جمع حقل الاجمالي norman 0 1,836 06-07-19, 02:47 AM
آخر رد: norman

التنقل السريع :


يقوم بقرائة الموضوع: بالاضافة الى ( 1 ) ضيف كريم