当前位置:Gxlcms > 数据库问题 > 数据库存储ATM机,开户、查询等信息

数据库存储ATM机,开户、查询等信息

时间:2021-07-01 10:21:17 帮助过:4人阅读

 

package com.bank.unionpay;

//银行卡的接口
public interface I_yinhangka 
{

	//抽象方法
	//public abstract默认修饰抽象的
	
	public abstract void cxyue();//查询余额
	
	void  cunkuan();//存款
	
	void qukuan();//取款
	
	void accound();//账户
	
	
}

  

package com.bank.unionpay;

import java.util.ArrayList;
import java.util.List;

public class Zhujiemian {
	
	public void zhujiemian()
	{
		System.out.println("银行自助终端系统");
		System.out.println();
		System.out.println("************************");
		List<String> li=new ArrayList<>();
		li.add("开户");
		li.add("查询");
		li.add("存款");
		li.add("取款");
		li.add("退出");
		
		for(int i=0;i<5;i++)
		{
			System.out.println(i+"------"+li.get(i));
		}
		System.out.println();
		System.out.println("请选择您要执行的功能");
	}

}

  

package com.bank.unionpay;

public abstract class Atm implements I_yinhangka
{
	String leixing;//银行卡类型
	String accound;//账户
	double qukuan;//取款
	double cunkuan;//存款
	double cxyue ;//余额
	String name;
	String sfzheng;//省份证号
	

	
	public Atm(String name,String sfzheng,String accound, double cxyue ) {
		super();
		this.accound = accound;
		this.cxyue = cxyue;
		this.name = name;
		this.sfzheng = sfzheng;
	}
	

	public Atm() {
		super();
	}


	@Override
	public void cxyue()
	{
		// 查询余额
		cxyue-=qukuan;
		cxyue+=cunkuan;

		System.out.println("您的余额="+cxyue);
	}

	@Override
	public void cunkuan() 
	{
		// 存款
		cxyue+=cunkuan;
		
		System.out.println("存款成功,您的存款金额为"+cunkuan);
        System.out.println("本次操作后您的余额为:"+cxyue);
	}

	@Override
	public void qukuan() 
	{
		// 取款
		cxyue-=qukuan;
		if(cxyue>=0)
		{
			System.out.println("取款成功,本次取款金额= "+qukuan);
			System.out.println("本次操作后您的余额= "+cxyue);
		}
		else
		{
			System.out.println("余额不足,无法取款");
			
		}
		
	}

	@Override
	public void accound() {
		// 账户
		
	}

	
	//声明成员方法
	public double qukuan(double qukuan)//取款
	{
		cxyue-=qukuan;
		if(cxyue>=0)
		{
			System.out.println("取款成功,本次取款金额= "+qukuan);
			System.out.println("本次操作后您的余额= "+cxyue);
		}
		else
		{
			System.out.println("余额不足,无法取款");
			
		}
		return qukuan;
		
	}
	
	public double cunkuan(double cunkuan)//存款
	{
		

		cxyue+=cunkuan;
		
		System.out.println("存款成功,您的存款金额为"+cunkuan);
        System.out.println("本次操作后您的余额为:"+cxyue);
		return cunkuan;
	}
	
	public double cxyue(double cxyue)
	{
		cxyue-=qukuan;
		cxyue+=cunkuan;

		System.out.println("您的余额="+cxyue);
		return cxyue;
	}
	
	//添加开户的抽象方法
	public abstract void kaihu();

}

  

package com.bank.unionpay;

//银行枚举类型
public enum Leixing 
{

	ABC("农行"),ICBC("工行"),CCB("建行"),BOC("中行");
	
	private   final String leixing;
	
	
	public String getLeixing() 
	{
		return this.leixing;
	}

	//构造方法
	private Leixing(String leixing)
	{
		this.leixing=leixing;
	}
	
}

  

package com.bank.abc;

import java.io.Serializable;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import com.bank.unionpay.Leixing;

//单利模式
public class Bank implements Serializable 
{
	private Bank()//禁止外部访问构造方法
	{
		
	}
	private static Bank  bank=new Bank();//内部产生唯一实例
	public static Bank  getBank()//开放一个方法给调用者返回这个实例
	{
		return bank;
	}

	final Leixing lx=Leixing.ABC;//农行类型
	
	private String yhName;//银行名称
	
	public List <String>card=new ArrayList<>();//银行卡列表
	
	//public Map<String, CxCard > account=new HashMap<>();//账号储蓄卡集合
	
	
}

  

package com.bank.abc;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Random;
import java.util.Scanner;

import com.bank.unionpay.Atm;
import com.bank.unionpay.Leixing;

public class Atm2 extends Atm 
{

	 public CxCard cx=new  CxCard();//
	
	public Atm2(String name, String sfzheng, String accound, double cxyue) {
		super(name, sfzheng, accound, cxyue);
		// TODO 自动生成的构造函数存根
	}

	public  Atm2() {
		// TODO 自动生成的构造函数存根
		super();
	}

	final Leixing lx = Leixing.ABC;

	@Override
	public void kaihu()// 实现开户
	{
		System.out.println("您选择的为开户功能");
		Scanner sc0=new Scanner(System.in);
		System.out.println("请输入姓名");
		String name=sc0.nextLine();
			
				
		for(int i=1;i>0;i++) 
		{
			System.out.println("请输入身份证号");
			String sfzheng=sc0.nextLine();
				
				if(sfzheng.length()==18)//判断身份证
				{
			
					for(int j=1;j>0;j++)
					{
						
						System.out.println("请输入密码");
						String mm="\\d{6}";//6位数字正则表达式
						String password=sc0.nextLine();
						if(password.matches(mm))
						{
					
							//cx.setPassword(password);//写入密码
								
							
							Random  ra=new Random();//随机生成6位卡号
							int[] ch=new int[6];
							StringBuilder str=new StringBuilder();
							String s;//用于下面拼接
							for(int k=0;k<6;k++)
							{
								ch[k]=ra.nextInt(9);//0-9
							}
								
							for(Integer c:ch)
							{
							str.append(c.toString());//遍历  拼接6位数字
							}
							s=str.toString();
							//cx.setCairNumber(s);//写入卡号
							
							
//							Bank.getBank().card.add(cx.getCairNumber());//将生成的储蓄卡号存到银行的银行卡列表中
//
//							Bank.getBank().account.put(cx.getCairNumber(), cx); //id+储蓄卡对象
							System.out.println("开户成功");
							System.out.println("您的账号为: "+s);
							
							
							// 访问数据库
							//1.加载驱动:加载数据库提供的驱动类
							try {	
								Class.forName("oracle.jdbc.driver.OracleDriver");
							} catch (ClassNotFoundException e) {
								// TODO 自动生成的 catch 块
								e.printStackTrace();
							}
							//2.获取数据库连接
							Connection conn;
							try {	
								conn = DriverManager.getConnection("jdbc:oracle:thin:@127.0.0.1:1521:orcl", 
										"test0816", "123456");
							
							
								System.out.println("连接成功");
							
							//操作数据库:增删改查
							//3.获得操作数据库的声明
							Statement st;
							
								st = conn.createStatement();
							
							
								int y=st.executeUpdate("insert into ATM(cairNumber,name,sfzheng,cxyue,password)"
								+"values(‘"+s+"‘,‘"+name+"‘,‘"+sfzheng+"‘,‘"+cx.getCxyue()+"‘,‘"+password+"‘)");
							} 
							catch (SQLException e) {
								// TODO 自动生成的 catch 块
								e.printStackTrace();
							}		
							break;
						}
							
						else
						{
							System.out.println("请输入6位纯数字密码");
						}
					}
						
				break;
				}
					
				else
				{
					System.out.println("请重新输入身份证号");
				
				}	
		}	
			
	}

}

  

package com.bank.abc;

import java.io.Serializable;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Scanner;

import com.bank.unionpay.Leixing;

//储蓄卡
//只有实现了Serializable和Externalizable接口的类的对象才能被序列化。
public class CxCard implements Serializable 


{
	//属性
	final Leixing lx=Leixing.ABC;
	String  name;//姓名
	String sfzheng;//身份证号
	String cairNumber2;//卡号
	String password;//密码
	double cxyue ;//余额
	
	//生成卡号的get   set方法

	public String getCairNumber() {
		return cairNumber2;
	}

	public void setCairNumber(String cairNumber) {
		this.cairNumber2 = cairNumber;
	}
	

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public String getSfzheng() {
		return sfzheng;
	}

	public void setSfzheng(String sfzheng) {
		this.sfzheng = sfzheng;
	}

	public String getPassword() {
		return password;
	}

	public void setPassword(String password) {
		this.password = password;
	}

	public double getCxyue() {
		return cxyue;
	}

	public void setCxyue(double cxyue) {
		this.cxyue = cxyue;
	}

	public CxCard(String cairNumber, String password) {
		super();
		
		this.cairNumber2 = cairNumber;
		this.password = password;
		
	}

	

	@Override
	public String toString() {
		return "姓名:" + name + "\n"+" 身份证:" + sfzheng + "\n"+"卡号: " + cairNumber2 +"\n"+ " 余额:" + cxyue;
	}

	public CxCard() {
		// TODO 自动生成的构造函数存根
	}

//声明成员方法
public void qukuan()//取款
{
	if(true)
	{
		System.out.println("您选择的为取款功能");
		for(int i=1;i>0;i++)
		{
			Scanner sc1=new Scanner(System.in);
				
			System.out.println("请输入您要取款的卡号");
			String c2=sc1.nextLine();
			
			try 
			{
				Class.forName("oracle.jdbc.driver.OracleDriver") ;
				
				Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@127.0.0.1:1521:orcl",
						"test0816","123456") ;
				
				Statement st = conn.createStatement() ;
				//查询用户输入卡号的结果集
				ResultSet rs =st.executeQuery("select * from ATM where cairnumber = ‘" +c2 +"‘ ") ;
				
				if(rs.next())
				{
					
					String ss = rs.getString("password") ;
					for(int k = 0 ; k<3; k++ )
					{
						System.out.println("请输入您的密码:");
						Scanner mm = new Scanner(System.in) ;
						String mima = mm.nextLine();
						if(ss.equals(mima))
						{
							System.out.println("请输入取款金额");
							Scanner sc =new Scanner(System.in);
							double qk =sc.nextDouble();
							if(qk>0)
							{
								double yue = rs.getDouble("cxyue");
								if(qk<=yue)
								{
									double sumyue =yue-qk;
									st.executeUpdate("update ATM set cxyue=‘"+sumyue+"‘ where cairnumber "
										+ "= ‘" +c2 +"‘ ");
									System.out.println("取款成功");
									
									break;
								}
								else
								{
									System.out.println("您的余额不足,无法取款");
								}
							}
							else
							{
								System.out.println("您输入的取款金额,系统不识别");
							}
							
							
						}
						else
						{
							System.out.println("密码不对");
						}

					break;
					}
					break;
				}
				rs.close();
				st.close();
				conn.close();
			} catch (ClassNotFoundException | SQLException e) {
				// TODO 自动生成的 catch 块
				e.printStackTrace();
			}
			
		}
			
	}
		
			
}
		
public void cunkuan()//存款
{

	if(true)
	{
		System.out.println("您选择的为存款功能");
		for(int i=1;i>0;i++)
		{
			Scanner sc1=new Scanner(System.in);
				
			System.out.println("请输入您要存款的卡号");
			String c2=sc1.nextLine();
			
			try 
			{
				Class.forName("oracle.jdbc.driver.OracleDriver") ;
				
				Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@127.0.0.1:1521:orcl",
						"test0816","123456") ;
				
				Statement st = conn.createStatement() ;
				//查询用户输入卡号的结果集
				ResultSet rs =st.executeQuery("select * from ATM where cairnumber = ‘" +c2 +"‘ ") ;
				
				if(rs.next())
				{
					
					String ss = rs.getString("password") ;
					for(int k = 0 ; k<3; k++ )
					{
						System.out.println("请输入您的密码:");
						Scanner mm = new Scanner(System.in) ;
						String mima = mm.nextLine();
						if(ss.equals(mima))
						{
							System.out.println("请输入存款金额");
							Scanner sc =new Scanner(System.in);
							double ck =sc.nextDouble();
							if(ck>=0)
							{
								double yue = rs.getDouble("cxyue");
								double sumyue =yue+ck;
								st.executeUpdate("update ATM set cxyue=‘"+sumyue+"‘ where cairnumber "
										+ "= ‘" +c2 +"‘ ");
								System.out.println("存款成功");
								
								break;
							}
							else
							{
								System.out.println("您输入的存款金额,系统不识别");
							}
							
							
						}
						else
						{
							System.out.println("密码不对");
						}

					break;
					}
					break;
				}
				rs.close();
				st.close();
				conn.close();
			} catch (ClassNotFoundException | SQLException e) {
				// TODO 自动生成的 catch 块
				e.printStackTrace();
			}
			
		}	
	}
			
}
		
		
		
public void cxyue()//查询
{
		
	if(true)
	{
		System.out.println("您选择的为查询功能");
		for(int i=1;i>0;i++)
		{
			Scanner sc1=new Scanner(System.in);
				
			System.out.println("请输入您要查询的卡号");
			String c2=sc1.nextLine();
			
			try 
			{
				Class.forName("oracle.jdbc.driver.OracleDriver") ;
				
				Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@127.0.0.1:1521:orcl",
						"test0816","123456") ;
				
				Statement st = conn.createStatement() ;
				
				ResultSet rs =st.executeQuery("select * from ATM where cairnumber = ‘" +c2 +"‘ ") ;
				
				if(rs.next())
				{
					
					String ss = rs.getString("password") ;
					for(int k = 0 ; k<3; k++ )
					{
						System.out.println("请输入您的密码:");
						Scanner mm = new Scanner(System.in) ;
						String mima = mm.nextLine();
						if(ss.equals(mima))
						{
							System.out.println("您的信息为:");
							System.out.println("姓名:"+rs.getString("name")+"\t身份证号:"+rs.getString("sfzheng")
							+"\t账号:"+rs.getString("cairnumber")+"\t余额"+rs.getString("cxyue"));
							break;
						}
						else
						{
							System.out.println("密码不对");
						}

					break;
					}
					break;
				}
				rs.close();
				st.close();
				conn.close();
			} catch (ClassNotFoundException | SQLException e) {
				// TODO 自动生成的 catch 块
				e.printStackTrace();
			}
			
		}	
	}
			
}


}

  

package com.bank.test;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.Statement;
import java.util.HashMap;
import java.util.Map;
import java.util.Scanner;

import com.bank.abc.Atm2;
import com.bank.abc.Bank;
import com.bank.abc.CxCard;
import com.bank.unionpay.Atm;
import com.bank.unionpay.Leixing;
import com.bank.unionpay.Zhujiemian;

public class A 
{

	public static void main(String[] args) throws Exception
	{
	
		

		
		for(int i=1;i>0;i++)
		{
			Zhujiemian zjm=new Zhujiemian();
			zjm.zhujiemian();
			

			
				Scanner sc=new Scanner(System.in);
				int in=sc.nextInt();
				if(in==0||in==1||in==2||in==3||in==4)
				{
		
					if(in==0)
						
					{//测试开户
						Atm2  a2=new Atm2();
						a2.kaihu();
						continue;
					}
					//查询
					if(in==1)
					{
						Atm2  a2=new Atm2();
						a2.cx.cxyue();
						continue;
					}
		
					if(in==2)
					{
						//存款
						Atm2  a2=new Atm2();
						a2.cx.cunkuan();
						continue;
					}
					if(in==3)
					{
						//取款
						Atm2  a2=new Atm2();
						a2.cx.qukuan();
						continue;
					}
					if(in==4)
					{
						//退出
						System.out.println("系统即将退出");
						
//						File fi=new File("d:/abc122");
//						if(!fi.exists())
//						{
//							fi.mkdirs();
//						}
//						ObjectOutputStream obj=new ObjectOutputStream(new FileOutputStream("d:/abc122/abc.obj"));
//						obj.writeObject(Bank.getBank().account);
//						System.out.println("数据保存完成");
//						obj.close();
//						
						break;
						
					}
				
				
				}
				else
				{
					System.out.println("该菜单不存在");
				}
		
			
			
		}
		
		
		
	}

	
	
	

}

  

 

 

技术分享

技术分享

技术分享

技术分享

技术分享

 

数据库存储ATM机,开户、查询等信息

标签:

人气教程排行