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

java模擬ATM功能(控制臺連接Mysql數(shù)據(jù)庫)

 更新時間:2022年05月27日 10:41:06   作者:TK13的舔狗  
這篇文章主要介紹了java模擬ATM功能,控制臺連接Mysql數(shù)據(jù)庫,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了java模擬ATM功能的具體代碼,供大家參考,具體內(nèi)容如下

有三個類:Test.java、Customer.java、CustomerDAO.java、ATMSystem.java

ATMSystem.java實現(xiàn)模擬ATM的功能

Customer.java創(chuàng)建一個用戶對象

CustomerDAO.java實現(xiàn)連接數(shù)據(jù)庫

Test為主程序 

ATMSystem.java:

package ATM;
 
import java.util.Scanner;
 
public class ATMSystem 
{
 CustomerDAO dao=new CustomerDAO();
 Scanner input=new Scanner(System.in);
 private int id;
 public ATMSystem()
 {
 
 }
 public void Regist()
 {
 System.out.println("注冊卡號:");
 int myid=input.nextInt();
 System.out.println("注冊用戶名:");
 String myname=input.next();
 System.out.println("注冊密碼:");
 String mypwd=input.next();
 System.out.println("輸入存入金額:");
 int mymoney=input.nextInt();
 dao.Regist(myid, mypwd, myname, mymoney);
 }
 public boolean login()
 {
 System.out.println("請輸入密碼:");
 String mypwd=input.next();
 id=dao.login(mypwd);
 if(id==-1)
 {
  System.out.println("登錄失??!");
  return false;
 }
 else
 {
  System.out.println("登陸成功!");
  return true;
 }
 }
 public void query(int id)
 {
 Customer cust=dao.query(id);
 System.out.println("********************");
 System.out.println("卡號:"+cust.getid());
 System.out.println("余額:"+cust.getmoney());
 System.out.println("用戶名:"+cust.getname());
 System.out.println("********************");
 }
 public void save()
 {
 System.out.println("輸入存款金額:");
 int money=input.nextInt();
 dao.update_save(id, money);
 }
 public void get()
 {
 System.out.println("********************");
 System.out.println("輸入取款金額:");
 int money=input.nextInt();
 dao.update_get(id, money);
 System.out.println("********************");
 }
 public void change()
 {
 System.out.println("請輸入轉(zhuǎn)賬卡號:");
 int inid=input.nextInt();
 System.out.println("請輸入轉(zhuǎn)賬金額:");
 int money=input.nextInt();
 dao.change(id, inid, money);
 }
 public void begin()
 {
 int num=-1;
 int Num=0;
 System.out.println("請選擇功能:");
 System.out.println("1.注冊      2.登錄");
 Num=input.nextInt();
 switch(Num)
 {
 case 1:
  Regist();
  break;
 case 2:
  if(login())
  {
  while(num!=0)
  {
   System.out.println("********************");
   System.out.println("歡迎歡迎,熱烈歡迎");
   System.out.println("請選擇功能:");
   System.out.println("1.存款     2.取款   3.查詢   4.轉(zhuǎn)賬  0.退出");
   System.out.println("********************");
   num=input.nextInt();
   switch(num)
   {
   case 1:
   save();
   break;
   case 2:
   get();
   break;
   case 3:
   query(id);
   break;
   case 4:
   change();
   break;
   case 0:
   System.out.println("謝謝使用!");
   break;
   }
  }
  }
  else
  {
  System.out.println("登錄失敗,賬號、密碼錯誤!");
  }
 break;
 default:
  break;
 }
 }
}

Customer.java

package ATM;
 
public class Customer 
{
 private int id;
 private String pwd;
 private int money;
 private String name;
 public int getid()
 {
 return id;
 }
 public void setid(int newid)
 {
 id=newid;
 }
 public String getpwd()
 {
 return pwd;
 }
 public void setpwd(String newpwd)
 {
 pwd=newpwd;
 }
 public String getname()
 {
 return name;
 }
 public void setname(String newname)
 {
 name=newname;
 }
 public int getmoney()
 {
 return money;
 }
 public void setmoney(int newmoney)
 {
 money=newmoney;
 }
}

CustomerDAO.java:

package ATM;
 
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
 
 
public class CustomerDAO
{
 private Connection conn=null;
 private java.sql.PreparedStatement p=null;
 public CustomerDAO()
 {
 try {
  Class.forName("org.gjt.mm.mysql.Driver");
 } catch (ClassNotFoundException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
 }
 try {
  conn=DriverManager.getConnection("jdbc:mysql://localhost:3306/mysql", "root", "");
 } catch (SQLException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
 }
 }
 public int login(String mypwd)
 {
 String sql="select * from mysql where pwd = ?";
 try 
 {
  p=conn.prepareStatement(sql);
  p.setString(1, mypwd);
  ResultSet rs=p.executeQuery();
  if(rs.next())
  {
  return rs.getInt("id");
  }
  rs.close();
  p.close();
  conn.close();
 } 
 catch (SQLException e) 
 {
  e.printStackTrace();
 }
 return -1;
 }
 public Customer query(int id)
 {
 Customer cust=new Customer();
 try
 {
  String sql="select * from mysql where id = ?";
  p=conn.prepareStatement(sql);
  p.setInt(1, id);
  ResultSet rs=p.executeQuery();
  if(rs.next())
  {
  cust.setid(rs.getInt("id"));
  cust.setmoney(rs.getInt("money"));
  cust.setname(rs.getString("name"));
  cust.setpwd(rs.getString("pwd"));
  }
 }
 catch (Exception e) {
  // TODO: handle exception
 }
 return cust;
 
 }
 public void update_get(int id,int money) 
 {
 String sql="select * from mysql where id = ?";
 try 
 {
  p=conn.prepareStatement(sql);
  p.setInt(1, id);
  ResultSet rs=p.executeQuery();
  if(rs.next())
  {
  if(rs.getInt("money")<money)
  {
   System.out.println("余額不足!");
  }
  else
  {
   sql="update mysql set money = money - ? where id = ?";
   p=conn.prepareStatement(sql);
   p.setInt(1, money);
   p.setInt(2, id);
   p.executeUpdate();
   System.out.println("取款成功!");
  }
  }
 }
 catch (Exception e)
 {
  // TODO: handle exception
 }
 }
 public void update_save(int id,int money)
 {
 String sql="update mysql set money = money + ? where id = ?";
 try 
 {
  p=conn.prepareStatement(sql);
  p.setInt(1, money);
  p.setInt(2, id);
  p.executeUpdate();
  System.out.println("存款成功!");
 }
 catch (Exception e) 
 {
  // TODO: handle exception
 }
 }
 public void change(int myid,int inid,int money)
 {
 try
 { String sql="select * from mysql where id = ?";
  p=conn.prepareStatement(sql);
  p.setInt(1, inid);
  ResultSet rs=p.executeQuery();
  if(rs.next())
  {
  sql="select * from mysql where id = ?";
  p=conn.prepareStatement(sql);
  p.setInt(1, myid);
  rs=p.executeQuery();
  if(rs.next())
  {
   if(rs.getInt("money")<money)
   {
   System.out.println("余額不足!");
   return;
   }
   else
   {
   sql="update mysql set money = money - ? where id = ?";
   p=conn.prepareStatement(sql);
   p.setInt(1, money);
   p.setInt(2, myid);
   p.executeUpdate();
   sql="update mysql set money = money + ? where id = ?";
   p=conn.prepareStatement(sql);
   p.setInt(1, money);
   p.setInt(2, inid);
   p.executeUpdate();
   }
  }
  }
  else
  {
  System.out.println("卡號錯誤!");
  }
 }
 catch (Exception e) {
  // TODO: handle exception
 }
 }
 public void Regist(int myid,String mypwd,String myname,int mymoney)
 {
 String sql;
 try
 {
  sql="select * from mysql where id = ?";
  p=conn.prepareStatement(sql);
  p.setInt(1, myid);
  ResultSet rs=p.executeQuery();
  if(rs.next())
  {
  System.out.println("此卡已注冊,請勿重復(fù)注冊?。。?!");
  return;
  }
 }
 catch (Exception e)
 {
  // TODO: handle exception
 }
 
 try 
 {
  sql="insert into mysql(id,pwd,money,name) values(?,?,?,?)";
  p=conn.prepareStatement(sql);
  p.setInt(1, myid);
  p.setString(2, mypwd);
  p.setInt(3, mymoney);
  p.setString(4, myname);
  p.executeUpdate();
  System.out.println("注冊成功!");
 }
 catch (Exception e) 
 {
  // TODO: handle exception
 }
 }
}

Test.java:

package ATM;
 
public class Test 
{
 public static void main(String[] args) 
 {
 // TODO Auto-generated method stub
 ATMSystem ATM=new ATMSystem();
 while(true)
 {
  ATM.begin();
 }
 }
 
}

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java 單例模式的實現(xiàn)資料整理

    Java 單例模式的實現(xiàn)資料整理

    這篇文章主要介紹了Java 單例模式的實現(xiàn)的相關(guān)資料,并附簡單實例代碼,需要的朋友可以參考下
    2016-10-10
  • 快速解決commons-fileupload組件無法處理自定義head信息的bug

    快速解決commons-fileupload組件無法處理自定義head信息的bug

    問題在于fileupload組件解析完自定義的head節(jié)點后,卻忘記傳遞到FileItemStreamImpl中了,稍作修訂,即可修正該bug
    2013-08-08
  • 詳解SpringBoot開發(fā)使用@ImportResource注解影響攔截器

    詳解SpringBoot開發(fā)使用@ImportResource注解影響攔截器

    這篇文章主要介紹了詳解SpringBoot開發(fā)使用@ImportResource注解影響攔截器,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-11-11
  • 淺析Java和Scala中的Future

    淺析Java和Scala中的Future

    這篇文章主要介紹了Java和Scala中的Future的相關(guān)資料,需要的朋友可以參考下
    2017-10-10
  • Java 正確終止線程的方法

    Java 正確終止線程的方法

    這篇文章主要介紹了Java 正確終止線程的方法,幫助大家更好的理解和學(xué)習(xí)java 多線程的相關(guān)知識,感興趣的朋友可以了解下
    2020-12-12
  • JavaWeb使用Session和Cookie實現(xiàn)登錄認證

    JavaWeb使用Session和Cookie實現(xiàn)登錄認證

    本篇文章主要介紹了JavaWeb使用Session和Cookie實現(xiàn)登錄認證,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2017-03-03
  • Mybatis枚舉類型轉(zhuǎn)換源碼分析

    Mybatis枚舉類型轉(zhuǎn)換源碼分析

    在Mybatis的TypeHandlerRegistry中,添加了常用的類轉(zhuǎn)換器,其中默認的枚舉類型轉(zhuǎn)換器是EnumTypeHandler,這篇文章主要介紹了Mybatis枚舉類型轉(zhuǎn)換源碼分析,需要的朋友可以參考下
    2024-05-05
  • 親測解決,nacos下線失敗問題

    親測解決,nacos下線失敗問題

    這篇文章主要介紹了親測解決,nacos下線失敗問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • System.currentTimeMillis()計算方式與時間的單位轉(zhuǎn)換詳解

    System.currentTimeMillis()計算方式與時間的單位轉(zhuǎn)換詳解

    這篇文章主要介紹了System.currentTimeMillis()計算方式與時間的單位轉(zhuǎn)換詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-05-05
  • Java如何正確處理下載文件時HTTP頭的編碼問題

    Java如何正確處理下載文件時HTTP頭的編碼問題

    這篇文章主要介紹了Java如何正確處理下載文件時HTTP頭的編碼問題,
    通常HTTP消息包括客戶機向服務(wù)器的請求消息和服務(wù)器向客戶機的響應(yīng)消息,今天來講解下正確處理下載文件時HTTP頭的編碼問題,需要的朋友可以參考下
    2023-07-07

最新評論