IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> C# Windows窗体应用与SQL Server制作的选课系统 -> 正文阅读

[大数据]C# Windows窗体应用与SQL Server制作的选课系统

C# Windows窗体应用与SQL Server制作的选课系统

项目要求

北理工小学期数据库大作业
设计数据库,基本信息包括学生、课程、教师,学生从已分配教师的课程列表中选择相应的课程(课程列表项信息包括:课程名称、学分、授课教师、授课时间等,可以手工录入已分配教师、上课时间的课程列表信息)。
选课规则:每个学生最少选择3门课程,学分高于8学分,最多可以选择5门课程,学分不超过12学分。
实现下列功能:
(1) 录入学号,自动显示学生姓名。
(2) 在可选择课程列表上方显示已选择的课程列表,可以从已选择的课程列表中删除已选择的课程。
(3) 显示可选择的课程列表(不包含已选择的课程),可以按规则选择3-5门课程,选择的课程自动从可选课程列表中移至已选课程列表。
(4) 显示当前学生选择的课程数量、总学分。
(5) 可以临时保存学生选择的课程信息,如果符合选课规则(3-5门、学分:8-12学分),则可提交选课结果。

项目成果

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

项目源码

主要form代码如下:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Data.SqlClient;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace chosesubject
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
            InitDataGridView();
        }

        string studentid;
        string sqlconnectioncommand = "Data Source=数据库地址;Initial Catalog=使用的数据库名称;Uid=用户名;Pwd=密码";

        int ischosenum = 0;
        int ischosecredit = 0;
        private void button_SelectName_Click(object sender, EventArgs e)
        {
            if (textBox_studentid.Text.Length != 0)
            {
                studentid = textBox_studentid.Text;
                string queryString = "SELECT student_name FROM dbo.student where student_id = " + studentid;
                using (SqlConnection connection = new SqlConnection(sqlconnectioncommand))
                {
                    SqlCommand command = new SqlCommand(queryString, connection);
                    connection.Open();
                    using (SqlDataReader reader = command.ExecuteReader())
                    {
                        if (reader.Read())
                        {
                            label_studentname_show.Text = (string)reader[0];
                            updatedatagrip();
                        }
                        else
                        {
                            label_studentname_show.Text = "查无此人";
                            MessageBox.Show("查无此人");
                        }
                    }
                }

            }
            else
            {
                MessageBox.Show("学号不能为空");
            }
        }

        private void updatedatagrip()
        {
            ischosenum = 0;
            ischosecredit = 0;

            //查询该用户已经选的课
            List<Int32> subject_has_chose = new List<Int32>();
            string queryString = "SELECT C_ID FROM dbo.subject_chose_" + studentid;
            using (SqlConnection connection = new SqlConnection(sqlconnectioncommand))
            {
                SqlCommand command = new SqlCommand(queryString, connection);
                connection.Open();
                using (SqlDataReader reader = command.ExecuteReader())
                {
                    while (reader.Read())
                    {
                        subject_has_chose.Add((Int32)reader[0]);
                    }
                }
            }

            DataGridView_down.Rows.Clear();
            DataGridView_top.Rows.Clear();

            //所有课表
            queryString = "SELECT * FROM dbo.curriculum";
            using (SqlConnection connection = new SqlConnection(sqlconnectioncommand))
            {
                SqlCommand command = new SqlCommand(queryString, connection);
                connection.Open();

                using (SqlDataReader reader = command.ExecuteReader())
                {
                    while (reader.Read())
                    {
                        int subjectid = (Int32)reader[0];
                        Object[] row = new object[6];
                        row[0] = subjectid;
                        row[1] = (string)reader[1];
                        row[2] = (string)reader[2];
                        int credit = (Int32)reader[3];
                        row[3] = credit;
                        row[4] = (string)reader[4];
                        if (subject_has_chose.Exists(x => x == subjectid))
                        {//已经选的课
                            DataGridView_top.Rows.Add(row);
                            ischosenum++;
                            ischosecredit += credit;
                        }
                        else
                        {
                            DataGridView_down.Rows.Add(row);
                        }
                    }
                }
            }
            label_mid.Text = "已选课程数量:" + ischosenum + " ,已选学分:" + ischosecredit;
        }

        private void InitDataGridView()
        {
            //上,已选课程
            DataGridView_top.ColumnCount = 5;
            DataGridView_top.ColumnHeadersDefaultCellStyle.BackColor = Color.Navy;
            DataGridView_top.ColumnHeadersDefaultCellStyle.ForeColor = Color.White;
            DataGridView_top.ColumnHeadersDefaultCellStyle.Font = new Font(DataGridView_top.Font, FontStyle.Bold);
            DataGridView_top.Columns[0].Name = "课程ID";
            DataGridView_top.Columns[1].Name = "课程名称";
            DataGridView_top.Columns[2].Name = "授课老师";
            DataGridView_top.Columns[3].Name = "学分";
            DataGridView_top.Columns[4].Name = "时间";
            DataGridView_top.SelectionMode = DataGridViewSelectionMode.FullRowSelect;
            DataGridView_top.MultiSelect = false;
            //下,待选课程
            DataGridView_down.ColumnCount = 5;
            DataGridView_down.ColumnHeadersDefaultCellStyle.BackColor = Color.Navy;
            DataGridView_down.ColumnHeadersDefaultCellStyle.ForeColor = Color.White;
            DataGridView_down.ColumnHeadersDefaultCellStyle.Font = new Font(DataGridView_top.Font, FontStyle.Bold);
            DataGridView_down.Columns[0].Name = "课程ID";
            DataGridView_down.Columns[1].Name = "课程名称";
            DataGridView_down.Columns[2].Name = "授课老师";
            DataGridView_down.Columns[3].Name = "学分";
            DataGridView_down.Columns[4].Name = "时间";
            DataGridView_down.SelectionMode = DataGridViewSelectionMode.FullRowSelect;
            DataGridView_down.MultiSelect = true;

            DataGridView_top.Columns[0].DisplayIndex = 0;
            DataGridView_top.Columns[1].DisplayIndex = 1;
            DataGridView_top.Columns[2].DisplayIndex = 2;
            DataGridView_top.Columns[3].DisplayIndex = 3;
            DataGridView_top.Columns[4].DisplayIndex = 4;

            DataGridView_down.Columns[0].DisplayIndex = 0;
            DataGridView_down.Columns[1].DisplayIndex = 1;
            DataGridView_down.Columns[2].DisplayIndex = 2;
            DataGridView_down.Columns[3].DisplayIndex = 3;
            DataGridView_down.Columns[4].DisplayIndex = 4;
        }

        private void button_select_Click(object sender, EventArgs e)
        {
            if (DataGridView_down.SelectedRows.Count + ischosenum >= 3 && DataGridView_down.SelectedRows.Count + ischosenum <= 5)
            {
                int chosecredit = 0;
                Console.WriteLine(DataGridView_down.SelectedRows);
                foreach (DataGridViewRow selectrow in DataGridView_down.SelectedRows)
                {
                    chosecredit += (int)selectrow.Cells[3].Value;
                }

                if (chosecredit +ischosecredit >= 8 && chosecredit + ischosecredit <= 12)
                {
                    using (SqlConnection connection = new SqlConnection(sqlconnectioncommand))
                    {
                        connection.Open();
                        foreach (DataGridViewRow selectrow in DataGridView_down.SelectedRows)
                        {
                            if (selectrow.Cells[0].Value != null)
                            {
                                int choseid = (int)selectrow.Cells[0].Value;
                                string queryString = "INSERT dbo.subject_chose_" + studentid + " values(" + choseid + ")";
                                SqlCommand command = new SqlCommand(queryString, connection);
                                command.ExecuteNonQuery();
                            }
                            else
                            {
                                MessageBox.Show("请不要选择空行");
                            }
                        }
                    }
                    updatedatagrip();
                }
                else
                {
                    MessageBox.Show("您选择了"+ chosecredit + "个学分,请按规定一共选择8-12学分");
                }
            }
            else
            {
                MessageBox.Show("您选择了" + DataGridView_down.SelectedRows.Count + "门课,按规定一共选择3-5门课");
            }
        }

        private void button_delete_Click(object sender, EventArgs e)
        {
            if (DataGridView_top.SelectedRows.Count == 1)
            {
                using (SqlConnection connection = new SqlConnection(sqlconnectioncommand))
                {
                    connection.Open();
                    foreach (DataGridViewRow selectrow in DataGridView_top.SelectedRows)
                    {
                        if(selectrow.Cells[0].Value != null)
                        {
                            int choseid = (int)selectrow.Cells[0].Value;
                            string queryString = "DELETE dbo.subject_chose_" + studentid + " where C_ID = " + choseid;
                            SqlCommand command = new SqlCommand(queryString, connection);
                            command.ExecuteNonQuery();
                        }
                        else
                        {
                            MessageBox.Show("请不要选择空值");
                        }
                    }
                }
                updatedatagrip();
            }
            else
            {
                MessageBox.Show("您未选择课程");
            }
        }
    }
}

展示视频

bilibili地址

源码地址

GitHub地址

End

时间较为仓促,尚不完美的完成了项目。
项目仅供参考,本人有最终解释权。

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-09-19 08:02:49  更:2021-09-19 08:02:53 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/18 12:57:54-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码