基本信息
源码名称:数据库课程设计:图书管理系统(JAVA源码+sql server数据库)
源码大小:1.19M
文件格式:.zip
开发语言:Java
更新时间:2019-06-27
   友情提示:(无需注册或充值,赞助后即可获取资源下载链接)

     嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300

本次赞助数额为: 2 元 
   源码介绍

开发工具:MyEclipse、SQL Server 2008,基本的图书管理系统,包含增删改查、java图形界面,数据库技术包含存储过程与触发器。

【调试步骤】

0. 执行数据库脚本 或者附加数据库 以达到让数据库可用的目的

1. 修改源码中的数据库密码 为您本地的密码

2. 输入管理员账号密码admin1/admin1 即可看到如下界面





读者登陆如下:











package MainUI;


import java.awt.*;
import java.awt.event.*;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;

import javax.swing.*;
import javax.swing.Timer;
 
 
import java.util.*;
 
public class login extends JFrame implements ActionListener, ItemListener {
	Container ct; 
	BackgroundPanel bgp; 
	
    JLabel user = new JLabel("用户名:");
    JLabel password = new JLabel("密    码:");
    JLabel usertype = new JLabel("用户类型:");
    JLabel space = new JLabel("        ");//用来占位
    JButton login = new JButton();
    JButton cancel = new JButton();
     
    ButtonGroup buttongroup = new ButtonGroup();
    JRadioButton mang = new JRadioButton("管理员");
    JRadioButton stu = new JRadioButton("读者");
    
    static JTextField text1 = new JTextField(18);
    JPasswordField text2 = new JPasswordField(18);

    public int a=0,b=0;
    
    
    public static void main(String args[]) {
    	new login();
    }
    
    public login() {
        super("登陆窗口");
        
       // setResizable(false);
        
        bgp=new BackgroundPanel((new ImageIcon("photo//login//login.jpg")).getImage()); //参数是一个Image对象,
        bgp.setLayout(new FlowLayout(FlowLayout.CENTER, 10, 15));
        bgp.setBounds(0,0,300,220);
         
        bgp.add(user);
        bgp.add(text1);
        bgp.add(password);
        bgp.add(text2);
        bgp.add(usertype);
        bgp.add(mang);
        bgp.add(stu);
         
        bgp.add(space);
        
        buttongroup.add(mang);
        buttongroup.add(stu);
        
        login.setIcon(new ImageIcon("photo//login//register.png"));
        login.setBorder(null); 
        cancel.setIcon(new ImageIcon("photo//login//exit.png"));
        cancel.setBorder(null);
        bgp.add(login);
        bgp.add(cancel);
        
        
        ct=this.getContentPane();
        ct.add(bgp);
       
        this.setLayout(null); 
         
        mang.addItemListener(this);//添加事件监听
        stu.addItemListener(this);
        login.addActionListener(this);
        cancel.addActionListener(this);
        
        this.setSize(300,220);  
        this.setLocationRelativeTo(null); 
        this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); 
        this.setResizable(false);
        this.setVisible(true); 
        
       // pack();
        addWindowListener(new WindowAdapter() {
            public void windowClosing(WindowEvent e) {
                dispose();
                System.exit(0);
            }
        });
    }
 
    public void actionPerformed(ActionEvent e) {//登录按钮
        if (e.getSource() == login) {
        	
        	Connection conn = null;
            Statement stmt = null;
            ResultSet rs = null;
            String url = "jdbc:sqlserver://localhost:1433;DatabaseName=librarydb;";
            String sql = "select * from Admin";
            String sql2 = "select * from Reader";
            String eq = null;
            if(a==1&&b==0)
            {
            	eq = sql;
            }else if(a==0&&b==1)
            {
            	eq=sql2;
            }
            
            try {
                // 连接数据库
            	reminder(text1.getText(),text2.getText());//检查登录的问题
                conn = DriverManager.getConnection(url, "sa", "1@1.com");
                stmt = conn.createStatement();
                rs = stmt.executeQuery(eq);//连接数据库
                while (rs.next()) {
                    String account1 = rs.getString("Admin_id");//账号
                    String password1 = rs.getString("Admin_code");//密码
                    if(account1.equals(text1.getText())&&password1.equals(text2.getText())&&a==1)//管理员
                    {
                    	new MainForm(text1.getText(),true,true);
                    	JOptionPane.showMessageDialog(null, "管理员登录", "登录信息",JOptionPane.WARNING_MESSAGE);
                    	dispose();
                    }                   
                }
                if (rs != null) {rs.close();rs = null;}
                if (stmt != null) {stmt.close();stmt = null;}
                if (conn != null) {conn.close();conn = null;}
        }catch (Exception e1) {
        	try{
        	while (rs.next()) {
                String account2 = rs.getString("Reader_id");//账号
                String password2 = rs.getString("Reader_code");//密码
               if(account2.equals(text1.getText())&&password2.equals(text2.getText())&&b==1)//读者
                {
                	new MainForm(text1.getText(),true,false);
                	JOptionPane.showMessageDialog(null, "读者登录", "登录信息",JOptionPane.WARNING_MESSAGE);
                	dispose();
                }               
            }
        	if (rs != null) {rs.close();rs = null;}
            if (stmt != null) {stmt.close();stmt = null;}
            if (conn != null) {conn.close();conn = null;}
        	}catch(Exception e2){
        		//JOptionPane.showMessageDialog(null, "数据库连接失败,你的账户密码有误", "出现错误",JOptionPane.WARNING_MESSAGE);
        	}
            }
            } else if (e.getSource() == cancel) {//退出按钮
            dispose();
        }
    }
 
	public void itemStateChanged(ItemEvent e) 
    {//三种身份按钮

            if (e.getSource() == mang) {
            	a=1;b=0;
            } else if (e.getSource() == stu) {
            	a=0;b=1;
            }
    } 
    
    public void reminder(String acc,String pwd)
    {	
    	acc=text1.getText();
    	pwd=text2.getText();
    	if(acc.length()==0&&pwd.length()!=0){ShakeFrame();}
    	if(acc.length()!=0&&pwd.length()==0){ShakeFrame();}
    	if(acc.length()==0&&pwd.length()==0){ShakeFrame();}
    	
    }
    
    public void ShakeFrame(){
    	int x = this.getX();
        int y = this.getY();
        for (int i = 0; i < 10; i  ) {
         if ((i & 1) == 0) {
          x  = 3;
          y  = 3;
         } else {
          x -= 3;
          y -= 3;
         }
         this.setLocation(x, y);
         try {
          Thread.sleep(50);
         } catch (InterruptedException e1) {
          e1.printStackTrace();
         }
         }
        }
}


class BackgroundPanel extends JPanel  
{  
    Image im;  
    public BackgroundPanel(Image im)  
    {  
        this.im=im;  
        this.setOpaque(true);                    //设置控件不透明,若是false,那么就是透明
    }  
    //Draw the background again,继承自Jpanle,是Swing控件需要继承实现的方法,而不是AWT中的Paint()
    public void paintComponent(Graphics g)       //绘图类,详情可见博主的Java 下 java-Graphics 
    {  
        super.paintComponents(g);  
        g.drawImage(im,0,0,this.getWidth(),this.getHeight(),this);  //绘制指定图像中当前可用的图像。图像的左上角位于该图形上下文坐标空间的 (x, y)。图像中的透明像素不影响该处已存在的像素

    }  
}