تقييم الموضوع :
  • 0 أصوات - بمعدل 0
  • 1
  • 2
  • 3
  • 4
  • 5
[VB.NET] احصاء و تمثيل بيانات بChart
#1
السلام عليكم ورحمة الله
حاولت ان احصاء و تمثيل البيانات بChart يعمل عند التحميل فقط ثم لا يتغير عند استعمال ComboBox
اليكم الملف


الملفات المرفقة
.rar   احصاء و تمثيل بيانات.rar (الحجم : 128.78 ك ب / التحميلات : 15)
الرد
تم الشكر بواسطة:
#2
كود :
Imports System.Data.OleDb

Public Class Form1

   Dim DT As New DataTable
   Dim totals() As Integer
   Dim titles() As String = {"ذكر", "أنثى"}

   Private Sub Form1_Load(sender As Object, e As EventArgs) Handles MyBase.Load
       '=========================
       fillcboSubject()
       '=========================
       LoadDataGridView_Subject_Gender()
   End Sub

   Private Sub fillcboSubject()
       'تحميل بيانات المواد في الكومبوبكس
       Subjects_Load()
       '==============================
       ComboBox1.DropDownStyle = ComboBoxStyle.DropDownList
       ComboBox1.DataSource = SubjectDT
       ComboBox1.DisplayMember = "Subject"
       ComboBox1.ValueMember = "ID_Subject"
       ComboBox1.SelectedIndex = -1
       'ComboBox1.Text = "المادة"
   End Sub

   Private Sub LoadDataGridView_Subject_Gender()
       Try

           Dim id = ComboBox1.SelectedValue
           DT.Clear()
           Dim DA As New OleDbDataAdapter("SELECT Subjects.Subject, Teachers.Gender AS Gender, Count(Teachers.ID_Teacher) AS total FROM Teachers,Subjects where (Teachers.ID_Subject = Subjects.ID_Subject) and (Teachers.ID_Subject = " & ComboBox1.SelectedValue & ") GROUP BY Subjects.Subject, Teachers.Gender", con)

           DA.Fill(DT)
           DataGridView1.DataSource = DT
           Data_GridView()

           Dim male As Integer = (From x In DT Where x("Gender").Equals("ذكر") Select x("total")).FirstOrDefault
           Dim female As Integer = (From x In DT Where x("Gender").Equals("أنثى") Select x("total")).FirstOrDefault
           totals = {male, female}

       Catch ex As Exception
       End Try
   End Sub

   Private Sub ComboBox1_SelectionChangeCommitted(sender As Object, e As System.EventArgs) Handles ComboBox1.SelectionChangeCommitted
       LoadDataGridView_Subject_Gender()
       Chart1.Series(0).Points.DataBindXY(titles, totals)
   End Sub


   Private Sub Data_GridView()
       DataGridView1.Columns(0).HeaderText = " المادة"
       DataGridView1.Columns(1).HeaderText = " الجنس"
       DataGridView1.Columns(2).HeaderText = " المجموع"
   End Sub

End Class
الرد
تم الشكر بواسطة: elgokr , elgokr , عبد العزيز البسكري , DOX.1 , DOX.1
#3
شكرا لك اخي 911 على الرد
و لكن النسبة المئوية لم تتحقق
وكذلك اردت لو امكن لماذا لاتتغير في الكود الذي وضعته انا بحيث عند التحميل في المرة الاولى النسبة صحيحىة ثم لاتتغير
الرد
تم الشكر بواسطة: 911 , 911 , elgokr
#4
كود :
Imports System.Data.OleDb

Public Class Form1

   Private Sub Form1_Load(sender As Object, e As EventArgs) Handles MyBase.Load
       '=========================
       fillcboSubject()
       '=========================
       LoadDataGridView_Subject_Gender()
       '=========================
       Data_GridView()
       '=========================
       ComboBox1.Select()
   End Sub

   Private Sub fillcboSubject()
       'تحميل بيانات المواد في الكومبوبكس
       Subjects_Load()
       '==============================
       ComboBox1.DataSource = SubjectDT
       ComboBox1.DisplayMember = "Subject"
       ComboBox1.ValueMember = "ID_Subject"
       If ComboBox1.Items.Count > 0 Then
           ComboBox1.SelectedIndex = 0
       End If
       'ComboBox1.Text = "المادة"
   End Sub

   Dim DT As New DataTable
   Dim total() As Integer
   Dim titles() As String = {"ذكر", "أنثى"}

   Private Sub LoadDataGridView_Subject_Gender()
       Try

           Dim id = ComboBox1.SelectedValue
           DT.Clear()
           Dim DA As New OleDbDataAdapter("SELECT Subjects.Subject, Teachers.Gender AS Gender, Count(Teachers.ID_Teacher) AS total FROM Teachers,Subjects where (Teachers.ID_Subject = Subjects.ID_Subject) and (Teachers.ID_Subject = " & ComboBox1.SelectedValue & ") GROUP BY Subjects.Subject, Teachers.Gender", con)

           DA.Fill(DT)
           DataGridView1.DataSource = DT

           Dim male As Integer = (From x In DT Where x("Gender").Equals("ذكر") Select x("total")).FirstOrDefault
           Dim female As Integer = (From x In DT Where x("Gender").Equals("أنثى") Select x("total")).FirstOrDefault

           If male > 0 Or female > 0 Then
               total = {(male / (male + female)) * 100, (female / (male + female)) * 100}
           Else
               total = {0, 0}
           End If

           charting()

       Catch ex As Exception

       End Try

   End Sub

   Private Sub ComboBox1_SelectionChangeCommitted(sender As Object, e As System.EventArgs) Handles ComboBox1.SelectionChangeCommitted
       LoadDataGridView_Subject_Gender()
       charting()
   End Sub

   Private Sub charting()
       Chart1.Series(0).LabelFormat = "#'%'"
       Chart1.Series(0).Points.DataBindXY(titles, total)
       Chart1.Series(0).IsValueShownAsLabel = True
   End Sub

   Private Sub Data_GridView()

       DataGridView1.Columns(0).HeaderText = " المادة"
       DataGridView1.Columns(1).HeaderText = " الجنس"
       DataGridView1.Columns(2).HeaderText = " المجموع"
   End Sub

End Class
الرد
تم الشكر بواسطة: عبد العزيز البسكري , elgokr
#5
شكرا لك اخي 911 على تعبك معنا وبارك الله فيكم
الرد
تم الشكر بواسطة: 911 , 911 , elgokr , elgokr


المواضيع المحتمل أن تكون متشابهة .
الموضوع : الكاتب الردود : المشاهدات : آخر رد
  مشكلة في برنامج قواعد بيانات وجداول وحقول من نوع اكسس ابراهيم ايبو 2 50 اليوم, 07:17 AM
آخر رد: ابراهيم ايبو
  فكرة مشروع بالفيجوال بيسك وقاعده بيانات اكسس ارجو المساعده خالد كامل1 3 86 18-09-18, 01:34 PM
آخر رد: elgokr
  أستفسار عن حذف بيانات من DataTabel DOX.1 7 136 12-09-18, 07:25 AM
آخر رد: elgokr
Exclamation مشكلة في ربط المشروع بقاعدة بيانات YousefOkasha 21 431 06-09-18, 03:30 PM
آخر رد: elgokr
  [VB.NET] تحديد مسار قاعدة بيانات أكسس Access اثناء تشغيل البرنامج VB.net كريم جودي 3 123 30-08-18, 01:57 PM
آخر رد: elgokr
  ما هى طريقة تحديث قاعدة بيانات - بعد الانتهاء من التصميمم ahmedmansour 8 230 25-08-18, 05:34 PM
آخر رد: elgokr
  [VB.NET] كيف يُمكن طباعة بيانات Datagridview عندما تكون البيانات أكثر من صفحة واحدة Hazem1 3 157 23-08-18, 08:38 PM
آخر رد: elgokr
  [سؤال] طلب مساعدة كود التحكم بعرض بيانات حقل حسابية في التكست بكس على ان لا يظهر لاصفار essawq 11 278 20-08-18, 10:27 PM
آخر رد: elgokr
  [VB.NET] عرض بيانات الدتا جريد فيو عبدالرحمن بشري عمر 1 109 20-08-18, 08:39 PM
آخر رد: elgokr
  [سؤال] طلب مساعدة vb.net: إرسال بيانات من داتاقريدفيو الى نمودج وورد hamzatalbi 2 106 19-08-18, 11:11 PM
آخر رد: aljzazy

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


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