让我快速解释一下。我在7月份通过Java公司参加了为期5周的课程。他们介绍了基本的东西,比如控制台应用程序,crud操作,mysql和n层架构。自从课程结束以来,我没有使用它,因为我回去工作,其他医疗原因浮出水面......等等等等。
公司告诉我制作一个简单的程序来反映我学到的东西。事实证明我保留的很少。
我决定制作一个视频游戏starage计划。它将用于凝视您的视频游戏,因此您不必搜索您的书架(或者您存储游戏的方式。)
这是一个使用MYSQL的crud操作的基本控制台应用程序。我无法让我的搜索功能真正起作用。我有2层表示层和逻辑层。搜索方法允许他们通过标题搜索游戏。当我带来运行程序并使用搜索它只显示标题,其余为空。 这是我的表达层:
private static Games SearchForGame()
{
Logic aref = new Logic();
Games g = new Games();
Scanner scanline = new Scanner(System.in);
System.out.println("Please enter the name of the game you wish to find:");
g.setTitle(scanline.nextLine());
aref.SearchGame();
System.out.println();
System.out.println("Game Id: " + g.getGameId());
System.out.println("Title: " + g.getTitle());
System.out.println("Rating: " + g.getRating());
System.out.println("Platform: "+ g.getPlatform());
System.out.println("Developer: "+ g.getDeveloper());
return g;
}
这是我的逻辑层
public Games SearchGame() {
Games g = new Games();
try {
Class.forName(driver).newInstance();
Connection conn = DriverManager.getConnection(url+dbName,userName,password);
java.sql.PreparedStatement statement = conn.prepareStatement("SELECT GameId,Title,Rating,Platform,Developer FROM games WHERE Title=?");
statement.setString(1, g.getTitle());
ResultSet rs = statement.executeQuery();
while(rs.next()){
g.setGameId(rs.getInt("GameId"));
g.setTitle(rs.getString("Title"));
g.setRating(rs.getString("Rating"));
g.setPlatform(rs.getString("Platform"));
g.setDeveloper(rs.getString("Developer"));
statement.executeUpdate();
}
} catch (Exception e) {
e.printStackTrace();
}
return g;
}
这也是我最后的结果
Please enter the name of the game you wish to find:
Skyrim
Game Id: 0
Title: Skyrim
Rating: null
Platform: null
Developer: null
任何帮助都将非常感谢并提前感谢
编辑:这是我的游戏类代码
public class Games
{
public int GameId;
public String Title;
public String Rating;
public String Platform;
public String Developer;
public int getGameId()
{
return GameId;
}
public int setGameId(int gameId)
{
return GameId = gameId;
}
public String getTitle()
{
return Title;
}
public String setTitle(String title)
{
return Title = title;
}
public String getRating()
{
return Rating;
}
public void setRating(String rating)
{
Rating = rating;
}
public String getPlatform()
{
return Platform;
}
public void setPlatform(String platform)
{
Platform = platform;
}
public String getDeveloper()
{
return Developer;
}
public void setDeveloper(String developer)
{
Developer = developer;
}
}
答案 0 :(得分:0)
在SearchGame()
中,您创建了一个新的Games
对象,然后使用getTitle()
而不设置标题。在SearchForGame()
中,您确实设置了标题,但是您应该将Games
对象传递给SearchGame()
并存储返回的对象。 (g
中的SearchGame()
和g
中的SearchForGame()
是两个不同的对象)