基于C#+SQL Server2008实现(CS界面)学生宿舍管理系统

1 概述

本次课程设计是数据库课程设计,我选的是学生宿舍管理系统,功能块主要是宿舍管理、学生管理、出入登记和来访登记,目的在于将学生宿舍的管理实现信息化,监控学生宿舍的情况防止意外发生。

课程设计任务的需求分析

2.1设计任务

设计出一个方便进行宿舍管理的系统的数据库。

2.2设计要求

假定学校有多栋宿舍楼,每栋楼有多层,每层有多个寝室,每个寝室可住多名学生,学生宿舍管理系统对学校的学生宿舍进行规范管理,其管理的对象如下:

.宿舍信息:编号、楼层、床位数、单价等。

.学生:学号、姓名、性别、年龄、所在院系、年级、电话等。

每个宿舍最多可以住4位同学,每个同学只能在一个宿舍,不同宿舍的费用标准可以不同。不同院系、年级的同学可以住同一间宿舍。

系统要能够对宿舍、学生、住宿信息进行登记、调整,并能随时进行各种查询、统计等处理。包括:

.寝室分配:根据院系、年级分配寝室。

.学生管理:实现入住学生信息的登记、维护和查询功能。

.信息查询:按公寓楼号、学生姓名等查询住宿信息。

.出入登记:对学生进出公寓的情况进行登记、实现基本的出、入监控功能。

2.3需求描述的规范文档

  1. 宿舍情况查询和清空宿舍;
  2. 学生信息查询和修改、删除和添加;
  3. 学生出入登记;
  4. 来访登记;
  5. 权限管理,包括三种权限(宿舍管理员、高级管理员和超级管理员);
  6. 宿舍管理员可以编辑出入登记和来访登记,但是不能操作学生信息和宿舍信息,只能查询;
  7. 高级管理员可以操作学生信息和宿舍信息但是不能编辑出入登记和来访登记;
  8. 超级管理员除了高级管理员的权限外还能对高级管理员和宿舍管理员的用户进行添加和删除修改。

3 概念结构设计

3.1概念结构设计工具(E-R模型)

使用E-R图作为概念结构设计工具,构建出数据库E-R模型。

3.2管理员子系统

3.2.1子系统描述

管理员表:id,名字,密码,联系方式,权限。

其中主键为id。

3.2.2分E-R图

3.2.3说明

管理员表用于记录管理员信息。

3.3宿舍子系统

3.3.1 子系统描述

``宿舍表:id,宿舍管理员id,宿舍号(如C),宿舍楼号,宿舍学生性别。

``其中主键为id,外键为宿舍管理员id。

3.3.2 分E-R图

3.3.3 说明

宿舍表用于记录已有宿舍信息。

3.4房间子系统

3.4.1 子系统描述

房间表:id,宿舍id,房间号,价格。

其中主键为id,外键为宿舍id。

3.4.2 分E-R图

3.4.3 说明

房间表用于记录房间信息。

3.5学生子系统

3.5.1子系统描述

学生表:id,学号,姓名,性别,年龄,联系方式,学院id,专业id,年级,宿舍id,房间id。

其中主键为id,外键为学院id,专业id,宿舍id,房间id。

3.5.2分E-R图

3.5.3说明

学生表用于记录学生信息。

3.6院系子系统

3.6.1子系统描述

院系专业表:id,院系名字,所属学院id。

其中主键为id,外键为所属学院id。

3.6.2分E-R图

3.6.3说明

院系专业表用于记录院系专业信息。

3.7出入登记子系统

3.7.1 子系统描述

出入登记表:id,宿舍id,学生id,出去时间,返回时间。

其中主键为id,外键为宿舍id,学生id。

3.7.2 分E-R图

3.7.3 说明

出入登记表用于记录学生出入宿舍的信息。

3.8来访登记子系统

3.8.1 子系统描述

来访登记表:id,宿舍id,学生id,来访人名字,来访时间,出去时间。

其中主键为id,外键为宿舍id,学生id。

3.8.2 分E-R图

3.8.3 说明

来访登记表用于宿舍来访登记。

3.9总体E-R图

4 逻辑结构设计

4.1 关系数据模式

管理员表(admin):

id int 主键

名字(aname) varchar(10) 非空

密码(password) varchar(10) 非空

联系方式(tel) varchar(20) 非空

权限(power) tinyint 非空

宿舍表(dormitory):

id int 主键

管理员id(a_id) int 非空 外键联系admin表

宿舍号(如C)(ch) char(1) 非空

宿舍编号(num) int 非空

宿舍学生性别(s_gender) varchar(10) 非空

房间表(room):

id itn 主键

宿舍id(d_id) int 非空 外键联系dormitory表

宿舍号(num) int 非空

剩余床位(margin) tinyint 非空

价格(price) int 非空

学生表(student):

id int 主键

学号(sno) varchar(20) 非空

姓名(sname) varchar(10) 非空

性别(gender) varchar(10) 非空

年龄(age) int 非空

联系方式(tel) varchar(20) 非空

学院id(u_id) int 非空 外键联系major表

专业id(m_id) int 非空 外键联系major表

年级(class) int 非空

宿舍id(d_id) int 非空 外键联系dormitory表

房间id(r_id) int 非空 外键联系room表

院系专业表(major):

id int 主键

名字(name) varchar(50) 非空

所属学院id(m_id) int 非空 外键联系major表

出入登记表(in_out):

id int 主键

宿舍id(d_id) int 非空 外键联系dormitory表

学生id(s_id) int 非空 外键联系student表

出去时间(out_date) datetime 非空

返回时间(in_date) datetime

来访登记表(visit):

id int 主键

宿舍id(d_id) int 非空 外键联系dormitory表

学生id(s_id) int 非空 外键联系student表

来访人名字(name) varchar(10) 非空

来访时间(in_date) datetime 非空

出去时间(out_date) datetime

4.2 视图的设计

dormitory和room之间的视图:

dormitory和in_out之间的视图:

dormitory和visit之间的视图:

4.3 优化

在宿舍表和房间表、学生表、出入登记表、来访登记表之间建立外键约束,实现删除和更新的级联,并且建立视图。

5 数据库物理设计与实施

5.1 数据库应用的硬件、软件环境介绍

此次数据库设计使用的硬件包括笔记本电脑一台,装有win10系统,软件环境为VS2012和sql server2008。

5.2 物理结构设计

数据库表的设计可见4.1关系数据模式,同时为了提高数据库的查找效率和用户响应速度,数据库应该建立相应的视图和索引提高存取效率,其中视图见4.2。

5.3 索引的设计

本次数据库课程设计除了主键索引和非空索引外并没有设置其他索引。

5.4 建立数据库

数据库:

CREATE DATABASE [dms] ON  PRIMARY 
( NAME = N'dms', FILENAME = N'D:\dms.mdf' , SIZE = 3072KB , MAXSIZE = UNLIMITED, FILEGROWTH = 1024KB )LOG ON 
( NAME = N'dms_log', FILENAME = N'D:\dms_log.ldf' , SIZE = 1024KB , MAXSIZE = 2048GB , FILEGROWTH = 10%)

表:

admin表:

CREATE TABLE [dbo].[admin]([id] [int] IDENTITY(1,1) NOT NULL,[aname] [varchar](10) NOT NULL,[password] [varchar](10) NOT NULL,[tel] [varchar](20) NOT NULL,[power] [tinyint] NOT NULL,CONSTRAINT [PK_admin] PRIMARY KEY CLUSTERED 
([id] ASC
)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
) ON [PRIMARY]

dormitory表

 CREATE TABLE [dbo].[dormitory]([id] [int] IDENTITY(1,1) NOT NULL,
[a_id] [int] NOT NULL,[ch] [char](1) NOT NULL,[num] [int] NOT NULL,[s_gender] [varchar](10) NOT NULL,CONSTRAINT [PK_dormitory] PRIMARY KEY CLUSTERED 
([id] ASC
)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
) ON [PRIMARY]

student表

CREATE TABLE [dbo].[student]([id] [int] IDENTITY(1,1) NOT NULL,[sno] [varchar](20) NOT NULL,[sname] [varchar](10) NOT NULL,[gender] [varchar](10) NOT NULL,[age] [int] NOT NULL,[tel] [varchar](20) NOT NULL,[u_id] [int] NOT NULL,[m_id] [int] NOT NULL,[class] [int] NOT NULL,[d_id] [int] NOT NULL,[r_id] [int] NOT NULL,CONSTRAINT [PK_student] PRIMARY KEY CLUSTERED 
([id] ASC
)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
) ON [PRIMARY]

major表

CREATE TABLE [dbo].[major]([id] [int] IDENTITY(1,1) NOT NULL,[name] [varchar](50) NOT NULL,[m_id] [int] NOT NULL,CONSTRAINT [PK_major] PRIMARY KEY CLUSTERED 
([id] ASC
)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS     = ON) ON [PRIMARY]
) ON [PRIMARY]

visit表

CREATE TABLE [dbo].[visit]([id] [int] IDENTITY(1,1) NOT NULL,[d_id] [int] NOT NULL,[s_id] [int] NOT NULL,[name] [varchar](10) NOT NULL,[in_date] [datetime] NOT NULL,[out_date] [datetime] NULL,CONSTRAINT [PK_visit] PRIMARY KEY CLUSTERED 
([id] ASC
)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
) ON [PRIMARY]

in_out表

CREATE TABLE [dbo].[in_out]([id] [int] IDENTITY(1,1) NOT NULL,[d_id] [int] NOT NULL,[s_id] [int] NOT NULL,[out_date] [datetime] NOT NULL,[in_date] [datetime] NULL,CONSTRAINT [PK_in_out] PRIMARY KEY CLUSTERED 
([id] ASC
)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
) ON [PRIMARY]

5.5 加载测试数据

admin表如下:其中0为宿舍管理员权限(此权限无法查询未分配学生),1为高级管理员,2为超级管理员

dormitory表如下:

room表如下:

major表如下:

student表如下:

visit表和in_out表为空。

6 数据操作要求及实现

6.1数据查询

关于数据查询的代码举例如下:

查询管理员用户名密码:

select id,aname,password,power from admin

查询宿舍楼号:

查询未归学生:

  select student.sname name from in_out left join student on in_out.s_id=student.id where in_date is null

查询宿舍:

 select room.id, dormitory.ch+cast(dormitory.num as varchar(2)) 楼号,dormitory.s_gender 性别,room.num 房号,room.margin 剩余床位,room.price 价格 from room left join dormitory on room.d_id = dormitory.id“select room.id, dormitory.ch+cast(dormitory.num as varchar(2)) 楼号,dormitory.s_gender 性别,room.num 房号,room.margin 剩余床位,room.price 价格 from room left join dormitory on room.d_id = dormitory.id where" + s1 + s2 + s3

查询学生:

 select student.id, student.sno 学号,student.sname 姓名,student.gender 性别,student.age 年龄,student.tel 联系方式,student.class 年级,A.name 学院,B.name 专业,dormitory.ch+cast(dormitory.num as varchar(2)) 楼号,student.r_id 房间id,room.num 房间" + " from (((student left join major A on student.u_id=A.id) left join major B on student.m_id=B.id) left join dormitory on student.d_id=dormitory.id) left join room on student.r_id=room.id" + " where"+s1+s2+s3+s4+s5+s6+s7+s8+s9+s10

查询出入登记记录:

   select student.sno 学号,student.sname 姓名,student.tel 联系方式,student.class 年级,A.name 学院,B.name 专业,room.num 房间,in_out.out_date 出去时间,in_out.in_date 返回时间" +" from ((((in_out left join student on in_out.s_id=student.id) left join major A on student.u_id=A.id) left join major B on student.m_id=B.id) left join dormitory on student.d_id=dormitory.id) left join room on student.r_id=room.id" +" where" + s1 + s2

查询来访登记记录:

select visit.name 来访人,student.sno 学号,student.sname 姓名,student.tel 联系方式,student.class 年级,A.name 学院,B.name 专业,room.num 房间,visit.in_date 访问时间,visit.out_date 出去时间" +" from ((((visit left join student on visit.s_id=student.id) left join major A on student.u_id=A.id) left join major B on student.m_id=B.id) left join dormitory on student.d_id=dormitory.id) left join room on student.r_id=room.id" +" where" + s1 + s2

查询管理员:

 select id, aname 名字,tel 联系方式,power 权限 from admin

6.2数据更新

关于数据更新举例如下:

修改学生:

"update student set"+str+"where sno='"+s1+"'"

修改出入登记记录:

"update in\_out set in\_date='"+t.ToString()+"' where d\_id="+s1+" and s\_id="+s2

修改来访登记记录:

"update visit set out\_date='" + t.ToString() + "' where d\_id=" + s1 + " and name='" + s2 + "'"

6.3数据删除

关于数据删除举例如下:

删除学生:

string sqlStr = "delete from student where id=";

删除管理员:

string sqlStr = "delete from admin where id=";

6.4数据添加

关于数据添加举例如下:

添加学生:

"insert into student (sno,sname,gender,age,tel,u\_id,m\_id,class,d\_id,r\_id) values('"+s1+"','"+s2+"','"+s3+"',"+s6+",'"+s5+"',"+s7+","+s8+","+s4+","+s9+","+s10+ ")"

添加出入登记:

"insert into in\_out (d\_id,s\_id,out\_date) values(" + s1 + "," + s2 + ",'" + t.ToString() + "')"

添加来访登记:

"insert into visit (d\_id,s\_id,name,in\_date) values(" +ConnectDB.getInstance().GetDorId(s1)+","+ConnectDB.getInstance().GetStuId(s2)+",'"+s3+"','"+d.ToString()+"')"

6.5数据维护

关于数据维护方面,每隔固定时间就要备份一次数据,并且删除冗余数据。以防止数据丢失和出错。

7 源代码及查询截图

7.1程序流程图

7.2数据库链接

关于数据库链接的代码如下:

 string str;SqlConnection con;static ConnectDB cdb = new ConnectDB();private ConnectDB(){str = @"Data Source=A;Initial Catalog=dms;Persist Security Info=True;User ID=dms;Password=dms";con = new SqlConnection(str);}

数据库连接的打开和关闭:

con.Open();
con.Close();

7.3重点代码分析

7.3.1登陆:

通过查询数据库中管理员的名字和密码以及权限进行登陆,代码如下,

con.Open();
string cmd = "select id,aname,password,power from admin";
SqlCommand com = new SqlCommand(cmd, con);
SqlDataReader reader = com.ExecuteReader();
while (reader.Read())
{
String user = reader["aname"].ToString();
String pwd = reader["password"].ToString();
Form1.power = Int32.Parse(reader["power"].ToString().Trim());Form1.admin_name = "欢迎,"+user;Form1.admin_id = Int32.Parse(reader["id"].ToString().Trim());if (user.Trim() == u && pwd.Trim() == p){reader.Close();con.Close();return true; //登陆成功为true}}
reader.Close();
con.Close();return false;

7.3.2按权限显示内容:

通过判断登陆时获取的权限,决定是否显示相应的界面和内容,代码部分举例如下,

if (b == true && power == 0)
{
v_name_label1.Visible = b;
v_name1.Visible = b;
v_name_label2.Visible = b;
v_name_c.Visible = b;
v_name_label3.Visible = b;
v_name2.Visible = b;
in_bt.Visible = b;
out_bt.Visible = b;
}
else
{v_name_label1.Visible = false;v_name1.Visible = false;v_name_label2.Visible = false;v_name_c.Visible = false;v_name_label3.Visible = false;v_name2.Visible = false;in_bt.Visible = false;out_bt.Visible = false;}

7.3.3清空宿舍:

通过将学生的所属宿舍id改为0并且将宿舍剩余床位数量改为相应值来情况宿舍,代码部分举例如下,其中dat为查询出来的结果,最后一句模仿点击查询,将清空之后的结果显示,

if (dat == null)
{MessageBox.Show("没有选中的内容!", "提示");return;}string sqlStr = "update room set margin=4 where id=";for (int i = 0; i < dat.Rows.Count; i++){
ConnectDB.getInstance().Change(sqlStr+dat.Rows[i]["id"]);}sqlStr = "update student set d_id=0,r_id=0 where r_id=";for (int i = 0; i < dat.Rows.Count; i++)
{ConnectDB.getInstance().Change(sqlStr + dat.Rows[i]["id"]);
}select_Click(sender, e);

7.3.4按条件查询学生:

通过左连接查询相应条件的学生进行显示,代码如下,

string s1 = num.Text.ToString().Trim();
string s2 = name.Text.ToString().Trim();
string s3 = gender.Text.ToString().Trim();
string s4 = class_t.Text.ToString().Trim();
string s5 = tel.Text.ToString().Trim();
string s6 = age.Text.ToString().Trim();
string s7 = school.Text.ToString().Trim();
string s8 = major.Text.ToString().Trim();
string s9 = do_c.Text.ToString().Trim();
string s10 = room.Text.ToString().Trim();
try
{if (s4 != "")Int32.Parse(s4);if (s6 != "")Int32.Parse(s6);if (s10 != "")Int32.Parse(s10);}catch (Exception a){MessageBox.Show("请输入正确格式的数据!", "提示");return;}DataSet ds;s1 = s1 != "" ? " student.sno='"+s1+"'" : " student.sno!='null'";s2 = s2 != "" ? " and student.sname='" + s2 + "'" : " and student.sname!='null'";s3 = s3 != "" ? " and student.gender='" + s3 + "'" : " and student.gender!='null'";s4 = s4 != "" ? " and student.class=" + s4 : " and student.class!=0";s5 = s5 != "" ? " and student.tel='" + s5 +"'" : " and student.tel!='null'";s6 = s6 != "" ? " and student.age=" + s6 : " and student.age!=0";s7 = s7 != "" ? " and A.name='" + s7 + "'" : " and A.name!='null'";s8 = s8 != "" ? " and B.name='" + s8 + "'" : " and B.name!='null'";s9 = s9 != "全部" ? " and dormitory.ch='" + s9[0] + "' and dormitory.num=" + s9.Substring(1, s9.Length - 1) : "";s10 = s10 != "" ? " and room.num=" + s10 : "";
ds = ConnectDB.getInstance().GetData("select student.id, student.sno 学号,student.sname 姓名,student.gender 性别,student.age 年龄,student.tel 联系方式,student.class 年级,A.name 学院,B.name 专业,dormitory.ch+cast(dormitory.num as varchar(2)) 楼号,student.r_id 房间id,room.num 房间" +" from (((student left join major A on student.u_id=A.id) left join major B on student.m_id=B.id) left join dormitory on student.d_id=dormitory.id) left join room on student.r_id=room.id" +       " where"+s1+s2+s3+s4+s5+s6+s7+s8+s9+s10); 
dat = ds != null ? ds.Tables[0] : null;
dataGridView0.DataSource = dat;

7.4查询截图

以下截图为超级管理员(权限为2)权限下的情况:

8 收获、体会和建议

经过这次的数据库课程设计,首先,当然是得到了技能上的提升了,因为在完成这个课程设计的时候必须使用到C#和sql语言,并且C#的陌生和sql语言的复杂都让我有点难以解决,这便让我在这其中得到了技能的提升。

其次,由于本次课程设计的时间只有两周并且是在任务比较多的时间,这让我加快了学习的效率,学会了平心静气不浮躁的学习。

9 主要参考文献

  1. 《C#程序设计及应用教程》; 马俊、邓居英、杨湖;
  2. 《数据库原理及其应用教程(第三版)》; 黄德才主编; 科学出版社.
    PAGE * MERGEFORMAT- 27 -

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/1544395.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

中航资本:交易港股通,为什么刚买入就显示亏损?

经过港股通生意港股&#xff0c;刚买入就闪现亏本是因为买入港股时会有一个汇率差。 港股通生意选用的是港币报价、人民币结算的方式&#xff0c;港股通的参看本钱价是以港币核算的&#xff0c;触及买入时将港币换成人民币&#xff0c;卖出时将人民币换成港币的进程&#xff0…

Java语言程序设计基础篇_编程练习题18.36 (思瑞平斯基三角形)

目录 题目&#xff1a;18.36 (思瑞平斯基三角形) 代码示例 代码逻辑 1. 应用程序入口 2. GUI设置 3. 事件处理 4. 绘制逻辑 5. 递归绘制 输出结果 题目&#xff1a;18.36 (思瑞平斯基三角形) 编写一个程序&#xff0c;让用户输入一个阶数&#xff0c;然后显示填充的…

送书!一大波LLM大模型学习教程书籍

最近整理了日前市面上一大波大模型的书&#xff0c;已经打包成pdf了&#xff0c;大家有需要的&#xff0c;可以自行添加获取&#xff0c;纯福利&#xff0c;无套路&#xff0c;添加后说明是哪本书&#xff0c;会直接给大家&#xff01; &#x1f449;CSDN大礼包&#x1f381;&a…

国产SSL证书品牌怎么选择?

有人在歪曲大型央国企“信创化”与数字化转型建设思路&#xff0c;为了自身的利益开始造谣一些虚假传播信息国外SSL证书不安全问题&#xff0c;然而国外的SSL证书每个上网用户都在使用&#xff0c;然而发布虚假广告的一些人实际上是换了个马甲贴个名字就叫国产SSL证书了&#x…

等保测评误区与应对:企业常见问题解析

标题&#xff1a;等保测评误区与应对&#xff1a;企业常见问题解析 信息安全等级保护&#xff08;等保&#xff09;测评是企业信息安全建设的重要组成部分&#xff0c;但在实际操作中&#xff0c;企业常会陷入一些误区。本文将解析企业等保测评中常见的误区&#xff0c;并提出…

【Python报错已解决】IndexError: list index out of range

&#x1f3ac; 鸽芷咕&#xff1a;个人主页 &#x1f525; 个人专栏: 《C干货基地》《粉丝福利》 ⛺️生活的理想&#xff0c;就是为了理想的生活! 专栏介绍 在软件开发和日常使用中&#xff0c;BUG是不可避免的。本专栏致力于为广大开发者和技术爱好者提供一个关于BUG解决的经…

Flutter 之 ftcon24usa 大会,创始人分享 Flutter 十年发展史,一闪而过的鸿蒙身影

之前一直关注 Fluttercon 的相关活动&#xff0c;正如 Flutter 3.24 发布时所说&#xff0c;继 Fluttercon 欧洲之后&#xff0c;近日 Fluttercon 2024 USA 在纽约如期举行&#xff0c;大会带来了一些有趣消息和 Flutter 发展历程&#xff0c;本次也是通过 X 和 OpenWebF 创始人…

免费ppt模板哪里找?职场必备这些利器

一眨眼&#xff0c;9月份的尾声渐近&#xff0c;无论是学生还是职场人士&#xff0c;都开始准备着新一轮的演讲和报告。在这个忙碌的时期&#xff0c;一份精美的PPT模板能够大幅提升你的工作效率&#xff0c;让你的演示更加引人入胜。 不用担心高昂的版权费用&#xff0c;市场…

什么是反射,反射用途,spring哪些地方用到了反射,我们项目中哪些地方用到了反射

3分钟搞懂Java反射 一、反射是什么 在Java中&#xff0c;反射&#xff08;Reflection&#xff09;是一种强大的工具&#xff0c;它允许程序在运行时获取和操作类、接口、构造器、方法和字段等。反射是Java语言的一个重要特性&#xff0c;它为开发人员提供了许多灵活性&#xf…

单片机项目合集列表与专栏说明——Excel合集列表目录查阅(持续更新)

阿齐Archie《单片机项目合集》专栏项目 为方便查找本专栏的项目&#xff0c;特整理Excel合集列表供查阅&#xff08;可搜索或按系列查找&#xff09; 持续更新链接如下&#xff1a; 阿齐单片机项目合集 (kdocs.cn)https://www.kdocs.cn/l/cmrxCxJN05YN 打开链接如下Exce表所…

使用API有效率地管理Dynadot域名,注册域名服务器(NS)信息

前言 Dynadot是通过ICANN认证的域名注册商&#xff0c;自2002年成立以来&#xff0c;服务于全球108个国家和地区的客户&#xff0c;为数以万计的客户提供简洁&#xff0c;优惠&#xff0c;安全的域名注册以及管理服务。 Dynadot平台操作教程索引&#xff08;包括域名邮箱&…

视频去水印 —— 释放创意,让学习与创作更自由!

&#x1f31f; 视频去水印 —— 释放创意&#xff0c;让学习与创作更自由&#xff01; 在这个短视频盛行的时代&#xff0c;抖音、快手、小红书等平台成为了创意与灵感的聚集地。你是否曾遇到过想要学习或进行二次创作&#xff0c;却被视频中的水印所困扰&#xff1f;现在&…

fo-dicom开发之DICOM数据解析:常见数据类型及处理方法详解

前言 前面的文章&#xff0c;我们介绍了fo-dicom是一个怎样的开源库&#xff1a;fo-dicom&#xff0c;第一个基于.NET Standard 2.0 开发的DICOM开源库&#xff0c;以及 学会使用fo-dicom前&#xff0c;了解其非常重要的基本概念&#xff0c;本次我们将了解&#xff0c;当进行…

力扣最热一百题——最小覆盖子串

目录 题目链接&#xff1a;76. 最小覆盖子串 - 力扣&#xff08;LeetCode&#xff09; 题目描述 示例 提示&#xff1a; 解法一&#xff1a;滑动窗口 1. 初始化 2. 构建 mapT 3. 滑动窗口 4. checkT 方法 5. 返回结果 Java写法&#xff1a; 运行时间 C写法&#x…

人工智能与自然语言处理发展史

前言 在科技的浪潮中&#xff0c;人工智能 (AI) 作为一股不可阻挡的力量&#xff0c;持续推动着社会与科技的进步。本博客旨在深入剖析人工智能及其核心领域——神经网络、自然语言处理、统计语言模型、以及大规模语言模型——的演进历程&#xff0c;以专业的视角展现这一领域…

基于C语言开发(控制台)通讯录管理程序

通讯录程序设计 一、课程设计题目与要求 题目 &#xff1a;通讯录管理程序 1. 问题描述 编写一个简单的通讯录管理程序。通讯录记录有姓名&#xff0c;地址(省、市(县)、街道)&#xff0c;电话号码&#xff0c;邮政编码等四项。2. 基本要求 程序应提供的基本基本管理功能有…

豆包 MarsCode 代码练习体验

我最近体验了豆包MarsCode的代码练习&#xff0c;感觉非常棒&#xff01;首先&#xff0c;进入平台后&#xff0c;界面简洁明了&#xff0c;使用起来非常方便。选择内置题目时&#xff0c;题目类型丰富多样&#xff0c;涵盖了基础知识和一些进阶挑战&#xff0c;非常适合不同水…

【Kubernetes知识点】解读HPA的 thrashing(抖动)问题

【Kubernetes知识点】解读HPA的 thrashing&#xff08;抖动&#xff09;问题 目录 1 概念 1.1 什么是 Thrashing 现象&#xff1f;1.2 HPA 中 Thrashing 产生的原因1.3 解决 Thrashing 的优化措施 1.3.1 设置合适的阈值1.3.2 使用自定义指标和基于负载的自动扩缩1.3.3 增加扩…

探寻大模型时代智慧农业新未来,商汤与上海市农委达成战略合作

近日&#xff0c;在中国农民丰收节上海会场丰收庆典活动上&#xff0c;商汤科技与上海市农业农村委员会&#xff08;下称&#xff1a;上海市农委&#xff09;签署战略合作协议&#xff0c;双方将依托先进的AI大模型技术&#xff0c;共同推进上海智慧农业发展&#xff0c;打造国…

基向量和投影矩阵

文章目录 1. 投影向量2. 基向量&#xff0c;列向量秩1分解3. SVD&#xff0c;奇异向量秩1分解4. 小结&#xff1a;5. 图解分析 1. 投影向量 假设我们有一个向量b和一个向量q,求向量b在向量q上的投影向量p: 求向量p的长度&#xff1a; q T b ∣ q ∣ ⋅ ∣ b ∣ ⋅ cos ⁡ …