zoukankan      html  css  js  c++  java
  • 《零基础学C#3.0 -- 简单图书馆管理系统编写实践1》

    前言:

    对于那些零基础编写第一个C#小型系统的新手而言,最重要的永远是:编译通过,基本功能实现。C#以及窗体编程的特点决定了,即使你有全部的功能代码,你也不可能不加思考的完成既定功能。在示范代码看起来足够“好”的情况下(比如:多构造通用类,多调用自己编写的通用函数,而不是每个窗体上都有满天飞的数据库定义,如sqlDataAdapter, sqlCommandBuilder),先立足把书中的功能完成,再进行深入的思考。对于新手来说,不要高估自己的实力,很可能你的代码写的和示例一样也不能达到预定的功能,这时哪怕用最脏的方法,以完成功能为第一要务,等软件的基本功能实现了之后再进行反思以及改进。

    当第一次编写完成后,可以通过写技术博客的方式总结经验,拟从以下几个角度入手:

    1. 需求分析是否正确?功能板块之间的逻辑关系是否正确?

    2. 在正常使用软件的情况下,是否所有功能都正确的得到了满足?

    3. 窗体外形设计是否合理(这里指的不是美观)?

    4. 空字段输入是否应该允许?如何处理错误的输入?

    5. 是否需要快捷键?是否需要提示?

    6. 是否按照规定进行了注释?注释是否真正具有解释作用?

    7. 变量是否具有自解释性?是否便于维护?

    8. 模块是否可以进行精简?可重用的代码是否以函数的形式调用?

    9. 更多细节问题(是否可编辑?只读?光标默认位置?Tab顺序?……)

    不断的优化自己的代码,不断的精益求精,才是踏踏实实学习一门语言的捷径。

    ----------------------------------------------------------------------------------------------------------------------

    我的这份文档是在第一次编写完成后进行写作的。通过写作,可以找出自己没有思考或思考不足的地方。

    主要内容:实现功能简介。

    进入界面后功能:

    1. 登录(用户,管理员):用户登录后可以进行自己的借阅记录查询以及查阅书籍;未登录用户可以查阅书籍;管理员具有最大权限。

    2. 查询图书:以只读方式查找书籍。

    3. 借阅记录查询:通过借书证号进行借阅查询(暂不支持借阅历史查询)

    4. 增加图书:需要管理员权限。

    5. 修改图书:需要管理员权限。

    6. 删除图书:需要管理员权限。

    7. 借阅图书:需要管理员权限。

    数据库:(取名应该短,比如BookInfo,我这一开始没注意)

    (1)UserInformation

    UID : 用户ID,int,自动,主键(自动编号在increment属性中设置)

    UName : 用户名,varchar,不为空

    UPwd : 用户密码,varchar,不为空

    UBookID : 借阅证号, bigint, 可为空(管理员不需要借阅证号)

    UState : 用户权限(管理员,普通用户,未登录用户),int,默认值为普通用户

    (2)BookInformation

    BookID : 图书ID,bigint,自动,主键

    BookName : 图书名称,varchar,不为空

    BookType : 图书类别,varchar,不为空

    BookAuthor : 作者,varchar,不为空

    BookPrice : 价格,smallmoney,不为空

    BookPic : 封面,varchar,可以为空

    BookContent : 内容简介,varchar,不为空

    BookIssue : 图书访问码,varchar,不为空

    (3)BookLendInformation

    IssID : 借阅ID,bigint,自动,主键

    BookID : 图书ID,bigint,外键

    UID : 用户id,int,外键

    IssDateTime : 借书日期,datetime,不为空

  • 相关阅读:
    正则二三事
    docker elasticsearch 5.6.13 安装ik分词器
    centos docker 防火墙设置(多个ip之间互相访问)
    ElasticSearch结构化搜索和全文搜索
    Jest — ElasticSearch Java 客户端
    提高redis cluster集群的安全性,增加密码验证
    spring boot 设置 gzip 压缩
    centos 7磁盘空间满了导致redis cluster问题和kafka的问题
    SpringBoot之MySQL数据的丢失的元凶--事务(转)
    mysql mycat 1.6.6.1-release 批量 insert 数据丢失问题(续)
  • 原文地址:https://www.cnblogs.com/codingpenguin/p/3533474.html
Copyright © 2011-2022 走看看