C# + MySQL 圖書管理系統.doc
《C# + MySQL 圖書管理系統.doc》由會員分享,可在線閱讀,更多相關《C# + MySQL 圖書管理系統.doc(19頁珍藏版)》請在裝配圖網上搜索。
______________________________________________________________________________________________________________ 《C#面向對象程序設計》課程設計 ——圖書借閱管理系統 源碼下載地址:http://pan.baidu.com/s/1eRCzK2m 院 系: 計算機學院 專 業(yè): 計算機科學與技術 年 級: 2014級 學生姓名: // 學 號: // 教 師: // 日 期: 2017年6月6日 開發(fā)和運行環(huán)境 - 開發(fā)環(huán)境:Windows 10-1703; - 開發(fā)工具:Visual Studio 013 Update5; - 數據庫工具:Mysql 5.7 + NaviCat; - 運行環(huán)境:Windows 10-1703; 需求分析 1.【角色】用戶通過【注冊】成為本系統的可訪問成員,通過【登陸】進入系統。用戶可以操作的功能有: - 查看圖書館的所有圖書信息,圖書的是否可借閱信息; - 搜索功能:通過輸入關鍵字,來查找是否有自己需要的圖書; - 借閱功能:未被其他用戶借閱的書籍可以直接借閱; - 還書功能:若存在之前借閱的書籍,在未歸還的情況下,可以進行還書操作,若未存在需要還的書籍,提示:未有需要歸還的書籍; - 個人信息:修改除了【用戶名】以外之前注冊的全部信息; - 借閱信息:可以查看借閱歷史,曾經的借書日期和還書日期,是否有未歸還的書等等; 2.【角色】管理員通過【登陸】進入用戶進入不了的管理系統。管理員可以操作的功能有: - 圖書信息修改:修改除了圖書名的現有的所有圖書信息; - 添加圖書:添加新的圖書; - 查看用戶信息:可以查看用戶表的部分用戶信息; 3.數據保存:需要長期保存在數據庫的數據有: - 圖書信息:圖書的基本信息; - 讀者信息:讀者的基本信息; - 借閱信息:圖書的借閱信息; - 帳號信息:圖書管理員和讀者的登錄帳號; ?? 系統流程圖(不包含注冊功能) 數據庫設計說明 - 管理員表:adminInfo; - 圖書信息表:bookInfo; - 借閱信息表:borrowed; - 用戶信息表:userInfo; adminInfo表 列名 數據類型 可否為空 長度 說明 adminId int 否 11 管理員ID adminName varchar 否 255 管理員用戶名 adminPassword varchar 否 255 管理員密碼 bookInfo表 列名 數據類型 可否為空 長度 說明 bookId int 否 11 圖書編號ID bookName varchar 否 255 圖書名 bookAuthor varchar 否 255 圖書作者 bookPrice int 否 11 圖書價格 bookPress varchar 否 255 圖書出版社 bookType varchar 是 255 圖書類型 isBorrowed tinyint 是 11 是否被借閱 borrowId int 是 11 借閱人的ID BorrowedTime datetime 是 0 被借閱的時間 borrowed表 列名 數據類型 可否為空 長度 說明 borrowedId int 否 11 借閱信息ID userId int 是 11 操作人ID userName varchar 是 255 操作人用戶名 bookId int 是 11 圖書ID editTime datatime 是 0 操作時間 bookName varchar 是 255 圖書名 edit varchar 是 255 操作名 UserInfo表 列名 數據類型 可否為空 長度 說明 userId int 否 11 用戶ID userName varchar 否 255 用戶名 userPassword varchar 否 255 用戶密碼 userSex varchar 是 255 用戶性別 模塊分析 cs文件: 主界面: 主要顯示代碼 – mainCenter.cs : public mainCenter(){ InitializeComponent(); string sql = "server=localhost;user id=root;password=123456;database=C#librarycenter"; //根據自己的設置 MySqlConnection conn = new MySqlConnection(sql); conn.Open();//打開數據庫連接 MySqlDataAdapter data1 = new MySqlDataAdapter();//實例化sqldataadpter MySqlCommand cmd1 = new MySqlCommand("SELECT bookName as '圖書名',bookAuthor as '作者',bookPrice as '圖書價格',bookPress as '出版社',bookType as '圖書類型',(CASE isBorrowed WHEN 0 THEN '未借閱' ELSE '已借閱' END) as'借閱情況' FROM `c#librarycenter`.bookinfo", conn);//sql語句 data1.SelectCommand = cmd1;//設置為已實例化SqlDataAdapter的查詢命令 DataTable dt = new DataTable(); dt.Clear(); data1.Fill(dt);//把數據填充到datatable dataGridView1.DataSource = dt;//將數據集綁定datagridview,完成顯示 dataGridView1.AllowUserToAddRows = false; // login login = new login(); label1.Text = "這里是SMART-LIBRARY!用戶:" + login.username; // } 查找功能: 主要實現代碼: private void button1_Click(object sender, EventArgs e) { String so = textBox1.Text; String sql = "server=localhost;user id=root;password=123456;database=C#librarycenter"; //根據自己的設置 MySqlConnection conn = new MySqlConnection(sql); conn.Open();//打開數據庫連接 MySqlDataAdapter data1 = new MySqlDataAdapter();//實例化sqldataadpter MySqlCommand cmd1 = new MySqlCommand("SELECT bookName as '圖書名',bookAuthor as '作者',bookPrice as '圖書價格',bookPress as '出版社',bookType as '圖書類型',(CASE isBorrowed WHEN 0 THEN '未借閱' ELSE '已借閱' END) as'借閱情況' FROM `c#librarycenter`.bookinfo where bookName like '%"+ so +"%' ", conn);//sql語句 data1.SelectCommand = cmd1;//設置為已實例化SqlDataAdapter的查詢命令 //DataSet ds1 = new DataSet();//實例化dataset DataTable dt = new DataTable(); dt.Clear(); data1.Fill(dt);//把數據填充到datatable dataGridView1.DataSource = dt;//將數據集綁定datagridview,完成顯示 dataGridView1.AllowUserToAddRows = false; } 借閱功能: 主要實現代碼 - borrow.cs: private void dataGridView1_CellContentClick(object sender, DataGridViewCellEventArgs e) { int r = this.dataGridView1.CurrentRow.Index; string h = this.dataGridView1.Rows[r].Cells[1].Value.ToString(); string s = this.dataGridView1.Rows[r].Cells[2].Value.ToString(); // login login = new login(); String userId = ""; DateTime dt = DateTime.Now; String borrowedTime = dt.ToString("yyyy-MM-dd HH:mm:ss"); string sql = "server=localhost;user id=root;password=123456;database=C#librarycenter"; //根據自己的設置 MySqlConnection conn = new MySqlConnection(sql); String updateBorrow1 = "select userId from userInfo where userName = '"+login.username+"'"; MySqlCommand mysqlcommand = new MySqlCommand(updateBorrow1,conn); conn.Open(); MySqlDataReader mdr = mysqlcommand.ExecuteReader(); if (mdr.Read()) { userId = mdr.GetString(0).ToString(); } mdr.Close(); String updateBorrow2 = "update bookInfo set isBorrowed = '1', borrowId = '" + userId + "',borrowedTime ='" + borrowedTime + "' where bookId = '" + h + "'"; // MySqlCommand mysqlcommand2 = new MySqlCommand(updateBorrow2, conn); int i = mysqlcommand2.ExecuteNonQuery(); if (i != -1) { MessageBox.Show(login.username + " \r\n恭喜你借" + " << " + s + " >> \r\n這本書" + "成功"); } else { MessageBox.Show("系統出了點問題,請聯系管理員!"); } //更新借閱表 String updateBorrow3 = "insert into borrowed(userId,userName,bookId,editTime,bookName,edit) values('" + userId + "','" + login.username + "','" + h + "','" + borrowedTime + "','" + s + "','借書')"; MySqlCommand mysqlcommand3 = new MySqlCommand(updateBorrow3, conn); mysqlcommand3.ExecuteNonQuery(); //刷新dataGridView1,重新綁定數據源 f5(); } 歸還圖書功能: 主要實現代碼 – returnbook.cs: private void dataGridView1_CellContentClick(object sender, DataGridViewCellEventArgs e) { int r = this.dataGridView1.CurrentRow.Index; string h = this.dataGridView1.Rows[r].Cells[1].Value.ToString(); string s = this.dataGridView1.Rows[r].Cells[2].Value.ToString(); DateTime dt = DateTime.Now; String returnedTime = dt.ToString("yyyy-MM-dd HH:mm:ss"); String userId = ""; string sql = "server=localhost;user id=root;password=123456;database=C#librarycenter"; //根據自己的設置 MySqlConnection conn = new MySqlConnection(sql); conn.Open(); // String updateBorrow1 = "update bookInfo set isBorrowed = '0',borrowId = null,borrowedTime = null where bookId = '"+h+"'"; MySqlCommand mysqlcommand2 = new MySqlCommand(updateBorrow1, conn); int i = mysqlcommand2.ExecuteNonQuery(); if (i != -1) { MessageBox.Show(login.username + " \r\n<< " + s + " >> \r\n這本書,還書成功"); } else { MessageBox.Show("系統出了點問題,請聯系管理員!"); } //更新借閱表 String updateBorrow = "select userId from userInfo where userName = '" + login.username + "'"; MySqlCommand mysqlcommand = new MySqlCommand(updateBorrow, conn); MySqlDataReader mdr = mysqlcommand.ExecuteReader(); if (mdr.Read()) { userId = mdr.GetString(0).ToString(); } mdr.Close(); String updateBorrow2 = "insert into borrowed(userId,userName,bookId,editTime,bookName,edit) values('" + userId + "','" + login.username + "','" + h + "','" + returnedTime + "','" + s + "','還書')"; MySqlCommand mysqlcommand3 = new MySqlCommand(updateBorrow2, conn); mysqlcommand3.ExecuteNonQuery(); //刷新dataGridView1,重新綁定數據源 f5(); } 修改個人信息: 主要實現代碼 – editUser.cs: private void button1_Click(object sender, EventArgs e) { login login = new login(); String pw = textBox1.Text; String npw = textBox2.Text; String un = login.username; String userPassword = ""; String userId = ""; if (male.Checked == true) ans = "male"; if (female.Checked == true) ans = "female"; String sql = "server=localhost;user id=root;password=123456;database=C#librarycenter"; //根據自己的設置 MySqlConnection conn = new MySqlConnection(sql); conn.Open(); // String yanzheng = "SELECT userPassword FROM userinfo where userName = '"+login.username+"'"; MySqlCommand yz = new MySqlCommand(yanzheng,conn); MySqlDataReader mdr2 = yz.ExecuteReader(); if (mdr2.Read()) { userPassword = mdr2.GetString(0); } mdr2.Close(); if (textBox2.Text.Trim() != "") { if (pw == userPassword) { // String editsql1 = "select userId from userInfo where userName = '" + login.username + "' "; MySqlCommand cmd1 = new MySqlCommand(editsql1, conn); MySqlDataReader mdr = cmd1.ExecuteReader(); if (mdr.Read()) { userId = mdr.GetString(0); } else { } mdr.Close(); // String editsql2 = "update userInfo set userPassword = '" + npw + "', userSex = '" + ans + "'where userId = '" + userId + "'"; MySqlCommand cmd2 = new MySqlCommand(editsql2, conn); int i = cmd2.ExecuteNonQuery(); if (i == 1) { MessageBox.Show(login.username + "\r\n您的信息修改成功!\r\n請牢記您現在的密碼"); } else { MessageBox.Show("修改失敗,請聯系管理員~"); } } else { MessageBox.Show("你的原密碼輸入錯誤,請重新輸入啊啊啊"); } } else { MessageBox.Show("新的密碼請不要填空!"); } } 查詢借閱信息: 主要實現代碼 – borrowedinfo.cs: public borrowedinfo(){ InitializeComponent(); label1.Text = login.username + " ,以下是您的借閱記錄:"; String sql = "server=localhost;user id=root;password=123456;database=C#librarycenter"; //根據自己的設置 MySqlConnection conn = new MySqlConnection(sql); conn.Open();//打開數據庫連接 String userId = ""; MySqlCommand cmd = new MySqlCommand("select userId from borrowed where userName = '"+ login.username +"'",conn); MySqlDataReader mdr = cmd.ExecuteReader(); if (mdr.Read()) { userId = mdr.GetString(0); } mdr.Close(); MySqlDataAdapter data1 = new MySqlDataAdapter();//實例化sqldataadpter MySqlCommand cmd1 = new MySqlCommand("select bookId as '圖書編號',bookName as '圖書名',editTime as '操作時間',edit as '操作' from borrowed where userId = '"+ userId +"'", conn);//sql語句 data1.SelectCommand = cmd1;//設置為已實例化SqlDataAdapter的查詢命令 //DataSet ds1 = new DataSet();//實例化dataset DataTable dt = new DataTable(); dt.Clear(); data1.Fill(dt);//把數據填充到datatable dataGridView1.DataSource = dt;//將數據集綁定datagridview,完成顯示 dataGridView1.AllowUserToAddRows = false; } 后臺管理系統: 主要實現代碼 – adminCenter.cs: private void 關于ToolStripMenuItem_Click(object sender, EventArgs e) { MessageBox.Show("制作者:Matthew Han\r\n完成時間:2017-6-4"); } private void 退出系統ToolStripMenuItem_Click(object sender, EventArgs e) { System.Environment.Exit(0); } private void 圖書管理ToolStripMenuItem_Click(object sender, EventArgs e) { editMain editMain = new editMain(); editMain.FormBorderStyle = FormBorderStyle.None; editMain.Dock = DockStyle.Fill; editMain.TopLevel = false; this.panel1.Controls.Clear(); this.panel1.Controls.Add(editMain); editMain.Show(); } private void 添加圖書ToolStripMenuItem_Click(object sender, EventArgs e) { edit2 edit2 = new edit2(); edit2.Show(); } private void 用戶管理ToolStripMenuItem_Click(object sender, EventArgs e) { edit3 edit3 = new edit3(); edit3.FormBorderStyle = FormBorderStyle.None; edit3.Dock = DockStyle.Fill; edit3.TopLevel = false; this.panel1.Controls.Clear(); this.panel1.Controls.Add(edit3); edit3.Show(); } 修改圖書信息: 主要實現代碼 – editMain.cs & edit1.cs: public static string bookname; public static string bookauthor; public static string bookprice; public static string bookpress; public static string booktype; //說明:這里用的是全局靜態(tài)變量,把表格獲取到的數據保存起來,進行數據傳輸。 private void dataGridView1_CellContentClick(object sender, DataGridViewCellEventArgs e) { int r = this.dataGridView1.CurrentRow.Index; string bn = this.dataGridView1.Rows[r].Cells[1].Value.ToString(); string ba = this.dataGridView1.Rows[r].Cells[2].Value.ToString(); string bp1 = this.dataGridView1.Rows[r].Cells[3].Value.ToString(); string bp2 = this.dataGridView1.Rows[r].Cells[4].Value.ToString(); string bt = this.dataGridView1.Rows[r].Cells[5].Value.ToString(); // editMain editMain = new editMain(); editMain.bookname = bn.ToString(); editMain.bookauthor = ba.ToString(); editMain.bookprice = bp1.ToString(); editMain.bookpress = bp2.ToString(); editMain.booktype = bt.ToString(); // edit1 edit1 = new edit1(); edit1.Show(); } //接下來是edit1.cs中的提交新的數據,update數據庫。 public edit1(){ InitializeComponent(); editMain editMain = new editMain(); label6.Text = editMain.bookname; textBox1.Text = editMain.bookauthor; textBox2.Text = editMain.bookprice; textBox3.Text = editMain.bookpress; textBox4.Text = editMain.booktype; } private void button1_Click(object sender, EventArgs e) { String bn = editMain.bookname; String ba = textBox1.Text; String bp1 = textBox2.Text; String bp2 = textBox3.Text; String bt = textBox4.Text; // String sql = "server=localhost;user id=root;password=123456;database=C#librarycenter"; //根據自己的設置 MySqlConnection conn = new MySqlConnection(sql); conn.Open(); // String sql2 = "update bookInfo set bookAuthor = '" + ba + "', bookPrice = '" + bp1 + "', bookPress = '" + bp2 + "',bookType = '"+ bt +"' where bookName = '"+ bn +"' "; MySqlCommand cmd = new MySqlCommand(sql2, conn); int i = cmd.ExecuteNonQuery(); if (i == 1) { MessageBox.Show("圖書修改成功!"); } this.Hide(); } 添加圖書: 主要實現代碼 – edit2.cs: private void button1_Click(object sender, EventArgs e) { String bn = textBox5.Text; String ba = textBox1.Text; String bp1 = textBox2.Text; String bp2 = textBox3.Text; String bt = textBox4.Text; // String sql = "server=localhost;user id=root;password=123456;database=C#librarycenter"; //根據自己的設置 MySqlConnection conn = new MySqlConnection(sql); conn.Open(); String sql2 = "insert into bookInfo(bookName,bookAuthor,bookPrice,bookPress,bookType,isBorrowed) values('" + bn + "','" + ba + "','" + bp1 + "','" + bp2 + "','" + bt + "','0') "; MySqlCommand cmd = new MySqlCommand(sql2, conn); int i = cmd.ExecuteNonQuery(); if (i == 1) { MessageBox.Show("圖書添加成功!"); } else { MessageBox.Show("系統出錯!"); } this.Hide(); } 用戶管理: 主要實現代碼 – edit3.cs: public edit3(){ InitializeComponent(); String sql = "server=localhost;user id=root;password=123456;database=C#librarycenter"; //根據自己的設置 MySqlConnection conn = new MySqlConnection(sql); conn.Open();//打開數據庫連接 MySqlDataAdapter data1 = new MySqlDataAdapter();//實例化sqldataadpter MySqlCommand cmd1 = new MySqlCommand("SELECT userId as '用戶ID',userName as '用戶名',(CASE userPassword WHEN null THEN '******' ELSE '******' END) as '用戶密碼',userSex as '用戶性別' FROM `c#librarycenter`.userInfo", conn);//sql語句 data1.SelectCommand = cmd1;//設置為已實例化SqlDataAdapter的查詢命令 DataTable dt = new DataTable(); dt.Clear(); data1.Fill(dt);//把數據填充到datatable dataGridView1.DataSource = dt;//將數據集綁定datagridview,完成顯示 dataGridView1.AllowUserToAddRows = false; } 總結 這次的圖書管理系統,并未用到MVC設計模式,只是簡單的面向對象設計,選的題目也是比較熟悉的,本系統提供兩種權限:用戶和管理員,其實應該把【管理員】分成【圖書管理員】和【系統管理員】,提供不同的權限,【系統管理員】具有對所有用戶的操作權限,【圖書管理員】具有對所有圖書的操作權限。本次課題當然還存在著許多不足,以后有機會的話,會加以改進。 姓名:// 學號:// -可編輯修改-- 配套講稿:
如PPT文件的首頁顯示word圖標,表示該PPT已包含配套word講稿。雙擊word圖標可打開word文檔。
- 特殊限制:
部分文檔作品中含有的國旗、國徽等圖片,僅作為作品整體效果示例展示,禁止商用。設計者僅對作品中獨創(chuàng)性部分享有著作權。
- 關 鍵 詞:
- C# MySQL 圖書管理系統 圖書 管理 系統
裝配圖網所有資源均是用戶自行上傳分享,僅供網友學習交流,未經上傳用戶書面授權,請勿作他用。
鏈接地址:http://m.weibangfood.com.cn/p-1124325.html