Student Model
Student Model
Student Application
Punith B
JDBC StudentDAO
CONSOLE LOGIC
Index.java
package in.pentagon.studentapp.model;
import java.util.Scanner;
PUNITH B 1|Page
JDBC StudentDAO
}while(choice!=4);
}
}
Login.java
package in.pentagon.studentapp.model;
import java.util.ArrayList;
import java.util.Scanner;
import in.pentagon.studentapp.dao.StudentDAO;
import in.pentagon.studentapp.dao.StudentDAOImpl;
import in.pentagon.studentapp.dto.Student;
PUNITH B 2|Page
JDBC StudentDAO
PUNITH B 3|Page
JDBC StudentDAO
System.out.println("Name:"+s2.getName());
System.out.println("Branch"+s2.getBranch());
System.out.println("==========================");
}
break;
case 5: System.out.println("Going back to main menu...");
break;
case 6:
ArrayList<Student> students=sdao.getStudent();
for(Student s1:students) {
System.out.println(s1);
}
break;
case 7: System.out.println("Enter the Student ID to be deleted:");
boolean res=sdao.deleteStudent(sc.nextInt());
if(res) {
System.out.println("Data deleted successfully");
}
else {
System.out.println("Failed to delete the data");
}
default: System.out.println("Invalid choice!");
break;
}
}while(choice!=5);
}
else {
PUNITH B 4|Page
JDBC StudentDAO
System.out.println("Failed to login!");
}
}
}
Signup.java
package in.pentagon.studentapp.model;
import java.util.Scanner;
import in.pentagon.studentapp.dao.StudentDAO;
import in.pentagon.studentapp.dao.StudentDAOImpl;
import in.pentagon.studentapp.dto.Student;
PUNITH B 5|Page
JDBC StudentDAO
s.setPhone(sc.nextLong());
System.out.println("Enter the Mail ID");
s.setMail(sc.next());
System.out.println("Enter the Branch");
s.setBranch(sc.next());
System.out.println("Enter the Location");
s.setLoc(sc.next());
System.out.println("Set a new Password");
String password=sc.next();
System.out.println("Confirm the password");
String confirmPassword=sc.next();
if(password.equals(confirmPassword)) {
s.setPassword(confirmPassword);
boolean res=sdao.insertStudent(s);
if(res) {
System.out.println("Data added successfully");
}
else {
System.out.println("Failed to add the data");
}
}
else {
System.out.println("Password mismatch!");
}
}
}
PUNITH B 6|Page
JDBC StudentDAO
Update.java
package in.pentagon.studentapp.model;
import java.util.Scanner;
import in.pentagon.studentapp.dao.StudentDAO;
import in.pentagon.studentapp.dao.StudentDAOImpl;
import in.pentagon.studentapp.dto.Student;
PUNITH B 7|Page
JDBC StudentDAO
break;
PUNITH B 8|Page
JDBC StudentDAO
else {
System.out.println("Failed to update");
}
}while(choice!=6);
}
}
Password.java
package in.pentagon.studentapp.model;
import java.util.Scanner;
import in.pentagon.studentapp.dao.StudentDAO;
import in.pentagon.studentapp.dao.StudentDAOImpl;
import in.pentagon.studentapp.dto.Student;
PUNITH B 9|Page
JDBC StudentDAO
String password=sc.next();
System.out.println("Confirm the new password");
String confirm=sc.next();
if(password.equals(confirm)) {
s.setPassword(password);
boolean res=sdao.updateStudent(s);
if(res) {
System.out.println("Password updated!");
}
else {
System.out.println("Failed to update the password!");
}
}
else {
System.out.println("Password mismatch");
}
}else {
System.out.println("Student not found!");
}
}
}
PUNITH B 10 | P a g e
JDBC StudentDAO
DAO LOGIC
StudentDAO.java
package in.pentagon.studentapp.dao;
import java.util.ArrayList;
import in.pentagon.studentapp.dto.Student;
StudentDAOImpl.java
package in.pentagon.studentapp.dao;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
PUNITH B 11 | P a g e
JDBC StudentDAO
import java.util.ArrayList;
import in.pentagon.studentapp.connection.Connector;
import in.pentagon.studentapp.dto.Student;
public StudentDAOImpl() {
this.con=Connector.requestConnection();
}
@Override
public boolean insertStudent(Student s) {
PreparedStatement ps=null;
String query="INSERT INTO STUDENT VALUES(0,?,?,?,?,?,?,SYSDATE())";
int i=0;
try {
ps=con.prepareStatement(query);
ps.setString(1, s.getName());
ps.setLong(2, s.getPhone());
ps.setString(3,s.getMail());
ps.setString(4, s.getBranch());
ps.setString(5, s.getLoc());
ps.setString(6, s.getPassword());
i=ps.executeUpdate();
} catch (SQLException e) {
PUNITH B 12 | P a g e
JDBC StudentDAO
@Override
public boolean updateStudent(Student s) {
PreparedStatement ps=null;
String query="UPDATE STUDENT SET NAME=?,PHONE=?,MAIL=?,BRANCH=?,LOCATION=?,PASSWORD=?
WHERE ID=?";
int i=0;
try {
ps=con.prepareStatement(query);
ps.setString(1,s.getName());
ps.setLong(2, s.getPhone());
ps.setString(3,s.getMail());
ps.setString(4,s.getBranch());
ps.setString(5, s.getLoc());
ps.setString(6, s.getPassword());
ps.setInt(7, s.getId());
i=ps.executeUpdate();
} catch (SQLException e) {
PUNITH B 13 | P a g e
JDBC StudentDAO
@Override
public boolean deleteStudent(int id) {
// TODO Auto-generated method stub
return false;
}
@Override
public Student getStudent(String mail, String password) {
PreparedStatement ps=null;
String query="SELECT * FROM STUDENT WHERE MAIL=? AND PASSWORD=?";
Student s=null;
try {
ps=con.prepareStatement(query);
ps.setString(1, mail);
ps.setString(2, password);
ResultSet rs=ps.executeQuery();
PUNITH B 14 | P a g e
JDBC StudentDAO
while(rs.next()) {
s=new Student();
// int id=rs.getInt("id");
// s.setId(id);
s.setId(rs.getInt("id"));
s.setName(rs.getString("name"));
s.setPhone(rs.getLong("phone"));
s.setMail(rs.getString("mail"));
s.setBranch(rs.getString("branch"));
s.setLoc(rs.getString("location"));
s.setPassword(rs.getString("password"));
s.setDate(rs.getString("date"));
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return s;
}
@Override
public Student getStudent(long phone, String mail) {
PreparedStatement ps=null;
String query="SELECT * FROM STUDENT WHERE PHONE=? AND MAIL=?";
Student s=null;
try {
ps=con.prepareStatement(query);
PUNITH B 15 | P a g e
JDBC StudentDAO
ps.setLong(1, phone);
ps.setString(2, mail);
ResultSet rs=ps.executeQuery();
while(rs.next()) {
s=new Student();
s.setId(rs.getInt("id"));
s.setName(rs.getString("name"));
s.setPhone(rs.getLong("phone"));
s.setMail(rs.getString("mail"));
s.setBranch(rs.getString("branch"));
s.setLoc(rs.getString("location"));
s.setPassword(rs.getString("password"));
s.setDate(rs.getString("date"));
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return s;
}
@Override
public ArrayList<Student> getStudent() {
PreparedStatement ps=null;
ArrayList<Student> studentsList=new ArrayList<Student>();
Student s=null;
String query="SELECT * FROM STUDENT WHERE ID!=1";
try {
PUNITH B 16 | P a g e
JDBC StudentDAO
ps=con.prepareStatement(query);
ResultSet rs=ps.executeQuery();
while(rs.next()) {
s=new Student();
s.setId(rs.getInt("id"));
s.setName(rs.getString("name"));
s.setPhone(rs.getLong("phone"));
s.setMail(rs.getString("mail"));
s.setBranch(rs.getString("branch"));
s.setLoc(rs.getString("location"));
s.setPassword(rs.getString("password"));
s.setDate(rs.getString("date"));
studentsList.add(s);
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return studentsList;
}
@Override
public ArrayList<Student> getStudent(String name) {
ArrayList<Student> students=new ArrayList<>();
Student s=null;
PreparedStatement ps=null;
String query="SELECT * FROM STUDENT WHERE NAME=?";
PUNITH B 17 | P a g e
JDBC StudentDAO
try {
ps=con.prepareStatement(query);
ps.setString(1,name);
ResultSet rs=ps.executeQuery();
while(rs.next()) {
s=new Student();
s.setId(rs.getInt("id"));
s.setName(rs.getString("name"));
s.setPhone(rs.getLong("phone"));
s.setMail(rs.getString("mail"));
s.setBranch(rs.getString("branch"));
s.setLoc(rs.getString("location"));
s.setPassword(rs.getString("password"));
s.setDate(rs.getString("date"));
students.add(s);
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return students;
}
PUNITH B 18 | P a g e
JDBC StudentDAO
CONNECTION LOGIC
Connector.java
package in.ps.studentapp.connection;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
PUNITH B 19 | P a g e
JDBC StudentDAO
}
DTO LOGIC
Student.java
package in.ps.studentapp.dto;
//pojo class
public class Student {
//instance variables
private int id;
private String name;
private long phone;
private String mail;
private String branch;
private String loc;
private String password;
private String date;
PUNITH B 20 | P a g e
JDBC StudentDAO
}
public void setName(String name) {
this.name = name;
}
public long getPhone() {
return phone;
}
public void setPhone(long phone) {
this.phone = phone;
}
public String getMail() {
return mail;
}
public void setMail(String mail) {
this.mail = mail;
}
public String getBranch() {
return branch;
}
public void setBranch(String branch) {
this.branch = branch;
}
public String getLoc() {
return loc;
}
public void setLoc(String loc) {
this.loc = loc;
}
PUNITH B 21 | P a g e
JDBC StudentDAO
PUNITH B 22 | P a g e