تقييم الموضوع :
  • 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
الرد


المواضيع المحتمل أن تكون متشابهة .
الموضوع : الكاتب الردود : المشاهدات : آخر رد
  مشكلة عند الاتصال ب sql server 2014 bassant 4 125 16-09-21, 02:52 PM
آخر رد: asemshahen5
  مشكلة عند الاتصال ب sql server 2014 bassant 0 101 12-09-21, 01:09 PM
آخر رد: bassant
  [سؤال] مشكلة اضافة التاريخ مع قاعدة بيانات alims 6 828 25-01-21, 02:45 AM
آخر رد: alims
Big Grin مشكلة لسه ماحدش جاوبني عليها cmd.excutenunquery Medo84 0 344 12-01-21, 08:44 PM
آخر رد: Medo84
  مشكلة في إظهار عمود التاريخ في داتا جريد فيو mofhmy 5 4,661 12-11-20, 12:13 PM
آخر رد: bahaa.elkomy@yahoo.com
Heart مشكلة ال ID في عدم تخزين وترتيب البيانات بشكل منتظم الرائد 5 1,609 18-07-19, 01:42 AM
آخر رد: الرائد
  [سؤال] مشكلة بـ كود جمع حقل الاجمالي norman 0 1,101 06-07-19, 02:47 AM
آخر رد: norman
  [SQL] مشكلة في ربط قاعدة البيانات SQLSERVER2014 بـ فيجول بيسك 2017 اباذر 4 1,877 16-03-19, 12:00 AM
آخر رد: اباذر
  مشكلة في كود صلاحيات المستخدمين مصمم هاوي 4 1,242 30-01-19, 06:32 PM
آخر رد: عبد العزيز البسكري
  مشكلة قاعدة البيانات لا تقبل البيانات بعد التنصيب abozeyd 8 2,289 10-09-18, 08:02 AM
آخر رد: elgokr

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


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