java實(shí)現(xiàn)簡(jiǎn)單的圖書借閱系統(tǒng)
本文實(shí)例為大家分享了java實(shí)現(xiàn)簡(jiǎn)單圖書借閱系統(tǒng)的具體代碼,供大家參考,具體內(nèi)容如下
直接看代碼:
package ttt; import java.awt.BorderLayout; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; import javax.swing.JButton; import javax.swing.JFrame; import javax.swing.JOptionPane; import javax.swing.JPanel; import javax.swing.JScrollPane; import javax.swing.JTable; import javax.swing.border.TitledBorder; import javax.swing.table.DefaultTableModel; public class Labmsys extends JFrame{ ? ? ? ? JTable booktable=null; ? ? ? ? static DefaultTableModel bookmodel=null; ? ? ? ? JTable borrowtable=null; ? ? ? ? static DefaultTableModel bmodel=null; ? ? ? ? JPanel j1=new JPanel(); ? ? ? ? JPanel j2=new JPanel(); ? ? ? ? JPanel j3=new JPanel(); ? ? ? ? JButton button1=new JButton("借書"); ? ? ? ? JButton button2=new JButton("還書"); ? ? public Labmsys() ? ? { ? ? ? ? this.setLayout(new BorderLayout()); ? ? ? ? this.add(j1,BorderLayout.WEST); ? ? ? ? this.add(j2,BorderLayout.EAST); ? ? ? ? this.add(j3,BorderLayout.CENTER); ? ? ? ? j1.setBorder(new TitledBorder("圖書借書表")); ? ? ? ? j2.setBorder(new TitledBorder("圖書庫(kù)存表")); ? ? ? ? this.booktable=bookIn(); ? ? ? ? this.borrowtable=borrowIn(); ? ? ? ? JScrollPane ?jsp1=new JScrollPane(borrowtable); ? ? ? ? JScrollPane ?jsp2=new JScrollPane(booktable); ? ? ? ? j1.add(jsp1); ? ? ? ? j2.add(jsp2); ? ? ? ? j3.add(button1); ? ? ? ? j3.add(button2); ? ? ? ? //添加借書監(jiān)聽器 ? ? ? ? button1.addActionListener(new ActionListener() ? ? ? ? { ? ? ? ? ? ? @Override ? ? ? ? ? ? public void actionPerformed(ActionEvent e) { ? ? ? ? ? ? ? ? // TODO Auto-generated method stub ? ? ? ? ? ? ? ? int rowNum=booktable.getSelectedRow(); ? ? ? ? ? ? ? ? System.out.println(rowNum); ? ? ? ? ? ? ? ? if(rowNum>=0) ? ? ? ? ? ? ? ? { ? ? ? ? ? ? ? ? ? ? String isbn=booktable.getValueAt(rowNum, 0).toString(); ? ? ? ? ? ? ? ? ? ? System.out.println(isbn); ? ? ? ? ? ? ? ? ? ? int count=Integer.parseInt((String) booktable.getValueAt(rowNum, 2)); ? ? ? ? ? ? ? ? ? ? String s=JOptionPane.showInputDialog("請(qǐng)輸入學(xué)號(hào)"); ? ? ? ? ? ? ? ? ? ? if(count<=0) ? ? ? ? ? ? ? ? ? ? ? ? JOptionPane.showMessageDialog(null,"圖書庫(kù)存不足"); ? ? ? ? ? ? ? ? ? ? else if (null==s) ? ? ? ? ? ? ? ? ? ? ? ? JOptionPane.showMessageDialog(null,"請(qǐng)輸入學(xué)號(hào)"); ? ? ? ? ? ? ? ? ? ? else{ ? ? ? ? ? ? ? ? ? ? ? ? if(borrowBook(isbn,s)) ? ? ? ? ? ? ? ? ? ? ? ? { ? ? ? ? ? ? ? ? ? ? ? ? ? ? System.out.println("yes"); ? ? ? ? ? ? ? ? ? ? ? ? ? ? JOptionPane.showMessageDialog(null,"successful!"); ? ? ? ? ? ? ? ? ? ? ? ? } ? ? ? ? ? ? ? ? ? ? ? ? else JOptionPane.showMessageDialog(null,"Wrong!"); ? ? ? ? ? ? ? ? ? ? } ? ? ? ? ? ? ? ? }else JOptionPane.showMessageDialog(null,"Choose book!"); ? ? ? ? ? ? } ? ? ? }); ? ? ? ? //添加還書監(jiān)聽器 ? ? ? ? button2.addActionListener(new ActionListener() ? ? ? ? { ? ? ? ? ? ? @Override ? ? ? ? ? ? public void actionPerformed(ActionEvent e) { ? ? ? ? ? ? ? ? // TODO Auto-generated method stub ? ? ? ? ? ? ? ? int rowNum=borrowtable.getSelectedRow(); ? ? ? ? ? ? ? ? System.out.println(rowNum); ? ? ? ? ? ? ? ? if(rowNum>=0) ? ? ? ? ? ? ? ? { ? ? ? ? ? ? ? ? ? ? String isbn=borrowtable.getValueAt(rowNum, 2).toString(); ? ? ? ? ? ? ? ? ? ? String tablexh = borrowtable.getValueAt(rowNum, 1).toString(); ? ? ? ? ? ? ? ? ? ? System.out.println(isbn); ? ? ? ? ? ? ? ? ? ? String xh=JOptionPane.showInputDialog("請(qǐng)輸入學(xué)號(hào)"); ? ? ? ? ? ? ? ? ? ? if (!xh.equals(tablexh)) ? ? ? ? ? ? ? ? ? ? ? ? JOptionPane.showMessageDialog(null,"學(xué)號(hào)不正確"); ? ? ? ? ? ? ? ? ? ? else{ ? ? ? ? ? ? ? ? ? ? ? ? if(returnBook(isbn)) ? ? ? ? ? ? ? ? ? ? ? ? { ? ? ? ? ? ? ? ? ? ? ? ? ? ? JOptionPane.showMessageDialog(null,"successful!"); ? ? ? ? ? ? ? ? ? ? ? ? } ? ? ? ? ? ? ? ? ? ? ? ? else JOptionPane.showMessageDialog(null,"Wrong!"); ? ? ? ? ? ? ? ? ? ? } ? ? ? ? ? ? ? ? }else JOptionPane.showMessageDialog(null,"Choose book!"); ? ? ? ? ? ? ? ? } ? ? ? ? ? ? }); ? ? } ? ? public boolean borrowBook(String isbn, String s) { ? ? ? ? ? ? ? ? int xh = Integer.parseInt(s); ? ? ? ? ? ? ? ? int isbn2 =Integer.parseInt(isbn); ? ? ? ? ? ? ? ? System.out.println("學(xué)號(hào):"+xh); ? ? ? ? boolean b=false; ? ? ? ? String driver="com.mysql.jdbc.Driver"; ? ? ? ? String url="jdbc:mysql://localhost:3306/test"; ? ? ? ? String user="root"; ? ? ? ? String password="123456"; ? ? ? ? Connection conn=null; ? ? ? ? Statement stmt=null; ? ? ? ? try { ? ? ? ? ? ? ? ? ?Class.forName(driver);? ? ? ? ? ? ? ? ?conn = DriverManager.getConnection(url, user, password); ? ? ? ? ? ? ? ? ?stmt = conn.createStatement(); ? ? ? ? ? ? ? ? ?System.out.println("isbn:"+isbn); ? ? ? ? ? ? ? ?conn.setAutoCommit(false); ? ? ? ? ? ? ? ?String sql1 = "update book set count=count-1 where isbn='"+isbn2+"'"; ? ? ? ? ? ? ? ?String sql2 = "insert into borrow(xh,isbn) values('"+xh+"','"+isbn2+"')"; ? ? ? ? ? ? ? ?stmt.executeUpdate(sql1); ? ? ? ? ? ? ? ?stmt.executeUpdate(sql2); ? ? ? ? ? ? ? ?System.out.println("isbn2:"+isbn2); ? ? ? ? ? ? ? ?//stmt = (PreparedStatement) conn.prepareStatement("update book set count=count-1 where isbn=?"); ? ? ? ? ? ? ? ?conn.commit(); ? ? ? ? ? ? ? ?stmt.close(); ? ? ? ? ? ? ? ?conn.close(); ? ? ? ? ? ? ? ?b=true; ? ? ? ? } ? ? ? ? catch (Exception e) { ? ? ? ? ? ? ? ? ?try{ ? ? ? ? ? ? ? ? ? ?conn.rollback(); ? ? ? ? ? ? ? ?}catch(Exception e1){e1.printStackTrace();} ? ? ? ? ? ? ? } ? ? ? ? ? ? ? ? return b; ? ? ? ? ? ? } ? ? private boolean returnBook(String isbn) { ? ? ? ? int isbn2 =Integer.parseInt(isbn); ? ? ? ? ? ?boolean b=false; ? ? ? ? ? ?String driver="com.mysql.jdbc.Driver"; ? ? ? ? ? ?String url="jdbc:mysql://localhost:3306/test"; ? ? ? ? ? ?String user="root"; ? ? ? ? ? ?String password="123456"; ? ? ? ? ? ?Connection conn=null; ? ? ? ? ? ?Statement stmt=null; ? ? ? ? ? ?try { ? ? ? ? ? ? ? ?Class.forName(driver);? ? ? ? ? ? ? ?conn = DriverManager.getConnection(url, user, password); ? ? ? ? ? ? ? ?stmt = conn.createStatement(); ? ? ? ? ? ? ? ?conn.setAutoCommit(false); ? ? ? ? ? ? ?stmt.executeUpdate("delete from borrow where isbn='"+isbn2+"'"); ? ? ? ? ? ? ?stmt.executeUpdate("update book set count=count+1 where isbn='"+isbn2+"'"); ? ? ? ? ? ? ?System.out.println("還書isbn2:"+isbn2); ? ? ? ? ? ? ?conn.commit(); ? ? ? ? ? ? ?stmt.close(); ? ? ? ? ? ? ?conn.close(); ? ? ? ? ? ? ?b=true; ? ? ? ? ? ? ?} ? ? ? ? ? ?catch (Exception e) { ? ? ? ? ? ? ? ? ?try{ ? ? ? ? ? ? ? ? ? ?conn.rollback(); ? ? ? ? ? ? ? ? ? ?}catch(Exception e1){e1.printStackTrace();}} ? ? ? ? ? ? ?return b; ? ? } ? ? private JTable borrowIn() { ? ? ? ? // TODO Auto-generated method stub ? ? ? ? String []head={"id","xh","ISBN"}; ? ? ? ? String [][]data=null; ? ? ? ? bookmodel=new DefaultTableModel(data,head); ? ? ? ? JTable t=new JTable(bookmodel); ? ? ? ? String driver="com.mysql.jdbc.Driver"; ? ? ? ? String url="jdbc:mysql://localhost:3306/test"; ? ? ? ? String user="root"; ? ? ? ? String password="123456"; ? ? ? ? Connection conn=null; ? ? ? ? Statement stmt=null; ? ? ? ? ResultSet rs=null; ? ? ? ? try { ? ? ? ? ? ? ? ? ?Class.forName(driver);? ? ? ? ? ? ? ? ?conn = DriverManager.getConnection(url, user, password); ? ? ? ? ? ? ? ? ?stmt = conn.createStatement(); ? ? ? ? ? ? ? ? ?rs=stmt.executeQuery("select * from borrow");? ? ? ? ? ? ? ? ?String[] row=new String[3]; ? ? ? ? ? ? ? ?while(rs.next()){ ? ? ? ? ? ? ? ?row[0]=rs.getString(1); ? ? ? ? ? ? ? ?row[1]=rs.getString(2); ? ? ? ? ? ? ? ?row[2]=rs.getString(3); ? ? ? ? ? ? ? ?bookmodel.addRow(row); ? ? ? ? ? ? ? ?bookmodel.fireTableDataChanged(); } ? ? ? ? ? ? ? ?rs.close(); ? ? ? ? ? ? ? ?stmt.close(); ? ? ? ? ? ? ? ?conn.close();} ? ? ? ? catch (Exception e) { ? ? ? ? ? ? ? ? ?// TODO Auto-generated catch block ? ?? ? ? ? ? ? ? ? ?System.out.println(e); ? ? ? ? ? ? ? ? } ? ? ? ? ? ? ? ? return t; ? ? } ? ? public ?JTable bookIn() { ? ? ? ? // TODO Auto-generated method stub ? ? ? ? String []head={"ISBN","name","count"}; ? ? ? ? String [][]data=null; ? ? ? ? bmodel=new DefaultTableModel(data,head); ? ? ? ? JTable t=new JTable(bmodel); ? ? ? ? String driver="com.mysql.jdbc.Driver"; ? ? ? ? String url="jdbc:mysql://localhost:3306/test"; ? ? ? ? String user="root"; ? ? ? ? String password="123456"; ? ? ? ? Connection conn=null; ? ? ? ? Statement stmt=null; ? ? ? ? ResultSet rs=null; ? ? ? ? try { ? ? ? ? ? ? ? ? ?Class.forName(driver);? ? ? ? ? ? ? ? ?conn = DriverManager.getConnection(url, user, password); ? ? ? ? ? ? ? ? ?stmt = conn.createStatement(); ? ? ? ? ? ? ? ? ?rs=stmt.executeQuery("select * from book");? ? ? ? ? ? ? ? ?String[] row=new String[3]; ? ? ? ? ? ? ? ?while(rs.next()){ ? ? ? ? ? ? ? ?row[0]=rs.getString(1); ? ? ? ? ? ? ? ?row[1]=rs.getString(2); ? ? ? ? ? ? ? ?row[2]=rs.getString(3); ? ? ? ? ? ? ? ?bmodel.addRow(row); ? ? ? ? ? ? ? ?bmodel.fireTableDataChanged(); } ? ? ? ? ? ? ? ?rs.close(); ? ? ? ? ? ? ? ?stmt.close(); ? ? ? ? ? ? ? ?conn.close();} ? ? ? ? catch (Exception e) { ? ? ? ? ? ? ? ? ?// TODO Auto-generated catch block ? ?? ? ? ? ? ? ? ? ?System.out.println(e); ? ? ? ? ? ? ? ? } ? ? ? ? return t; ? ? ? } ? ? public static void main(String[] args) { ? ? ? ? // TODO Auto-generated method stub ? ? ? ? Labmsys n=new Labmsys();? ? ? ? ? n.setTitle("圖書借閱管理系統(tǒng)"); ? ? ? ? n.setSize(1000,500); ? ? ? ? n.setLocationRelativeTo(null); ? ? ? ? n.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); ? ? ? ? n.setVisible(true); ? ? } }
數(shù)據(jù)庫(kù):
-- -- Table structure for table `book` -- DROP TABLE IF EXISTS `book`; CREATE TABLE `book` ( ? `ISBN` int(11) NOT NULL, ? `name` varchar(50) NOT NULL, ? `count` int(11) default NULL, ? PRIMARY KEY ?(`ISBN`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- -- Dumping data for table `book` -- LOCK TABLES `book` WRITE; /*!40000 ALTER TABLE `book` DISABLE KEYS */; INSERT INTO `book` VALUES (662530,'c#',9),(662545,'python',12),(663520,'c++',6),(663548,'java',8); /*!40000 ALTER TABLE `book` ENABLE KEYS */; UNLOCK TABLES; -- -- Table structure for table `borrow` -- DROP TABLE IF EXISTS `borrow`; CREATE TABLE `borrow` ( ? `id` int(11) NOT NULL auto_increment, ? `xh` int(11) NOT NULL, ? `isbn` int(11) NOT NULL, ? PRIMARY KEY ?(`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- -- Dumping data for table `borrow` -- LOCK TABLES `borrow` WRITE; /*!40000 ALTER TABLE `borrow` DISABLE KEYS */; INSERT INTO `borrow` VALUES (1006,123456,662545),(1007,456789,663520),(1009,789456,662530),(1010,741852,662530);
運(yùn)行結(jié)果顯示:
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java大數(shù)字運(yùn)算之BigInteger
在Java中提供了大數(shù)字的操作類,即 java.math.BigInteger 類與 java.math.BigDecimal 類。其中,BigInteger 類是針對(duì)大整數(shù)的處理類,這里有Integer 類的解釋,使用方法和實(shí)例,需要的朋友可以參考下。2017-08-08使用java實(shí)現(xiàn)“釘釘微應(yīng)用免登進(jìn)入某H5系統(tǒng)首頁(yè)“功能”
這篇文章主要介紹了用java實(shí)現(xiàn)“釘釘微應(yīng)用,免登進(jìn)入某H5系統(tǒng)首頁(yè)“功能”,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-10-10Java流程控制之循環(huán)結(jié)構(gòu)for,增強(qiáng)for循環(huán)
這篇文章主要介紹了Java流程控制之循環(huán)結(jié)構(gòu)for,增強(qiáng)for循環(huán),for循環(huán)是編程語(yǔ)言中一種循環(huán)語(yǔ)句,而循環(huán)語(yǔ)句由循環(huán)體及循環(huán)的判定條件兩部分組成,其表達(dá)式為:for(單次表達(dá)式;條件表達(dá)式;末尾循環(huán)體){中間循環(huán)體;},下面我們倆看看文章內(nèi)容的詳細(xì)介紹2021-12-12Java xml出現(xiàn)錯(cuò)誤 javax.xml.transform.TransformerException: java.
這篇文章主要介紹了Java xml出現(xiàn)錯(cuò)誤 javax.xml.transform.TransformerException: java.lang.NullPointerException的相關(guān)資料,需要的朋友可以參考下2016-11-11SpringBoot通過(guò)參數(shù)注解自動(dòng)獲取當(dāng)前用戶信息的方法
這篇文章主要介紹了SpringBoot通過(guò)參數(shù)注解自動(dòng)獲取當(dāng)前用戶信息的方法,文中使用HandlerMethodArgumentResolver 類來(lái)實(shí)現(xiàn)這個(gè)功能,并通過(guò)代碼示例講解的非常詳細(xì),需要的朋友可以參考下2024-03-03