数据库应用系统开发

数据库应用系统开发

实验目的

熟悉c/s架构,利用c#语言中ado.net类与winform工具实现数据库友好操作界面

实验环境

Microsoft visual studio2015

实验内容

根据实验已给内容初步学习ado.net类与winform工具

在app.config文件中设置服务器为本地主机,并使用数据库School

 

查询功能的实现:

private void btnSearch_Click(object sender, EventArgs e)

        {

            Search();   

        }

查询控件对应与btnSearch_Click函数,当单击“查询”时,便会触发该函数运行。

        private void Search()

        {

            string strID = string.Empty;

            string strName = string.Empty;

            strID = txtNo.Text.Trim();

            strName = txtName.Text.Trim();

 

            string strSql = string.Empty;

 

            strSql = @"SELECT   SID, SName, Grade, Email

                         FROM   Students

                        WHERE   ";

            if (strID != string.Empty)

            {

                strSql += " Sid LIKE '%" + strID + "%'";

            }

            if (strName != string.Empty)

            {

                strSql += "AND SName LIKE '%" + strName + "%'";

            }

            strSql += " ORDER BY Sid";

 

            DataSet dsDataStudent = new DataSet();

            dsDataStudent = DbHelperSQL.Query(strSql);

            gridStudent.AutoGenerateColumns = false;

            gridStudent.DataSource = dsDataStudent.Tables[0];           

            gridStudent.ClearSelection(); //取消选中

        }

函数实现逻辑:

先将两个txt文本中的内容赋值给字符串变量学号和姓名

再用字符串变量存储sql查询语句“SELECT   SID, SName, Grade, Email FROM   Students WHERE

Sid LIKE '%" + strID + "%' AND SName LIKE '%" + strName + "%' ORDER BY Sid

在用sql查询该语句,将结果保存在Dataset类中,并显示。

主要使用到了DataGridView类

截图:

删除功能实现:

private void btnDelete_Click(object sender, EventArgs e)

        {

            if (StudentIDSelected == string.Empty)

            {

                MessageBox.Show("请选择要删除的行");

                return;

            }

            if (DialogResult.Yes == MessageBox.Show("确定要删除该记录", "警告", MessageBoxButtons.YesNo, MessageBoxIcon.Question, MessageBoxDefaultButton.Button1))

            {

                string strSql = string.Empty;

 

                strSql = @"DELETE FROM   Students

                                 WHERE   SID ='" + StudentIDSelected + "'";

                DbHelperSQL.ExecuteSql(strSql);

                StudentIDSelected = string.Empty;

                Search();

            }

        }

 

        private void gridStudent_CellClick(object sender, DataGridViewCellEventArgs e)

        {

            StudentIDSelected=gridStudent.Rows[e.RowIndex].Cells["SID"].Value.ToString().Trim();

        }

函数逻辑:

先定义私有字符串变量        private string StudentIDSelected = string.Empty;

当点击删除键没有选择要删除的行时,显示警告消息

鼠标单击一行时给字符串变量赋值

StudentIDSelected=gridStudent.Rows[e.RowIndex].Cells["SID"].Value.ToString().Trim();

将sql语句补充完整,并执行sql删除语句后重新显示新的数据

截图:

 

 

自己实现新增,编辑功能

新增功能实现:

  1. 新建一个新增需要用到的窗口,并给它添加好控件,如图所示:

  1. 在点击“新增”按钮时需要将新建的窗口弹出,使用如下语句:

            StudentAdd studentAdd = new StudentAdd();

            studentAdd.Owner = this;

            studentAdd.ShowDialog();

 

  1. 根据新窗口输入的信息,直接编写sql语句,利用之前编写好的sql执行函数执行

   private void button1_Click(object sender, EventArgs e)

        {

            string strID = string.Empty;

            string strName = string.Empty;

            string strGrade = string.Empty;

            string strEmail = string.Empty;

            strID = textBox1.Text.Trim();

            strName = textBox2.Text.Trim();

            strGrade = textBox3.Text.Trim();

            strEmail = textBox4.Text.Trim();

 

            string strSql = string.Empty;

 

            strSql = @"insert into STUDENTS values('"+strID+"','" + strName+"','" + strEmail + "','" + strGrade + "') ";

            DbHelperSQL.ExecuteSql(strSql);

            this.Close();

        }

  1. 演示:

 

数据编辑实现:

  1. 新建一个新增需要用到的窗口,并给它添加好控件。
  2. 在选择修改时需要先选定一行,并获取这行的ID。

  1. 选择好后,弹出新的Form,并根据用户输入数据编写修改sql语句执行。

  1. 重新显示修改好后的数据。
  2. 演示如下:

  

 

实验总结

本次实验对我而言是一次非常有意思的实验,因为我学会了如何为一个程序设计窗口,这是我一直好奇但是没有实践的想法。

在microsoft visual stdio中,用c#库中的window窗体库,里面有非常丰富的库函数和可视化的设计控件,新建窗口后,对每个控件根据自己需要添加相应的后台函数。

除了初步认识外,我还懂得一些高级的操作,例如联系本地数据库,显示新的数据,弹出新form,选取选中行等等。还有很多新的知识等着我去了解。

最后更深刻的认识是虽然一些面向用户的界面很酷炫,但是支持它们实现的依然是起内部的算法和基本逻辑,所以核心还是要掌握好数据结构和算法。

 

  • 7
    点赞
  • 57
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
数据库应用系统设计与实现 实验类型:设计型 实验地点:2楼312 实验时间:12月14日、21日周五1-3/5-7节 实验内容: 系统概述: 某银行需要开发ATM存取款机系统实现如下功能: 1)开户(到银行填写开户申请单,卡号自动生成) 2)取款 3)存款 4)查询余额 题目要求: 一、建库、建表、建约束 1、使用SQL创建表 客户信息表userinfo 字段名称 说明 备注 customerID 顾客编号 自动编号(标识列),从1开始,主键 用序列sequence实现,用其属性:nextval customerName 开户名 必填 PID 身份证号 必填,智能是18位或15位,唯一约束 check约束length()函数 telephone 联系电话 必填,11位手机号 check约束,’[0-9]’ address 居住地址 银行卡信息表cardinfo 字段名称 说明 cardID 卡号 必填,主键,银行的卡号规则和电话好吗一样,一般前8位代表特殊含义,如某综合某支行等,假定该行要求其营业厅的卡号格式为10103576**** ***开始,每4位号码后有空格,卡号一般是随机产生。 curType 货币种类 必填,默认为RMB savingTate 存款类型 活期/定活两便/定期 openDate 开户日期 必填,默认为系统当前日期 openMoney 开户金额 必填,不低于1元 balance 余额 必填,不低于1元,否则将销户 pass 密码 必填,6位数字,开户时默认为6个“6” IsReportloss 是否挂失 必填,是/否值,默认为“否” customerID 顾客编号 外键,必填,表示该卡对应的顾客编号,一位顾客允许办理多张卡号 交易信息表transinfo 字段名称 说明 transDate 交易日期 必填,默认为系统当前日期 cardID 卡号 必填,外键 transType 交易类型 必填,只能是存入/支取 transMoney 交易金额 必填,大于0 remark 备注 可选,其他说明 2、使用SQL语言在每个表上添加约束 主键约束、外键约束、CHECK约束、默认约束、非空约束 二、插入测试数据 使用SQL语言向每个表中插入至少3条记录 三、模拟常规业务 1)修改客户密码 2)办理银行卡挂失 3)统计银行资金流通余额和盈利结算 银行资金流通余额=总存入金额-总支取金额 盈利结算=总支取金额 * 0.008 – 总存入金额 * 0.003 4)查询本周开户的卡号,显示该卡相关信息 5)查询本月交易金额最高的卡号 6)查询挂失账号的客户信息 四、利用视图实现数据查询 1)为客户提供以下3个视图供其查询该客户数据 客户基本信息:vw_userInfo 银行卡信息:vw_cardInfo 银行卡交易信息:vw_transInfo 2)提供友好界面,要求各列名称为中文描述 3)调用创建的视图获得查询结果 五、用存储过程实现业务处理 1)完成开户业务 2)完成取款或存款业务 3)根据卡号打印对账单 4)查询、统计指定时间段内没有发生交易的账户信息

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值