sdent類: java
package com.myschool.entity;
public class student{
private int studentno;
private String loginpwd;
private String studentname;
private int sex;
private int gradeid;
private String phone;
private String address;
private String borndate;
private String email;
private String IdentityCard;
grade grade=new grade();
public grade getGrade() {
return grade;
}
public void setGrade(grade grade) {
this.grade = grade;
}
public int getStudentno() {
return studentno;
}
public void setStudentno(int studentno) {
this.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) {
this.sex = sex;
}
public int getGradeid() {
return gradeid;
}
public void setGradeid(int gradeid) {
this.gradeid = gradeid;
}
public String getPhone() {
return phone;
}
public void setPhone(String phone) {
this.phone = phone;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
public String getBorndate() {
return borndate;
}
public void setBorndate(String borndate) {
this.borndate = borndate;
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.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 gradeid, String phone, String address, String borndate,
String email, String identityCard) {
super();
this.studentno = studentno;
this.loginpwd = loginpwd;
this.studentname = studentname;
this.sex = sex;
this.gradeid = gradeid;
this.phone = phone;
this.address = address;
this.borndate = borndate;
this.email = email;
IdentityCard = identityCard;
}
//無參構造
public student(){
}
}
grade類:mysql
package com.myschool.entity;
import java.util.List;
public class grade {
private int gradeid;
private String gradename;
public List<student> list;
public List<student> getList() {
return list;
}
public void setList(List<student> list) {
this.list = list;
}
public int getGradeid() {
return gradeid;
}
public void setGradeid(int gradeid) {
this.gradeid = gradeid;
}
public String getGradename() {
return gradename;
}
public void setGradename(String gradename) {
this.gradename = gradename;
}
//帶參構造
public grade(int gradeid, String gradename) {
super();
this.gradeid = gradeid;
this.gradename = gradename;
}
//無參構造
public grade(){
}
}
BaseDao接口:
package com.myschool.daos;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
public class BaseDao {
private static final String STRING="com.mysql.jdbc.Driver";
private static final String URL="jdbc:mysql:///myschool";
private static final String U_STRING="root";
private static final String PASSWORD="";
Connection con=null;
PreparedStatement Statement;
ResultSet executeQuery ;
public Connection getdConnection() throws Exception
{
Class.forName(STRING);
//con.isClosed:判斷是不是關閉的
if (con==null||con.isClosed()) {
con = DriverManager.getConnection(URL, U_STRING,PASSWORD);
}
return con;
}
//Object ...objects這種參數定義是在不肯定方法參數的狀況下的一種多態表現形式。
//即這個方法能夠傳遞多個參數,這個參數的個數是不肯定的。這樣你在方法體中須要相應的作些處理。
//由於Object是基類,因此使用Object ...objects這樣的參數形式,容許一切繼承自Object的對象做爲參數。
//這種方法在實際中應該仍是比較少用的。
public int getDao(String string,Object...objects) throws Exception
{
getdConnection();
Statement = con.prepareStatement(string);
for (int i = 1; i <=objects.length; i++) {
Statement.setObject(i,objects[i-1]);
}
int execute = Statement.executeUpdate();
return execute;
}
public ResultSet getDaos(String string,Object...objects) throws Exception
{
getdConnection();
Statement = con.prepareStatement(string);
for (int i = 1; i <=objects.length; i++) {
Statement.setObject(i,objects[i-1]);
}
executeQuery = Statement.executeQuery();
return executeQuery;
}
public void close() throws Exception
{
if (executeQuery!=null) {
executeQuery.close();
}
if (Statement!=null) {
Statement.close();
}
if (con!=null) {
con.close();
}
}
}
接口:
package com.myschool.daos;
import java.util.List;
import com.myschool.entity.grade;
import com.myschool.entity.student;
public interface studentdao {
public List<student> getstudent() throws Exception;
public grade getgrade(String gradeid) throws Exception;
}
實現類:
package com.myschool.dao.impl;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.List;
import com.myschool.daos.BaseDao;
import com.myschool.daos.studentdao;
import com.myschool.entity.grade;
import com.myschool.entity.student;
public class studnetdaoimpl extends BaseDao implements studentdao{
private ResultSet rs=null;
@Override
public grade getgrade(String gradename) throws Exception {
List<student> list1=new ArrayList<student>();
String sql="select s.*,g.GradeName from student as s,grade as g where s.GradeId=g.GradeId and g.gradename=?";
Object[] obj={gradename};
rs=executeQuery(sql, obj);
grade grade=null;
if (rs!=null) {
while(rs.next()){
grade=new grade();
student student=new student();
student.setStudentno(rs.getInt("studentno"));
student.setStudentname(rs.getString("studentname"));
list1.add(student);
grade.setGradename(rs.getString("gradename"));
}
grade.setList(list1);
}
return grade;
}
@Override
public List<student> getstudent() throws Exception {
List<student> list=new ArrayList<student>();
String sql="select * from student as s,grade as g where s.GradeId=g.GradeId";
rs = executeQuery(sql);
if (rs!=null) {
while(rs.next()){
student stu=new student();
grade grade=new grade();
stu.setStudentno(rs.getInt("studentno"));
stu.setStudentname(rs.getString("studentname"));
grade.setGradename(rs.getString("gradename"));
stu.setGrade(grade);
list.add(stu);
}
}
return list;
}
}
main方法:
package ui;
import java.util.List;
import com.myschool.dao.impl.studnetdaoimpl;
import com.myschool.daos.studentdao;
import com.myschool.entity.grade;
import com.myschool.entity.student;
public class ui {
static studentdao dao=new studnetdaoimpl();
public static void getstudent() throws Exception{
List<student> list=dao.getstudent();
for (student student : list) {
System.out.println(student.getStudentno()+"\t"+student.getStudentname()+"\t"+student.getGrade().getGradename());
}
}
public static void main(String[] args) throws Exception {
getstudent();
grade grade=dao.getgrade("S1");
for (student stu : grade.getList()) {
System.out.println(stu.getStudentno()+"\t"+stu.getStudentname()+"\t"+grade.getGradename());
}
}
}