java连接MySQL。ATM
admin
2023-06-04 19:41:07
0
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();				
	}
}


相关内容

热门资讯

伊朗军队:已做好准备,坚决回击... 当地时间23日,伊朗军队发表声明,强调将随时准备对敌人的任何侵犯做出坚决且全方位的回击。(总台记者 ...
燃油车,真的没人买了? “如今加满一箱油,费用较年初高出近百元。”燃油车主张先生坦言,用车成本大幅上涨,让新能源车型的性价比...
出境打工月入3万?警惕境外高薪... 不要求学历和工作经验,到了国外就能找到工作,“月薪三万”“零门槛”“包吃住”,看到这样的广告,相信很...
格力空调外机嗡嗡响一下风机就不... 原因可能是制冷系统管路内发生制冷剂的缓慢渗漏,导致压缩机的工作效率骤减,内机末端装置风机盘管温度降低...
抽油烟机响了一下就不工作了 1、也许是因为插座的地方没有电了,或者油烟机的线路断掉了,出现了短路,所以油烟机不能正常的进行工作。...
冰箱搬运了一下就不制冷了 1、主要是因为搬运过程中电源线出现了拉扯导致电源线内部的线发生了断裂,所以再次使用的时候不再启动制冷...
冰箱调了温度之后就不启动了 原因可能是没有达到启动温度,可以尝试将档位调到最大看是否能正常启动;原因可能是外界气温较低时,室温与...
飞利浦电视开机闪一下就黑屏怎么... 1、检查插座的电压,确定是由于电源不稳定导致的,则需要在家里准备一个稳压器,保证供给电视的电压是稳定...
缅北“四大家族”多人被执行死刑... 2026年5月19日至22日,福建省泉州市中级人民法院一审公开开庭审理了被告人魏怀仁、廖景芳、康敏诈...
法国禁止以色列国家安全部长入境 新华社巴黎5月23日电 法国外交部长巴罗23日在社交媒体发文说,自即日起,以色列国家安全部长本-格维...