一.导入项目,观察思考其运行原理
1.导入后的运行效果
2.com.how2java.test包
该包中只有一个类,MybatisTest.java;
该类里面有这么一行代码需要注意:
categoryMapper.add(category);
在往category_表中添加name的时候用的是categoryMapper这个接口,
而不是直接对表操作,这是为什么?
3.com.how2java.mapper包
该包中有两个文件,分别是CategoryMapper.java和Category.xml
3.1 CategoryMapper.java
这是一个接口,里面定义了增删改查四个操作,
3.2 Category.xml
这是一个配置文件,具体作用是实现CategoryMapper这个接口中定义的增删改查。
那么为什么不直接在接口中实现而是要再写一个xml文件来实现?
为了实现代码和数据存储机制之间的分离。
4.com.how2java.pojo包
该包中就一个类,Category.java。
这个类里面定义了id和name两个变量以及它们对应的get, set方法,
最后定义一个toString方法,返回一个string值。
每当我实例化了一个category类,这个实例category其实就是category_表中的一个元组。
5.com.how2java.controller包
这个包里面就一个文件,CategoryController.java。这个文件的开头是这样的
@Autowired
CategoryService categoryService;
Autowired是用来依赖注入的, 把categoryService的一个实例注入到CategoryController这个控制器类中。
6.com.how2java.service包
这个包里面也就一个文件CategoryService.java。这个类并不是IoC容器,IoC容器是Spring本身。
IoC控制CategoryService注入到CategoryController这个控制器类中,允许控制器调用service里面的方法。
7.com.how2java.service.impl包
就一个文件CategoryServiceImpl.java, 是对CategoryService.java的具体实现。
二.增加对product_表的操作
1. com.how2java.pojo包
在该类中新增一个Product.java类,参照已有的Category.java的代码,代码如下:
package com.how2java.pojo;
public class Product {
private int id;
private String name;
private float price;
private int cid;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public float getPrice(){
return price;
}
public void setPrice(float price){
this.price = price;
}
public int getCid(){
return cid;
}
public void setCid(int cid){
this.cid = cid;
}
@Override
public String toString() {
return "Product [id=" + id + ", name=" + name + ", price = " + price + ", cid = " + cid + "]";
}
}
对应product_表中的id, name, price, cid四个属性,定义四个相应的变量以及方法。
2.com.how2java.mapper包
这个包里面放一个接口,以及一个配置文件,配置文件用来实现接口中定义的方法。
2.1 ProductMapper.java接口
ProductMapper.java代码如下:
这里报错的原因是我只写了函数的声明,没有写函数的实现。具体实现放在xml文件中写。
后来经过chatGPT查询后,发现其实报错的原因在于ProductMapper是一个接口,接口不需要写函数的具体实现,我把interface写成了class,
所以报错。修改后正确。
2.2 Product.xml配置文件
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.how2java.mapper.ProductMapper">
<insert id="add" parameterType="Product" >
insert into product_ ( name ) values (#{name})
</insert>
<delete id="delete" parameterType="Product" >
delete from Product_ where id= #{id}
</delete>
<select id="get" parameterType="_int" resultType="Product">
select * from product_ where id= #{id}
</select>
<update id="update" parameterType="Product" >
update product_ set name=#{name} where id=#{id}
</update>
<select id="list" resultType="Product">
select * from product_
</select>
</mapper>
3.com.how2java.service包
package com.how2java.service;
import java.util.List;
import com.how2java.pojo.Product;
public interface ProductService {
List<Product> list();
}
这个文件用来被控制器类调用。
4. com.how2java.controller包
该控制器用来控制Product类