ATM java

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ATM java相关的知识,希望对你有一定的参考价值。

【类编号】:001
【所属包名】:atm1
【类名】:ATMTest
【类概述】:该类包含Main()方法,用来实现应用程序入口。
1. 提示用户输入欢迎信息,使用String类型变量w存放欢迎信息。
2. 提示用户输入帐户名,密码,帐号,余额,分别存放在三个String类型变量(变量1,变量2,变量3)和float类型变量(变量4))中,用于创建一个BankAccount类型的对象anAccount。
【BankAccount anAccount=new BankAccount(变量1,变量2,变量3,变量4)】
3. 创建一个ATM类的对象。
ATM atm=new ATM(w,anAccount);
【构造方法】:默认
【类的数据成员】:无
【类的方法成员】:Main()方法

帮帮忙啊
谢谢下面那位朋友 但是 我想用 我描述的 方法来做 希望能帮帮我

参考技术A import java.util.Scanner;
public class Atm
public static void main(String [] args)
Scanner input=new Scanner(System.in);
int a,b=0,c=0,d,e,f,g,h,i,j,k,l,m=10000,n=10000;
for(i=0;i<3;i++)
System.out.print("请输入帐户"+" ");
a=input.nextInt();
System.out.print("请输入密码"+" ");
d=input.nextInt();
if(a==123456&&d==654321)System.out.println("输入成功");
break;
elseSystem.out.println("输入密码或帐户错误");
if(i==2)System.out.println("三次错误吞卡!!报警。你别跑");

while(i<3)
System.out.print("请输入你的操作:1:查询 2:取钱"+" ");
a=input.nextInt();
if(a==1)System.out.print("请输入你的帐户类型:1:美圆 2:人民币"+" ");
a=input.nextInt();
if(a==1)System.out.println("你还有"+(m=m-b)+"美圆");
System.out.print("请输入你的操作:1:继续2:离开"+" ");
a=input.nextInt();
if(a==1)continue;
elsebreak;

elseSystem.out.println("你还有"+(n=n-c)+"人民币");
System.out.print("请输入你的操作:1:继续2:离开"+" ");
a=input.nextInt();
if(a==1)continue;
elsebreak;



elseSystem.out.print("请输入你取钱的帐户类型:1:美圆 2:人民币"+" ");
a=input.nextInt();
if(a==1)while(true)System.out.print("请输入你取钱的金额(美圆):"+" ");
b=input.nextInt();
if(b<=m)System.out.println("取钱成功!请妥善保管好你的钱");break;
elseSystem.out.println("您的账户余额不足。请重新输入"+" ");continue;
System.out.print("请输入你的操作:1:继续2:离开"+" ");
a=input.nextInt();
if(a==1)continue;
elsebreak;


elsewhile(true)System.out.print("请输入你取钱的金额(人民币):"+" ");
c=input.nextInt();
if(c<=n)System.out.println("取钱成功!请妥善保管好你的钱");break;
elseSystem.out.println("您的账户余额不足。请重新输入"+" ");continue;
System.out.print("请输入你的操作:1:继续2:离开"+" ");
a=input.nextInt();
if(a==1)continue;
elsebreak;








你看看 我不明白你说的条件是什么意识本回答被提问者采纳

java连接MySQL。ATM

package bank;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import java.util.Scanner;

public class JDBC {
	static Statement sc=null;
	static Scanner sca=new Scanner(System.in);
	static String username;
	public static void main(String[] args) throws Exception {
		//该方法是 得到数据库的操作平台的。
		getStatement();
		System.out.println("well come to bank of china");
		System.out.println("请选择你需要的内容:"+"1.注册"+"2.登陆");
		int m=sca.nextInt();
		for(int j=m;;){
			if(j==1){
				System.out.println("请输入新的账号");
				String bname=sca.next();
				System.out.println("请输入新的密码");
				String bpassword=sca.next();
				String sql="select * from bank where bname=‘"+bname+"‘";
				ResultSet bq=sc.executeQuery(sql);//查询数据库
				if(bq.next()){//判断数据库中是否也存在注册的帐号
					System.out.println("该帐号已被注册");
				}else{
					sql="insert into bank (bname,bpassword) values(‘"+bname+"‘,‘"+bpassword+"‘)";
					int i=sc.executeUpdate(sql);//更新数据库,用i来接收返回的数据
					if(i!=0){
					System.out.println("注册成功");
					}else{
					System.out.println("注册失败");
					}
				}
			}
			else if(j==2){
				for(int w=1;w<=3;w++){
				System.out.println("请登录:");
				System.out.println("用户名:");
				username=sca.next();
				System.out.println("密码:");
				String password=sca.next();
				//调用查询账户方法,需要传入   用户名 和密码  返回int类型的值
				int num=queryAccount(username,password);
				//num==1 表示 数据库中有对应的用户名和密码
					if(num==1){
						System.out.println("登录成功");
						//使用for死循环  进行操作
						for(;;){
							System.out.println("请选择交易类型:");
							System.out.println("1.存钱   2.取钱   3.查询余额   4.转账    5.退卡");
							int zx=sca.nextInt();//输入操作类型
							if(zx==1){
								cun(); //调用存钱方法
							}else if(zx==2){
								qu();//调用取钱方法
							}else if(zx==3){
								query();//调用查询余额方法
							}else if(zx==4){
								zhuan();//调用转账方法
							}else if(zx==5){
								System.out.println("已退出。谢谢使用!请收好您的卡片!");
								System.exit(0);
							}else{
								System.out.println("输入错误,已退出。谢谢使用!");
								break;
							}
						}
					}else{
						System.out.println("登录失败!您还有"+(3-w)+"次机会");
					}
				}
				 System.exit(0);
				}
				else{
					System.out.println("输入错误,已退出。谢谢使用!请收好您的卡片!");
					break;
				}
			}
		}
	/**
	 * 取钱方法
	 * @throws Exception
	 */
	public static void qu() throws Exception{
		System.out.println("请输入你的取款金额:");
		int bmoney=sca.nextInt();
		if(bmoney%100==0){
		String sql="update bank set bmoney=bmoney-"+bmoney;
		System.out.println(sql);
		boolean a =sc.execute(sql);
		if(!a){
			System.out.println("取款成功!");
			}
		}else{
			System.out.println("本机只提供面值为100元人民币存取!");
		}
	}
	/**
	 * 存钱方法
	 */
	public static void cun() throws Exception{
		
		System.out.println("请输入你的存款金额:");
		double bmoney=sca.nextDouble();//输入存款金额
		//拼接  修改sql  
		String sql="update bank set bmoney=bmoney+"+bmoney;
		//在 操作平台中  执行  sql语句
		boolean a=sc.execute(sql);
		//判断是否成功
		if(bmoney%100==0){
		if(!a){
			System.out.println("存款成功!");
			}
		}else{
			System.out.println("本机只提供面值为100元人民币存取!");
		}
	}
	public static int queryAccount(String bname,String bpassword) throws Exception{
		//拼接查询sql   注意:  在拼接的时候,,字符串需要在前后加‘(单引号)
		String sql="select * from bank where bname=‘"+bname+"‘ and bpassword=‘"+bpassword+"‘";
		//在平台中执行查询sql ,并把查询的内容放在  ResultSet rs 里面
		ResultSet rs=sc.executeQuery(sql);
		//声明一个int 类型的变量  初始值 0
		int num=0;
		//如果查询的结果里面有值得话,就进入循环里面
		while(rs.next()){  //rs.next()  是判断当前位置是否有数据,有就进入 没有就跳过
			num++;
		}
		return num;
	}
	/*
	 * 查询方法
	 */
	public static void query() throws Exception{
		//拼接查询sql   注意:  在拼接的时候,,字符串需要在前后加‘(单引号)
		String sql="select bmoney from bank where bname=‘"+username+"‘";
		//在平台中执行查询sql ,并把查询的内容放在  ResultSet rs 里面
		ResultSet rs=sc.executeQuery(sql);
		//声明一个double类型的变量  赋值 0
		double bmoney=0;
		//rs.next()  是判断当前位置是否有数据,有就进入 没有就跳过
		while(rs.next()){
			//把查询出来的数据赋值给money 变量
			bmoney=rs.getDouble(1);
		}
		System.out.println("你的账户余额:"+bmoney);
	}
	public static void zhuan() throws Exception{
		System.out.println("请输入您要转入的账户:");
		String zname=sca.next();
		System.out.println("请确认您要转入的账户:");
		String zrname=sca.next();
		if(zname.equals(zrname)){
		String sql="select * from bank where bname=‘"+zname+"‘";
		ResultSet bq=sc.executeQuery(sql);//查询数据库
		if(bq.next()){
			System.out.println("该账户存在,请输入转入金额:");
			int zrmoney=sca.nextInt();//输入转入金额
			//拼接  修改sql  
		    String  sql1="update bank set bmoney=bmoney+"+zrmoney+" WHERE bname=‘"+zname+"‘;";
		    int m=sc.executeUpdate(sql1);  
			String sql2="update bank set bmoney=bmoney-"+zrmoney+" WHERE bname=‘"+username+"‘;";
			int n=sc.executeUpdate(sql2);//更新数据库,用i来接收返回的数据
		System.out.println("成功");
			}else{
				System.out.println("账户不存在");
			}
			}else{
				System.out.println("俩次输入不一致");
			}
		}
	/**
	 * 得到数据库操作平台方法
	 * @throws Exception
	 */
	public static void getStatement() throws Exception{
		//1\加载驱动
		Class.forName("com.mysql.jdbc.Driver");
		/**
		 * 数据库连接URL
		 * jdbc:mysql://IP:port/数据库名
		 * jdbc:mysql://localhost:3306/score
		 */
		String url="jdbc:mysql://localhost:3306/atm";
		//数据库用户名
		String bname="root";
		//数据库密码
		String bword="556687a";
		//使用驱动得到数据库连接,需要传入  url username password
		Connection c=DriverManager.getConnection(url, bname, bword);
		//得到数据库操作平台,平台
		sc=c.createStatement();				
	}
}


本文出自 “12160034” 博客,请务必保留此出处http://12170034.blog.51cto.com/12160034/1865207

以上是关于ATM java的主要内容,如果未能解决你的问题,请参考以下文章

javajava枚举模板

javajava方法

javaJava之Random

Javajava.sql.SQLRecoverableException 解释

javajava 读写文件

javajava中日期时间转化