Skip to content

burma-project-ideas/banking-management-system

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

16 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Banking Management System

ဤ Project သည် Real World Project နှင့် သဘောတရား တူသယောင် ဖြစ်ပြီး အခုမှ Project သေးသေးလေးတွေ စရေးမယ့်သူတွေ လွယ်ကူဖို့အတွက် ဖန်တီးပေးထားသော အသေးစား Project တစ်ခုဖြစ်ပါတယ်။

Banking Management System Database Diagram

Summary

ငွေသွင်း ငွေလွှဲ ပြုလုပ်သည့်အခါ ဘဏ် staff ကနေ အသုံးပြုရတဲ့ စနစ်ဖြစ်တယ်။ ကိုယ်‌‌ ငွေလွှဲချင်တဲ့ account နံပါတ်ကို ဘဏ် staff အားပြောပြပြီးတော့မှ ဘဏ် staff ကနေ တစ်ဆင့် ငွေသွင်း ငွေလွှဲ‌ ပြုလုပ်ပေးနိုင်တဲ့ Service မျိုး ဖြစ်ပါတယ်။

  • ဆောက်ရမယ့် Table ‌က 4 ခု ရှိပါတယ်
    • State
    • Township
    • Account
    • Transaction History

ပါ၀င်မည့် Menu များကတော့


State and Township List

State And Township Data တွေကို ဤ Link ကနေ ထုတ်ယူထားတယ်။ Account ဖွင့်ရာတွင်အသုံးပြုတယ်။ ဘယ်နေရာ ဒေသမှာ ဖွင့်ထားသလဲဆိုတာ သိဖို့အတွက် ဖြစ်တယ်။

  • State

    • [StateId] [int] IDENTITY(1,1) NOT NULL
    • [StateCode] nvarchar NOT NULL
    • [StateName] nvarchar NOT NULL
  • Township

    • [TownshipId] [int] IDENTITY(1,1) NOT NULL
    • [TownshipCode] nvarchar NOT NULL
    • [TownshipName] nvarchar NOT NULL
    • [StateCode] nvarchar NOT NULL

Create Account

ဘဏ်တွင် ငွေသွင်း ငွေလွှဲ service များကိုအသုံးပြုလိုပါက ဘဏ်တွင် account ဖွင့်ရပါမည်။

  • Account
    • [AccountId] [int] IDENTITY(1,1) NOT NULL
    • [AccountNo] AS (right('000000'+ CONVERT(varchar,[AccountId]),(6)))
    • [CustomerCode] AS ('C' + right('000000'+ CONVERT(varchar,[AccountId]),(6)))
    • [CustomerName] nvarchar NOT NULL
    • [Balance] [decimal](20, 2) NOT NULL
    • [StateCode] nvarchar NOT NULL
    • [TownshipCode] nvarchar NOT NULL

Account List

ဘဏ်တွင် customer များဖွင့်ခဲ့သော account များကိုကြည့်ရှုလို့ရမယ်။


Transfer

Customer ငွေလွှဲချင်သည့် အကောင့်ထဲသို့ ဘဏ် Staff မှ တစ်ဆင့် လွှဲပြောင်းပေးနိုင်ပါသည်။

ငွေလွှဲတဲ့အခါ Account Table ထဲက မိမိ Account ရဲ့ Balance ကို အရင်လောက်မလောက် စစ်မယ်။ Account Table ထဲမှာရှိတဲ့ ကိုယ့်ရဲ့ Balance ကို အရင် နုတ်ပေးရမယ်။ လက်ရှိ 1000, လွှဲတာ 200 ဆို 800 ပဲဖြစ်ရပါမယ်။ Balance Update လုပ်ပေးရပါမယ်။ ပြီးရင် လွှဲပေးလိုက်တဲ့ Account ကျတော့ Amount ကို ပေါင်းပေးရမယ်။ လက်ရှိ 200, လွှဲလိုက်တာ 200 ဆို စုစုပေါင်း သူ့လက်ကျန်က 400 ဖြစ်ရပါမယ်။ လွှဲမယ့်သူဆီက နုတ်ပြီး လက်ခံရမယ့်သူဆီ ပေါင်းပေးရမယ်ဆိုတဲ့ သဘောပါ။

  • Transaction History
    • [TransactionHistoryId] [int] IDENTITY(1,1) NOT NULL
    • [FromAccountNo] nvarchar NOT NULL
    • [ToAccountNo] nvarchar NOT NULL
    • [TransactionDate] [datetime] NOT NULL
    • [Amount] [decimal](20, 2) NOT NULL

Deposit

Customer Account ထဲသို့ ငွေ Amount တွေကိုထည့်သွင်းလို့ရနိုင်ပါသည်။

Form မှာ Account ကို Popup နဲ့ ရှာလို့ရမယ် အဲ့ထဲက တစ်ခုကို ရွေးမယ် ထည့်ချင်တဲ့ Amount ကိုရိုက်ထည့်မယ် Add ကိုနှိပ်တဲ့အခါ Account Table မှ Balance ကို လက်ရှိ ရိုက်ထည့်ထားသော Amount နှင့် ပေါင်းပေးရပါမယ် အရင် 1000, လက်ရှိ ရိုက်ထားသော Amount 3000 ဆိုရင် စုစုပေါင်း Balance က 4000 ဖြစ်ရပါမယ်။


Withdraw

Customer Account ထဲမှ ငွေ Amount တွေကိုထုတ်ယူလို့ရပါမည်။

Logic

ဒါကတော့ သူက ငွေထုတ်တာမို့ Account Table ထဲက ငွေကို နုတ်ယူပေးရမယ်။ ငွေထုတ်မယူခင်တော့ Balance လောက်မလောက် အရင်စစ်ပေးရမယ်။ စစ်လို့အဆင်ပြေမှသာ ငွေထုတ်ခွင့်ပေးရပါမယ်။


Transaction History

Customer ငွေလွှဲသွားတဲ့ account တွေကို Date အလိုက်ကြည့်ရှုလို့ရတဲ့ Report ဖြစ်ပါတယ်။


-- State Table
CREATE TABLE Tbl_States (
    StateId INT IDENTITY(1,1) PRIMARY KEY,
    StateCode NVARCHAR(10) NOT NULL,
    StateName NVARCHAR(100) NOT NULL
);

-- Township Table
CREATE TABLE Tbl_Townships (
    TownshipId INT IDENTITY(1,1) PRIMARY KEY,
    TownshipCode NVARCHAR(10) NOT NULL,
    TownshipName NVARCHAR(100) NOT NULL,
    StateCode NVARCHAR(10) NOT NULL,
    FOREIGN KEY (StateCode) REFERENCES Tbl_States(StateCode) ON DELETE CASCADE
);

-- Account Table
CREATE TABLE Tbl_Accounts (
    AccountId INT IDENTITY(1,1) PRIMARY KEY,
    AccountNo AS (RIGHT('000000' + CONVERT(VARCHAR, AccountId), 6)) PERSISTED,
    CustomerCode AS ('C' + RIGHT('000000' + CONVERT(VARCHAR, AccountId), 6)) PERSISTED,
    CustomerName NVARCHAR(100) NOT NULL,
    Balance DECIMAL(20, 2) NOT NULL DEFAULT 0,
    StateCode NVARCHAR(10) NOT NULL,
    TownshipCode NVARCHAR(10) NOT NULL,
    FOREIGN KEY (StateCode) REFERENCES Tbl_States(StateCode),
    FOREIGN KEY (TownshipCode) REFERENCES Tbl_Townships(TownshipCode) ON DELETE CASCADE
);

-- Transaction History Table
CREATE TABLE Tbl_TransactionHistory (
    TransactionHistoryId INT IDENTITY(1,1) PRIMARY KEY,
    FromAccountNo NVARCHAR(10) NOT NULL,
    ToAccountNo NVARCHAR(10) NOT NULL,
    TransactionDate DATETIME NOT NULL DEFAULT GETDATE(),
    Amount DECIMAL(20, 2) NOT NULL,
    FOREIGN KEY (FromAccountNo) REFERENCES Tbl_Accounts(AccountNo),
    FOREIGN KEY (ToAccountNo) REFERENCES Tbl_Accounts(AccountNo)
);

-- Deposit Table (for deposit transactions)
CREATE TABLE Tbl_Deposits (
    DepositId INT IDENTITY(1,1) PRIMARY KEY,
    AccountNo NVARCHAR(10) NOT NULL,
    DepositAmount DECIMAL(20, 2) NOT NULL,
    DepositDate DATETIME NOT NULL DEFAULT GETDATE(),
    FOREIGN KEY (AccountNo) REFERENCES Tbl_Accounts(AccountNo)
);

-- Withdraw Table (for withdrawal transactions)
CREATE TABLE Tbl_Withdrawals (
    WithdrawalId INT IDENTITY(1,1) PRIMARY KEY,
    AccountNo NVARCHAR(10) NOT NULL,
    WithdrawalAmount DECIMAL(20, 2) NOT NULL,
    WithdrawalDate DATETIME NOT NULL DEFAULT GETDATE(),
    FOREIGN KEY (AccountNo) REFERENCES Tbl_Accounts(AccountNo)
);

Releases

No releases published

Packages

No packages published