欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java實(shí)現(xiàn)簡(jiǎn)單的圖書借閱系統(tǒng)

 更新時(shí)間:2022年03月12日 16:20:38   作者:西蘭先森  
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)簡(jiǎn)單的圖書借閱系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(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ù)字運(yùn)算之BigInteger

    在Java中提供了大數(shù)字的操作類,即 java.math.BigInteger 類與 java.math.BigDecimal 類。其中,BigInteger 類是針對(duì)大整數(shù)的處理類,這里有Integer 類的解釋,使用方法和實(shí)例,需要的朋友可以參考下。
    2017-08-08
  • Window中安裝構(gòu)建神器Jenkins詳解

    Window中安裝構(gòu)建神器Jenkins詳解

    Jenkins是一款開源 CI&CD 軟件,用于自動(dòng)化各種任務(wù),包括構(gòu)建、測(cè)試和部署軟件。支持各種運(yùn)行方式,可通過(guò)系統(tǒng)包、Docker 或者通過(guò)一個(gè)獨(dú)立的 Java 程序。是解放人工集成部署的自動(dòng)化構(gòu)建神器
    2021-07-07
  • 使用java實(shí)現(xiàn)“釘釘微應(yīng)用免登進(jìn)入某H5系統(tǒng)首頁(yè)“功能”

    使用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-10
  • Java實(shí)現(xiàn)文件的歸檔和解檔

    Java實(shí)現(xiàn)文件的歸檔和解檔

    這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)文件的歸檔和解檔,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • Java實(shí)現(xiàn)的n階曲線擬合功能示例

    Java實(shí)現(xiàn)的n階曲線擬合功能示例

    這篇文章主要介紹了Java實(shí)現(xiàn)的n階曲線擬合功能,結(jié)合實(shí)例形式分析了Java基于矩陣的多項(xiàng)式曲線擬合相關(guān)操作技巧,需要的朋友可以參考下
    2018-01-01
  • 最通俗的白話講解JDK源碼中的ThreadLocal

    最通俗的白話講解JDK源碼中的ThreadLocal

    ThreadLocal是JDK包提供的,它提供線程本地變量,如果創(chuàng)建一樂(lè)ThreadLocal變量,那么訪問(wèn)這個(gè)變量的每個(gè)線程都會(huì)有這個(gè)變量的一個(gè)副本,在實(shí)際多線程操作的時(shí)候,操作的是自己本地內(nèi)存中的變量,從而規(guī)避了線程安全問(wèn)題,感興趣的朋友快來(lái)看看吧
    2022-01-01
  • Java流程控制之循環(huán)結(jié)構(gòu)for,增強(qiáng)for循環(huán)

    Java流程控制之循環(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-12
  • Java xml出現(xiàn)錯(cuò)誤 javax.xml.transform.TransformerException: java.lang.NullPointerException

    Java 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-11
  • 淺談JVM垃圾回收有哪些常用算法

    淺談JVM垃圾回收有哪些常用算法

    今天給大家?guī)?lái)的是關(guān)于Java虛擬機(jī)的相關(guān)知識(shí),文章圍繞著JVM垃圾回收有哪些常用算法展開,文中有非常詳細(xì)的介紹及代碼示例,需要的朋友可以參考下
    2021-06-06
  • SpringBoot通過(guò)參數(shù)注解自動(dòng)獲取當(dāng)前用戶信息的方法

    SpringBoot通過(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

最新評(píng)論