- 一,前言
- 二,页面设计
- 三,具体描述
- 3.1,添加熟食包点
- 3.1.1,service.addUser方法
- 3.1.2,dao方法执行添加sql
- 3.2,删除熟食包点
- 3.2.1,service.delete方法
- 3.2.2,dao方法执行删除sql
- 3.3,查询熟食包点
- 3.3.1,service.searchByid方法
- 3.2.2,dao方法执行查询sql
- 3.4,修改熟食包点
- 3.4.1,service.updateid方法
- 3.4.2,dao方法执行更新sql
- 3.5排序熟食包点
- 3.5.1,service.updateid方法
- 3.5.2,dao方法执行排序sql
- 3.5.3,返回ui输出排序后
一,前言👨💻作者简介: 大家好,我是上进小菜猪。内蒙古科技大学,大二计科。技术很菜但不放弃,努力做全栈。 热爱开发,开发软件,开发网站,开发各种东西。
🛳️个人主页: 上进小菜猪的博客
📗系列专栏:本文写在《王道Java从入门到精通》专栏 ✉️如果文章知识点有错误的地方,请指正! 和大家一起学习一起进步🎈
🔥如果觉得博主的文章还不错的话,请👍三连支持👍一下博主哦
这是java老师的一个小组任务。拿来练手,让我对Java入门有了一些基本的感悟与熟悉。
二,页面设计五组——熟食包点
1-添加熟食包点
2-删除熟食包点
/ >按照编号删除
/ >按照名称删除
3-修改熟食包点
/ >按照编号修改
/ >按照名称修改
4-查询熟食包点
/ >按照熟食编号查询
/ >按照熟食名称查询
/ >按照熟食价格查询
/ >查询全部熟食
5-排序熟食包点
/ >按照价格排序
/ >按照库存排序
6-退出熟食包点
请输入数字,选择菜单功能:
如上为基本的页面设计。
三,具体描述 3.1,添加熟食包点
上述代码块解释:
终端输入数字1进入adduser方法,执行添加 *** 作。
依次输入熟食编号,熟食名称,熟食价格,熟食库存。
service.addUser(uid, eatname, eatprice, spare);
调用service的方法进行添加。
3.1.1,service.addUser方法public void addUser(String uid, String eatname, String eatprice, String spare) throws SQLException {
dao.addUser(uid, eatname, eatprice, spare);
}
接受ui传递的四个属性值,调用dao,进行添加。
起了一个中间传递的作用。
添加一条记录。
上述代码块解释:
PreparedStatement:是包中的一个接口,继承Statement,里面有已编译的 SQL 语句。
我觉得他的作用就是简化sql繁琐的拼接过程,方便使用。
里面的sql语句里的?就是他的功劳,提高代码的可读性和可维护性。
执行INSERT 添加sql语句。
后使用executeUpdate抽象方法,返回更新计数。
按照编号删除和按照名称删除基本差不多,我们已按照编号删除来写一下。
ui核心代码:
Scanner input = new Scanner(System.in);
int a = input.nextInt();
int m = service.delete(a);
把我们需要删除的id输入,存储到变量a,执行service.delete方法,传递a给service类。
3.2.1,service.delete方法public int delete(int a) throws SQLException {
// TODO Auto-generated method stub
return dao.deletewww(a);
}
依然是传递作用哈。调用dao,进行删除。
3.2.2,dao方法执行删除sql public int deletewww(int a) throws SQLException {
String sql = "DELETE FROM eat WHERE uid=?";
PreparedStatement pstmt = (PreparedStatement) conn.prepareStatement(sql);
pstmt.setInt(1, a);
return pstmt.executeUpdate();
}
如上代码解释:
较为简单获取传递的目标id值,执行删除sql语句。
后使用executeUpdate抽象方法,返回更新计数。
举例:按照熟食编号查询
上述代码块解释:
把终端输入的查询目标id存入变量inputeatId,后执行:
UserBean user= service.searchByid(inputeatId);
调用service的方法进行查询。
3.3.1,service.searchByid方法和上文一样,不多说了,传递的作用。
目标dao.searchByid。
上述代码块解释:
executeQuery()方法来下达select指令以查询数据库。
rs.next():指针指向下一条记录,如果有记录,返回true
user=new UserBean(u,n, psw,s);
传入UserBean实体类。
如果传递的user不为空,执行输出语句。
System.out.format("%-2s %-8s %-5s %-5s"+'\n',"食品编号","食物名称","食物价格","食品库存");
。。。
System.out.format("%-8s %-8s %-8s %-5s "+'\n',user.getNumber(),user.geteatname(),user.geteatprice(),user.getspare());
为了规范输出,对其 *** 作。
3.4,修改熟食包点以按照编号修改为例
上述代码块解释:
前面和查询 *** 作一样,先执行查询 *** 作,找到目标值。
System.out.println(user.getNumber()+"\t"+user.geteatname()+"\t"+user.geteatprice()+"\t"+user.getspare());
输出目标的查询结果(和上文查询 *** 作一模一样)。
之后输入输入新的食物名称,输入新的食物价格,输入新的食物库存。
后执行updateid方法。
和上文一样,不多说了,传递的作用。
调用dao的searchByupdateid
String sql ="update eat set eatname=?,eatprice=?,spare=? where uid=?";
PreparedStatement pstmt =(PreparedStatement) conn.prepareStatement(sql);
使用PreparedStatemen接口,继承Statement。
执行update sql更新语句。
将传递来的新目标变量,存入数据库中。
以按照按照价格排序为例。
System.out.println("按照价格排序:");
ResultSet rs = service.sortprice();
先执行service.sortprice方法。
3.5.1,service.updateid方法和上文一样,不多说了,传递的作用。
调用dao的dao.sortprice
public ResultSet sortprice() throws SQLException {
Statement stmt = conn.createStatement();
//String sql = "select * from eat";//表名
String sql ="select * from eat order by eatprice desc";
ResultSet rs = stmt.executeQuery(sql);
return rs;
}
上述代码解释:
执行排序sql语句以eatprice为目标建执行降序排序 *** 作。
返回排序后的对象。
3.5.3,返回ui输出排序后
while遍历结果集。
规定每一个元素占位符大小,为了美观好看,整齐。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)