package com.wdk.entity;
import javax.xml.crypto.Data;
public class Student {
private int StudentNo;
private String loginPwd;
private String studentName;
private int Sex;
private int GardeId;
private String Phone;
private String Address;
private Data broData;
private String Email;
private String IdentityCard;
private Grade grade;
public Grade getGrade() {
return grade;
}
public void setGrade(Grade grade) {
this.grade = grade;
}
public int getStudentNo() {
return StudentNo;
}
public void setStudentNo(int studentNo) {
StudentNo = studentNo;
}
public String getLoginPwd() {
return loginPwd;
}
public void setLoginPwd(String loginPwd) {
this.loginPwd = loginPwd;
}
public String getStudentName() {
return studentName;
}
public void setStudentName(String studentName) {
this.studentName = studentName;
}
public int getSex() {
return Sex;
}
public void setSex(int sex) {
Sex = sex;
}
public int getGardeId() {
return GardeId;
}
public void setGardeId(int gardeId) {
GardeId = gardeId;
}
public String getPhone() {
return Phone;
}
public void setPhone(String phone) {
Phone = phone;
}
public String getAddress() {
return Address;
}
public void setAddress(String address) {
Address = address;
}
public Data getBroData() {
return broData;
}
public void setBroData(Data broData) {
this.broData = broData;
}
public String getEmail() {
return Email;
}
public void setEmail(String email) {
Email = email;
}
public String getIdentityCard() {
return IdentityCard;
}
public void setIdentityCard(String identityCard) {
IdentityCard = identityCard;
}
public Student(int studentNo, String loginPwd, String studentName, int sex,
int gardeId, String phone, String address, Data broData, String email,
String identityCard, Grade grade) {
super();
StudentNo = studentNo;
this.loginPwd = loginPwd;
this.studentName = studentName;
Sex = sex;
GardeId = gardeId;
Phone = phone;
Address = address;
this.broData = broData;
Email = email;
IdentityCard = identityCard;
this.grade = grade;
}
public Student(){}
}
BaseD工具類:
package com.wdk.dao;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
public class BaseDao {
public static final String DRIVER="com.mysql.jdbc.Driver";
public static final String URL="jdbc:mysql:///myschool";
public static final String USERNAME="root";
public static final String PASSWORD="123";
//鏈接對象
Connection con=null;
//PreparedStatement對象
PreparedStatement ps=null;
//ResultSet對象
ResultSet rs=null;
//獲取鏈接對象
public Connection getConnection() throws Exception{
if(con==null){
Class.forName(DRIVER);
con=DriverManager.getConnection(URL,USERNAME,PASSWORD);
}
return con;
}
//關閉鏈接對象(和其餘資源對象)
public void closeConnection() throws Exception{
if(con!=null){
con.close();
}if(rs!=null){
rs.close();
}
if(ps!=null){
ps.close();}
}
//增刪改
public int executeUpdate(String sql,Object... objs) throws Exception{
getConnection();
ps=con.prepareStatement(sql);
for (int i = 0; i < objs.length; i++) {
ps.setObject(i+1, objs[i]);
}
int count=ps.executeUpdate();
return count;
}
//查
public ResultSet executeQuery(String sql,Object... objs) throws Exception{
getConnection();
ps=con.prepareStatement(sql);
for (int i = 0; i < objs.length; i++) {
ps.setObject(i+1, objs[i]);
}
rs=ps.executeQuery();
return rs;
}
}
IStudentDao 接口:
兩個方法:
//查詢全部學生記錄,包含年紀名稱
List<Student> student() throws Exception;
//查詢S1年紀下的學生錄
Grade student2(String gradeName) throws Exception;
IStudentDaoImpl實現類:
package com.wdk.dao.Impl;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.List;
import com.wdk.dao.BaseDao;
import com.wdk.dao.IStudentDao;
import com.wdk.entity.Grade;
import com.wdk.entity.Student;
public class IStudentDaoImpl extends BaseDao implements IStudentDao{
@Override
//查詢全部學生記錄,包含年紀名稱
public List<Student> student() throws Exception {
List<Student> students=null;
String sql="select s.*,g.gradeName from student as s,grade as g where s.gradeid=g.gradeid";
ResultSet rs = this.executeQuery(sql);
if(rs!=null){
students=new ArrayList<Student>();
while (rs.next()) {
Student student =new Student();
Grade grdae=new Grade();
student.setStudentNo(rs.getInt("StudentNo"));
student.setLoginPwd(rs.getString("LoginPwd"));
student.setStudentName(rs.getString("StudentName"));
student.setSex(rs.getInt("Sex"));
grdae.setGradeName(rs.getString("GradeName"));
student.setGrade(grdae);
students.add(student);
}
}
return students;
}
@Override
public Grade student2(String gradeName) throws Exception {
Grade grade=null;
Student student=null;
List<Student> students=new ArrayList<Student>();
String sql="select s.*,g.gradeName from student as s,grade as g where s.gradeid=g.gradeid and gradeName=?";
ResultSet rs = this.executeQuery(sql,gradeName);
if(rs!=null){
while (rs.next()) {
grade=new Grade();
grade.setGradeName(rs.getString("gradeName"));
student =new Student();
student.setStudentName(rs.getString("studentName"));
student.setGardeId(rs.getInt("gradeId"));
student.setStudentNo(rs.getInt("studentNo"));
students.add(student);
}
grade.setStudents(students);
}
return grade;
}
}
Txet測試類:
package com.wdk.ui;
import java.util.List;
import com.wdk.dao.IStudentDao;
import com.wdk.dao.Impl.IStudentDaoImpl;
import com.wdk.entity.Grade;
import com.wdk.entity.Student;
public class Test {
static IStudentDao Dao =new IStudentDaoImpl();
public static void main(String[] args) throws Exception {
List<Student> students=Dao.student();
for(Student student:students){
System.out.println(student.getStudentName()+"\t"+student.getGrade().getGradeName());
}
System.out.println("===========================================");
Grade grade =Dao.student2("S1");
for (Student student : grade.getStudents()) {
System.out.println(student.getStudentName()+"\t"+grade.getGradeName());
}
}
}