解释说明:视图创建是因为由于表与表之间的关系,在我写接口的时候会带出来一些有关系的数据,每个视图都是根据自己的sql语句或者是sql语句产生的
1.先看一下我的hql语句
//从Students的实体类中根据姓名和状态来查询学生的有关信息
from Students where name=:name and status=:status
2.就是在数据库中创建视图的过程
打开mysql数据库==>点击菜单栏的下面的“视图”==>点击“”新建视图“”==>点击“视图创建工具”==>选择数据库中你需要的表==>
你会看到你所选择表中的字段,选择你所需要的字段==>在下方会有sql语句,填写你hql语句的条件==>最后点击保存填写表名即可
==>查看点击视图
3.想要得到与其他表无关的信息,必须新建一个实体类,在里面写上你所用的字段,hql中填写的是你新建的实体类的名称
4.创建实体类,必须加上@Entity的注解,在创建视图的时候你所选择的字段,实体类中也得有
@Entity
public class Students extends IdEntity{
private String name;
private String code;
private int sex;
private String nation;
private Date birthday;
private String phone;
private String post;
private Date inTime;
private String guardianPhones;
private int status = Status.正常.getValue();
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getCode() {
return code;
}
public void setCode(String code) {
this.code = code;
}
public int getSex() {
return sex;
}
public void setSex(int sex) {
this.sex = sex;
}
public String getNation() {
return nation;
}
public void setNation(String nation) {
this.nation = nation;
}
public Date getBirthday() {
return birthday;
}
public void setBirthday(Date birthday) {
this.birthday = birthday;
}
public String getPhone() {
return phone;
}
public void setPhone(String phone) {
this.phone = phone;
}
public String getPost() {
return post;
}
public void setPost(String post) {
this.post = post;
}
public Date getInTime() {
return inTime;
}
public void setInTime(Date inTime) {
this.inTime = inTime;
}
public String getGuardianPhones() {
return guardianPhones;
}
public void setGuardianPhones(String guardianPhones) {
this.guardianPhones = guardianPhones;
}
public int getStatus() {
return status;
}
public void setStatus(int status) {
this.status = status;
}