解釋說明:視圖創建是因爲由於表與表之間的關係,在我寫接口的時候會帶出來一些有關係的數據,每個視圖都是根據自己的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;
}