JAVA零基础入门9-实现订单创建功能

如果说一个商品管理系统最重要的模块之一是什么,那么我首先会说订单模块,它代表着我们商品的售卖情况,是商家最关心的地方,今天我们开始学习订单是如何创建的

2023/11/21

1.将购物车数据变为订单数据

        前面我们提到我们将用户随手添加的产品放入到缓存中来应对用户每次的变化,因为每次用户点的菜品可能都不一样,所有使用缓存可以降低我们的内存消耗,但是一旦用户决定将购物车中的商品变为真实的订单,那么我们就需要将数据放入到我们的数据库中。

        由此,我们需要建立数据库表order和order_details

CREATE TABLE orders (
    id INT AUTO_INCREMENT PRIMARY KEY,
    user_id INT NOT NULL,
    total_price INT,
    status String,
    order_date TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
);

order表中包含我们的用户id,此张订单的总价格,订单状态,创建订单的时间

CREATE TABLE `order_details` (
  `order_details_id` INT NOT NULL AUTO_INCREMENT,
  `order_id` INT NOT NULL,
  `cai_name` INT NOT NULL,
  `quantity` INT NOT NULL,
  `price` INT NOT NULL,
  PRIMARY KEY (`order_details_id`),
  FOREIGN KEY (`order_id`) REFERENCES `order` (`order_id`) on delete cascade
);

order_details表中包含订单id作为外键,若订单删除,那么对应订单id的所有订单详情会同时被删除,cai_name,quantity用来记录菜品的名字和数量,price记录菜品对应的价格,后续我们在订单表中计算总价格;


2.创建订单相关实体和方法

        我们创建完了order和order_details之后,在java中创建对应的实体和方法以及xml,具体的逻辑在前面的基础中已经很熟练了,其中用到的方法是边做边加的,用什么直接新增一个方法就好,直接放代码,展示一下两个serverice实现类

@Service
public class OrderServiceImpl implements OrderService {
    @Autowired
    private OrderMapper orderMapper;
    public void insertOrder(Order order){
         orderMapper.insertOrder(order);
    }

    @Override
    public int selectIdbyuser(int user_id) {
        return orderMapper.selectIdbyuser(user_id);
    }

    @Override
    public void updataOrderPriceByid(int order_id,int total_price) {
        orderMapper.updataOrderPriceByid(order_id,total_price);
    }
}
@Service
public class OrderDetailServiceImpl implements OrderDetailService {
    @Autowired
    private OrderDetailsMapper orderDetailsMapper;

    @Override
    public void insertOrderDetails(OrderDetails orderDetails) {
        orderDetailsMapper.insertOrderDetails(orderDetails);
    }

    @Override
    public int gettotalprice(int order_id) {
        return orderDetailsMapper.gettotalprice(order_id);
    }
}

其实方法是很简单的,我们主要复杂的地方是在于我们处理的逻辑,也就是controller,下面会从逻辑的角度来细解实现的过程

3.实现订单创建逻辑


        在之前我们已经创建好了购物车,接下来我们要把购物车中的数据发送到后端,需要先新增一个按钮,点击提交订单发送fetch请求,此处与前面的学习都差不多,直接放代码即可

//在我们的购物车模拟框中加入一个按钮
<button type="submit" th:onclick="createOrder()">提交订单</button>

<script>
    function createOrder(){
        fetch('/createOrder',{
            method:'POST'
        }).then(res=>res.json())
            .then(res=>{document.getElementById("carModal").style.display = 'none';
            alert(res.message);
        }).catch(err=>console.error("上传失败请重试"+err))
    }
</script>

前端发送请求后,后端首先使用session验证用户身份,然后通过用户姓名来找到对应的redis购物车数据,这里说明一下我们之前是在购物车中放了菜品的名字和数量(小修改),接下来创建一个新的order,设置它的userid,状态为已创建,创建时间,这三个字段,这时mysql会自动为我们创建一个orderid我们查询这个id,因为我们后面要存入到详情表中,此时order还有一个total_price没有被设置,因为我们缺少订单详情,所以后面更新它即可。这部分代码如下:

 @PostMapping("/createOrder")
    public ResponseEntity<Map<String,String>> createOrder( HttpSession session){
        String username = (String) session.getAttribute("USER");
        System.out.println(username);
        int userid = userService.selectUserID(username);
        System.out.println(userid);
        if (username==null){
            Map<String,String> response = new HashMap<>();
            response.put("message","用户未登录");
            return ResponseEntity.badRequest().body(response);
        }
        Order order = new Order();
        order.setUser_id(userid);
        order.setStatus("已提交订单");
        order.setOrder_date(LocalDateTime.now());
        System.out.println(LocalDateTime.now());
        orderService.insertOrder(order);

接着我们根据redis中的购物车数据来更新订单详情表,使用hashoperation的entries方法,我们可以获取到一个hashmap的所有键值对,然后使用for-each也叫增强for循环来遍历entries,这里我们计算total_price的方法是在for循环外面初始化一个值,然后在for循环中累加,这样可以每次循环后保留计算好的total_price;我们将entry的每个键作为cai_name,每个value作为quantity,然后同时将之前定义好的cai_id,order_id以及从菜品表查到的菜品价格加入到详情表中,详情表就更新完成了,我们最后把这个order_id所对应的total_price更新到订单表中,这样两个表的字段就全部更新完成了,此时我们可以将之前没有设置过期时间的购物车redis缓存给删除,这样订单和购物车就只会存在一个了,代码如下(续上):

        int orderid = orderService.selectIdbyuser(userid);
        System.out.println(orderid);
        String carkey = "car" + username;
        hashOperations = redisTemplate.opsForHash();
        Map<Object,Object> car = hashOperations.entries(carkey);
        int total_price = 0;
        for (Map.Entry<Object,Object> entry : car.entrySet()){
            String cai_name = (String) entry.getKey();
            int quantity = (int) entry.getValue();
            OrderDetails orderDetails = new OrderDetails();
            System.out.println(orderid);
            orderDetails.setOrder_id(orderid);
            orderDetails.setCai_name(cai_name);
            orderDetails.setQuantity(quantity);
            int price = caiService.selectPriceByName(cai_name);
            orderDetails.setPrice(price);
            orderDetailService.insertOrderDetails(orderDetails);
            int item_price = quantity * price;
            total_price = total_price+item_price;
        }
        System.out.println("总价格为:"+total_price);
//        int totalprice = orderDetailService.gettotalprice(orderid);
        orderService.updataOrderPriceByid(orderid,total_price);
        redisTemplate.delete(carkey);
        Map<String,String> response = new HashMap<>();
        response.put("message","订单已创建");
        return ResponseEntity.ok().body(response);
    }

4.实现效果图

点击提交订单-发送数据到后端-模拟框关闭

更新订单详情表,此时我们oder_id对应是50的是本次订单

更新订单表价格,通过详情表的菜品数量和价格,我们将计算好的总金额更新到订单表

提交订单后,再次进入购物车,数据已经消失

  • 7
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
import java.awt.*; import java.awt.event.*; import javax.swing.*; import java.sql.*; public class system extends JFrame { JDesktopPane deskpane = new JDesktopPane();//在窗体里建立虚拟桌 JPanel p = new JPanel();//创建一个面板并实例化 public system(){//构造函数 setTitle("订单管理系统");//设置窗体标题 Container con = getContentPane(); con.setLayout(new BorderLayout());//创建一个布局 con.add(deskpane,BorderLayout.CENTER);//实例虚拟桌面的布局 Font f =new Font("新宋体",Font.PLAIN,12); JMenuBar mb = new JMenuBar();//实例化菜单栏 mb.setOpaque(true); setJMenuBar(mb); mb.setOpaque(true); setJMenuBar(mb); JMenu systemM = new JMenu("系统管理"); systemM.setFont(f); mb.add(systemM); JMenuItem land = new JMenuItem("重新登陆"); land.setFont(f); JMenuItem exit = new JMenuItem("退出系统"); exit.setFont(f); systemM.add(land); systemM.add(exit); JMenu userM = new JMenu("用户管理"); userM.setFont(f); mb.add(userM); JMenuItem password = new JMenuItem("密码修改"); password.setFont(f); JMenuItem addDelete = new JMenuItem("添加/删除用户"); addDelete.setFont(f); userM.add(password); userM.add(addDelete); JMenu mesM = new JMenu("信息管理"); mesM .setFont(f); mb.add(mesM ); JMenu addM= new JMenu("添加信息"); addM.setFont(f); JMenu viewM = new JMenu("查看信息"); viewM.setFont(f); JMenu modifM = new JMenu("修改信息"); modifM.setFont(f); JMenu deleteM = new JMenu("删除信息"); deleteM.setFont(f); mesM.add(addM); mesM.add(viewM); mesM.add(modifM); mesM.add(deleteM); JMenuItem addgoods = new JMenuItem("添加商品信息"); addgoods.setFont(f); addM.add(addgoods); JMenuItem addclient = new JMenuItem("添加客户信息"); addclient.setFont(f); addM.add(addclient); JMenuItem viewgoods= new JMenuItem("查看商品信息"); viewgoods.setFont(f); viewM.add(viewgoods); JMenuItem viewclient = new JMenuItem("查看客户信息"); viewclient.setFont(f); viewM.add(viewclient); JMenuItem modifgoods = new JMenuItem("修改商品信息"); modifgoods.setFont(f); modifM.add(modifgoods); JMenuItem modifclient = new JMenuItem("修改用户信息"); modifclient.setFont(f); modifM.add(modifclient); JMenuItem deletegoods = new JMenuItem("删除商品信息"); deletegoods.setFont(f); deleteM.add(deletegoods); JMenuItem deleteclient = new JMenuItem("删除用户信息"); deleteclient.setFont(f); deleteM.add(deleteclient); JMenu orderM = new JMenu("订单管理"); orderM.setFont(f); mb.add(orderM); JMenuItem addO= new JMenuItem("添加订单"); addO.setFont(f); JMenuItem viewO = new JMenuItem("查看订单"); viewO.setFont(f); JMenuItem modifO = new JMenuItem("修改订单"); modifO.setFont(f); JMenuItem deleteO = new JMenuItem("删除订单"); deleteO.setFont(f); orderM.add(addO); orderM.add(viewO); orderM.add(modifO); orderM.add(deleteO); //主界面上标出学号、姓名、及所作系统名 JLabel jlabel1=new JLabel(); jlabel1.setFont(new Font("宋体",Font.BOLD,15)); //设置字体 jlabel1.setHorizontalAlignment(SwingConstants.CENTER); //设置位置 jlabel1.setText("简易订单管理系统学号:070810228" + " 姓名:廖太春指导老师:周老师"); jlabel1.setBounds(450,350, 200, 200); deskpane.add(jlabel1); password.addActionListener(new ActionListener(){//密码修改监听 public void actionPerformed(ActionEvent e){ System.out.println("修改密码"); deskpane.add(new modifpsw()); } }); land.addActionListener(new ActionListener(){//重新登陆监听 public void actionPerformed(ActionEvent e){ System.out.println("登录"); setVisible(false); new Land(); } }); addDelete.addActionListener(new ActionListener(){//添加/删除用户监听 public void actionPerformed(ActionEvent e){ deskpane.add(new AddDeleteUser()); } }); addgoods.addActionListener(new ActionListener(){//添加商品信息 public void actionPerformed(ActionEvent e){ deskpane.add(new addgoods()); } }); addclient.addActionListener(new ActionListener(){//添加用户信息 public void actionPerformed(ActionEvent e){ deskpane.add(new addclient()); } }); viewgoods.addActionListener(new ActionListener(){//查看商品信息 public void actionPerformed(ActionEvent e){ System.out.println("查看商品信息"); deskpane.add(new viewgoods()); } }); viewclient.addActionListener(new ActionListener(){//查看客户信息 public void actionPerformed(ActionEvent e){ System.out.println("查看客户信息"); deskpane.add(new viewclient()); } }); modifgoods.addActionListener(new ActionListener(){//修改商品信息 public void actionPerformed(ActionEvent e){ System.out.println("修改商品信息"); deskpane.add(new modifgoods()); } }); modifclient.addActionListener(new ActionListener(){//修改用户信息 public void actionPerformed(ActionEvent e){ System.out.println("修改用户信息"); deskpane.add(new modifclient()); } }); deletegoods.addActionListener(new ActionListener(){//删除商品信息 public void actionPerformed(ActionEvent e){ System.out.println("删除商品信息"); deskpane.add(new deletegoods()); } }); deleteclient.addActionListener(new ActionListener(){//删除用户信息 public void actionPerformed(ActionEvent e){ System.out.println("删除用户信息"); deskpane.add(new deleteclient()); } }); addO.addActionListener(new ActionListener(){//添加订单 public void actionPerformed(ActionEvent e){ deskpane.add(new addO()); } }); viewO.addActionListener(new ActionListener(){//查看订单 public void actionPerformed(ActionEvent e){ deskpane.add(new viewO()); } }); modifO.addActionListener(new ActionListener(){//修改订单 public void actionPerformed(ActionEvent e){ System.out.println("修改订单"); deskpane.add(new modifO()); } }); deleteO.addActionListener(new ActionListener(){//删除订单 public void actionPerformed(ActionEvent e){ System.out.println("/删除订单"); deskpane.add(new deleteO()); } }); exit.addActionListener(new ActionListener(){//退出系统监听 public void actionPerformed(ActionEvent e){ setVisible(false); } }); this.setBounds(200,200,700,600); setVisible(true); } public static void main(String[] args){ new Land(); } }
好的,我来回答你的问题。 首先,让我们来了解一下什么是 EAV 模型。EAV 模型是一种数据建模的方法,它将所有的数据存储在一个三元组 (实体、属性、值) 中。其中,实体表示存储的对象,属性表示实体的某个特征,值则表示该属性的具体取值。这种模型可以用于存储非结构化数据和动态的数据,但是在查询和维护方面会存在一些挑战。 接下来,让我们来看一下如何实现简单的转存。Java 中提供了许多用于文件操作的类和方法,其中最常用的是 java.io 包中的类。我们可以使用 FileInputStream 和 FileOutputStream 类来实现文件的读写操作。 例如,我们可以通过以下代码将源文件的内容复制到目标文件中: ```java import java.io.*; public class FileCopy { public static void main(String[] args) { try { FileInputStream in = new FileInputStream("source.txt"); FileOutputStream out = new FileOutputStream("target.txt"); byte[] buffer = new byte[1024]; int length; while ((length = in.read(buffer)) > 0) { out.write(buffer, 0, length); } in.close(); out.close(); System.out.println("File copied successfully!"); } catch (IOException e) { e.printStackTrace(); } } } ``` 在上面的代码中,我们首先创建了一个 FileInputStream 对象来读取源文件,然后创建了一个 FileOutputStream 对象来写入目标文件。接着,我们使用一个字节数组作为缓冲区,每次读取 1024 个字节,并将其写入目标文件中。最后,我们关闭了输入输出流,完成了文件复制操作。 希望这个简单的例子能够帮助你入门 Java IO 操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值