- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有 2 张 table 要加入。第一个表名为 students
,有几个字段 => (studentID、姓名、名字、性别、出生日期、地址、电话、电子邮件、状态、日期注册、许可证 ID)
我的第二个表名为 licenses
,有 2 个字段 =>(licenseID、type_license)。
我的 SQL 请求似乎是正确的,如下:
SELECT students.studentID, students.name, students.firstname, students.dateofbirth, students.sex, students.address,
students.phone, students.email, students.status, students.dateofbirth, licenses.type_license
FROM students
INNER JOIN licenses
ON students.licenseID = licenses.licenseID
我认为我的模型也不错
模范学生
package com.autoecole.model;
public class Student {
private int studentID;
private String name;
private String firstname;
private String dateofbirth;
private String sex;
private String address;
private String phone;
private String email;
private String status;
private String dateregister;
private int licenseID;
public void setStudentID(int studentID) {
this.studentID = studentID;
}
public void setName(String name) {
this.name = name;
}
public void setFirstname(String firstname) {
this.firstname = firstname;
}
public void setDateofbirth(String dateofbirth) {
this.dateofbirth = dateofbirth;
}
public void setSex(String sex) {
this.sex = sex;
}
public void setAddress(String address) {
this.address = address;
}
public void setPhone(String phone) {
this.phone = phone;
}
public void setEmail(String email) {
this.email = email;
}
public void setStatus(String status) {
this.status = status;
}
public void setDateregister(String dateregister) {
this.dateregister = dateregister;
}
public void setLicenseID(int licenseID) {
this.licenseID = licenseID;
}
public int getStudentID() {
return studentID;
}
public String getName() {
return name;
}
public String getFirstname() {
return firstname;
}
public String getDateofbirth() {
return dateofbirth;
}
public String getSex() {
return sex;
}
public String getAddress() {
return address;
}
public String getPhone() {
return phone;
}
public String getEmail() {
return email;
}
public String getStatus() {
return status;
}
public String getDateregister() {
return dateregister;
}
public int getLicenseID() {
return licenseID;
}
}
模型许可证
public class License {
private int licenseID;
private String type_license;
public void setLicenseID(int licenseID) {
this.licenseID = licenseID;
}
public void setTypeLicense(String type_license) {
this.type_license = type_license;
}
public int getLicenseID() {
return licenseID;
}
public String getTypeLicense() {
return type_license;
}
}
在我的 getAllRecordsStudents() 方法中,此行有一条错误消息:
studentBean.setTypeLicense(rs.getString("licenses.type_license"));
“未为 Student 类型定义 setTypeLicense(String) 方法”
public static List getAllRecordsStudents(){
List <Student> list=new ArrayList<Student>();
try{
Connection con=getConnection();
PreparedStatement ps=con.prepareStatement("SELECT students.studentID, students.name, students.firstname, students.dateofbirth, students.sex, students.address, students.phone, students.email, students.status, students.dateofbirth, licenses.type_license FROM students INNER JOIN licenses ON students.licenseID = licenses.licenseID");
ResultSet rs=ps.executeQuery();
while(rs.next()){
Student studentBean =new Student();
studentBean.setStudentID(rs.getInt("studentID"));
studentBean.setName(rs.getString("name"));
studentBean.setFirstname(rs.getString("firstname"));
studentBean.setDateofbirth(rs.getString("dateofbirth"));
studentBean.setSex(rs.getString("sex"));
studentBean.setAddress(rs.getString("address"));
studentBean.setPhone(rs.getString("phone"));
studentBean.setEmail(rs.getString("email"));
studentBean.setStatus(rs.getString("status"));
studentBean.setDateregister(rs.getString("dateregister"));
studentBean.setTypeLicense(rs.getString("licenses.type_license"));
list.add(studentBean);
}
}catch(Exception e){System.out.println(e);}
return list;
}
编辑:这是屏幕截图
AddStudent方法()
public static int addStudent(Student studentBean){
int status=0;
try{
Connection con=getConnection();
PreparedStatement ps=con.prepareStatement("insert into students(name, firstname, sex, dateofbirth, address, phone, email, status, dateregister, licenseID) values(?,?,?,?,?,?,?,?,?,?)");
ps.setString(1,studentBean.getName());
ps.setString(2,studentBean.getFirstname());
ps.setString(3,studentBean.getDateofbirth());
ps.setString(4,studentBean.getSex());
ps.setString(5,studentBean.getAddress());
ps.setString(6, studentBean.getPhone());
ps.setString(7, studentBean.getEmail());
ps.setString(8, studentBean.getStatus());
ps.setString(9, studentBean.getDateregister());
ps.setInt(10, studentBean.getLicenseID());
status=ps.executeUpdate();
}catch(Exception e){System.out.println(e);}
return status;
}
真诚地,我不明白我应该做什么?
最佳答案
使用联接,您无需在结果集查找中定义表名称,因为它会返回两个表的新 View 。
rs.getString("licenses.type_license");
将其更改为
rs.getString("type_license");
它应该可以工作。
如果可以的话,请查看运行该查询时返回的数据库中的完整表
**编辑他们是错误的类型。 type_license
在 licence 中是 String,在 Student 中是 int。
要获取解析它或更改其中一种类型所需的值。我喜欢;
studentBean.setTypeLicense(Integer.valueOf(rs.getString("type_license")));
但是您可以通过几种不同的方式来做到这一点。
关于java - java jSTL 中外键的 DAO Controller ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61414375/
我有组件需要更新客户和客户地址的数据库(通过 JDBC)。从 CustomerDAO 调用 CustomerAddressDAO 是否合适?或者创建一个单独的“CustomerDataManager”
任何人都可以解释MS Access 2007中DAO.Recordset,DAO.Recordsets和DAO.Recordset2之间的区别吗?基本上使用记录集。...举一个例子,使它更清晰。我从“
所以我正在编写一个个人项目来学习 Web 编程,并且我遇到了 DAO 模式。我构建了一些类(模型),并且像几乎所有程序一样,它们是嵌套的(例如:类 Payment 具有对 Author 实例的引用)。
我有一个基本问题。 我一直在创建关注点分离的 DAO。每个 DAO 都专注于上下文中的 BusinessObject。我的问题是如何在另一个 DAO 中使用一个 DAO 方法。我认为这是错误的,但没有
有没有办法使用 Android Room Persistence Library 将 DAO 作为依赖项添加到其他 DAO 中,也许是使用 Dagger2?我试图避免在使用事务对多个表执行操作的 DA
通常,我会尝试以一种完全依赖于自身的方式来构建我的 DAO 类。它们可以与多个表交互,但前提是数据与基础对象相关。例如,假设我有一个约会对象,约会 DAO 从约会表中提取数据。如果约会表是一个服务 i
在学校学习过 Java 后,我对 DAO 模式( Data access object )非常熟悉。然而在工作中我使用.NET。在 .NET 中,经常讨论 DAL( Data Access Layer
我一直在尝试按照以下步骤创建一个通用的 DAO: http://www.ibm.com/developerworks/java/library/j-genericdao/index.html 不过,我
Java EE 中的最佳实践是什么? 在服务(或管理器)类中创建 DAO 类的实例 SalesDAO salesDao = new SalesDAOImpl(); salesDao.findCusto
这有道理吗? 假设我需要从 DB 中获取一个对象,该对象与另一个对象有关系(由 DB 中的外键表示,并由我的域对象中的组合表示)。如果在我的第一个 DAO 中,我为对象 1 获取数据,然后为对象 2
我目前正在为应用程序创建数据访问层。此应用程序最初将连接到 Oracle 数据库,但稍后也会连接到 DB2 数据库。 为了连接到数据库,我将使用 JDBC。在这个时候我正在考虑我的选择。在我看来,我有
我正在 JSF 中设计一些数据“块” 我从每个块的 Java bean 中获取我的数据。 我的问题是我的块从多个表中获取数据。 例如: 描述 的块客户的个人资料 由组成: 客户名称(在表 客户 中)
将 DAO 类与应用程序代码中实际实例化的 DAO 类分开有什么好处,即为什么不在这样的场景中直接实例化 DAO 类: Class CreateIocContainer{ p s v main
我正在为我的 DataNucleus JDO DAO 创建通用 DAO。通用 DAO 将执行获取、更新、删除、创建操作和一些其他通用操作,因此这些实现可以在更具体的 DAO 中进行扩展。 是否有可能以
这可能是一件非常微不足道的事情,但我是一些面向对象模式的新手。 简而言之,在另一个 DAO 中使用一个 DAO 中的方法是一种不好的做法吗?我试图在 DAO 中创建一个实体,但发现仅使用该 DAO 很
我参与了一个 Java 项目,该项目从不同的支付代理获取支付信息,对其进行处理并将其存储到我们的计费系统(数据库)中。 由于我们有不同的代理,因此支付协议(protocol)也不同,因此我们有时有相似
考虑以下 Room DAO @Dao public abstract class JobDao { @Insert public abstract long insert( Job v
我有一个“容器”类,其字段包含在多个数据库表中,我使用 DAO 模式来访问数据。 问题是,我应该为这个“容器”类创建一个 DAO,还是每个表有一个 DAO 并合并它们的数据更好? 最佳答案 您应该根据
我们正在通过 @Service 和 @Component 注释使用 Spring @Autowired 改造一个新的面向服务的架构。 我一直在和我的同事争论不让每个 DAO 都有接口(interfac
我有通用的 DAO: @NoRepositoryBean interface ICrudDao extends Repository { void delete(T deleted);
我是一名优秀的程序员,十分优秀!