@Data @AllArgsConstructor @NoArgsConstructor @Builder @Table(name = "advert") public class Advert { /** * 主键 / @Id @GeneratedValue(strategy = GenerationType.IDENTITY) @ApiModelProperty(value = "广告唯一id") private Integer id; /* * 广告名称 / @ApiModelProperty(value = "广告名称") @NotBlank(message = "广告名称不可为空", groups = {AddGroup.class, UpdateGroup.class}) private String name; /* * 广告位置ID / @ManyToOne(fetch = FetchType.LAZY) @JoinColumn(name = "position_id") private AdPosition position; /* * 广告图片ID / @ManyToOne(fetch = FetchType.LAZY) @JoinColumn(name = "media_id") private MediaFile media; /* * 开始日期 / @Column(name = "start_date") @ApiModelProperty(value = "开始日期") @NotNull(message = "开始日期不可为空", groups = {AddGroup.class}) private Date startDate; /* * 结束日期 / @Column(name = "end_date") @ApiModelProperty(value = "结束日期") @NotNull(message = "结束日期不可为空", groups = {AddGroup.class}) private Date endDate; /* * 广告链接 / @ApiModelProperty(value = "广告链接") @NotBlank(message = "广告链接不可为空", groups = {AddGroup.class}) private String link; /* * 广告状态:0:未启用,1:已启用,2:已结束 / @ApiModelProperty(value = "广告状态") @NotNull(message = "广告状态不可为空", groups = {UpdateGroup.class}) private Integer status; /* * 创建时间 / @Column(name = "create_time") @ApiModelProperty(value = "创建时间") private Date createTime; /* * 更新时间 */ @Column(name = "update_time") @ApiModelProperty(value = "更新时间") private Date updateTime; }如何在使用basemapper的插入时给position和media赋值,正常赋值会报错Cause: java.sql.SQLException: Field 'position_id' doesn't have a default value ; Field 'position_id' doesn't have a default value; nested exception is java.sql.SQLException: Field 'position_id' doesn't have a default value
时间: 2024-04-28 20:25:22 浏览: 167
可以在插入时手动设置position和media的值,例如:
Advert advert = new Advert();
advert.setName("广告名称");
advert.setStartDate(new Date());
advert.setEndDate(new Date());
advert.setLink("广告链接");
advert.setStatus(0);
advert.setPosition(new AdPosition(1)); //手动设置position的值
advert.setMedia(new MediaFile(1)); //手动设置media的值
advertMapper.insert(advert);
其中,1为position和media对应的ID值。这样就可以成功插入数据了。
相关问题
@Data @AllArgsConstructor @NoArgsConstructor @Builder @Table(name = "advert") public class Advert { /** * 主键 */ @Id @GeneratedValue(strategy = GenerationType.IDENTITY) @ApiModelProperty(value = "广告唯一id") private Integer id; /** * 广告名称 */ @ApiModelProperty(value = "广告名称") @NotBlank(message = "广告名称不可为空", groups = {AddGroup.class, UpdateGroup.class}) private String name; /** * 广告位置ID */ @ManyToOne(fetch = FetchType.LAZY) @JoinColumn(name = "position_id") private AdPosition position; /** * 广告图片ID */ @ManyToOne(fetch = FetchType.LAZY) @JoinColumn(name = "media_id") private MediaFile media; /** * 开始日期 */ @Column(name = "start_date") @ApiModelProperty(value = "开始日期") @NotNull(message = "开始日期不可为空", groups = {AddGroup.class}) private Date startDate; /** * 结束日期 */ @Column(name = "end_date") @ApiModelProperty(value = "结束日期") @NotNull(message = "结束日期不可为空", groups = {AddGroup.class}) private Date endDate; /** * 广告链接 */ @ApiModelProperty(value = "广告链接") @NotBlank(message = "广告链接不可为空", groups = {AddGroup.class}) private String link; /** * 广告状态:0:未启用,1:已启用,2:已结束 */ @ApiModelProperty(value = "广告状态") @NotNull(message = "广告状态不可为空", groups = {UpdateGroup.class}) private Integer status; /** * 创建时间 */ @Column(name = "create_time") @ApiModelProperty(value = "创建时间") private Date createTime; /** * 更新时间 */ @Column(name = "update_time") @ApiModelProperty(value = "更新时间") private Date updateTime; },这个类进行添加和修改时,因为有大量重复代码,如何简化代码并避免并发问题
可以使用Lombok提供的@Builder注解简化代码,并且使用@Transactional注解来实现数据库的事务控制,避免并发问题。简化后的代码如下:
```
@Data
@AllArgsConstructor
@NoArgsConstructor
@Builder
@Table(name = "advert")
public class Advert {
/** 主键 */
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@ApiModelProperty(value = "广告唯一id")
private Integer id;
/** 广告名称 */
@ApiModelProperty(value = "广告名称")
@NotBlank(message = "广告名称不可为空", groups = {AddGroup.class, UpdateGroup.class})
private String name;
/** 广告位置ID */
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "position_id")
private AdPosition position;
/** 广告图片ID */
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "media_id")
private MediaFile media;
/** 开始日期 */
@Column(name = "start_date")
@ApiModelProperty(value = "开始日期")
@NotNull(message = "开始日期不可为空", groups = {AddGroup.class})
private Date startDate;
/** 结束日期 */
@Column(name = "end_date")
@ApiModelProperty(value = "结束日期")
@NotNull(message = "结束日期不可为空", groups = {AddGroup.class})
private Date endDate;
/** 广告链接 */
@ApiModelProperty(value = "广告链接")
@NotBlank(message = "广告链接不可为空", groups = {AddGroup.class})
private String link;
/** 广告状态:0:未启用,1:已启用,2:已结束 */
@ApiModelProperty(value = "广告状态")
@NotNull(message = "广告状态不可为空", groups = {UpdateGroup.class})
private Integer status;
/** 创建时间 */
@Column(name = "create_time")
@ApiModelProperty(value = "创建时间")
private Date createTime;
/** 更新时间 */
@Column(name = "update_time")
@ApiModelProperty(value = "更新时间")
private Date updateTime;
/**
* 保存或更新广告
*/
@Transactional(rollbackFor = Exception.class)
public void saveOrUpdate() {
AdvertRepository advertRepository = SpringContextUtil.getBean(AdvertRepository.class);
if (this.getId() == null) {
// 新增广告
this.setCreateTime(new Date());
advertRepository.save(this);
} else {
// 更新广告
Advert oldAdvert = advertRepository.findById(this.getId()).orElse(null);
if (oldAdvert != null) {
BeanUtils.copyProperties(this, oldAdvert, "id", "createTime");
oldAdvert.setUpdateTime(new Date());
advertRepository.save(oldAdvert);
}
}
}
}
```
这里使用了Spring的@Transactional注解来实现事务控制,同时使用了Spring的工具类SpringContextUtil来获取AdvertRepository的实例。这样,我们就可以在Advert实体类中调用saveOrUpdate方法来进行保存或更新操作,避免了重复代码的出现,并且确保了并发安全。
@Data @AllArgsConstructor @NoArgsConstructor @Builder @Table(name = "media_file") public class MediaFile { /** * 主键 */ @Id @GeneratedValue(strategy = GenerationType.IDENTITY) @Column(name = "id") private Integer id; /** * 媒体文件名称 */ @Column(name = "name") @ApiModelProperty(value = "媒体文件名称") private String fileName; /** * 媒体文件类型:0-图片,1-视频 */ @Column(name = "type") @ApiModelProperty(value = "媒体文件类型") private Integer fileType; /** * 媒体文件URL地址 */ @Column(name = "url") @ApiModelProperty(value = "媒体文件URL地址") private String fileUrl; /** * 创建时间 */ @Column(name = "create_time") @ApiModelProperty(value = "创建时间") private Date createTime; /** * 更新时间 */ @Column(name = "update_time") @ApiModelProperty(value = "更新时间") private Date updateTime; @OneToMany(mappedBy = "mediaFile", cascade = CascadeType.ALL) private List<Advert> adverts = new ArrayList<>(); }与@Insert("insert into media_file(name, type, url) values (#{fileName}, #{fileType}, #{fileUrl})") @SelectKey(statement = "select last_insert_id()", keyProperty = "id", before = false, resultType = int.class) int insertAndGetId(MediaFile mediaFile);没有正确返回id
根据提供的代码,可能存在以下原因导致没有正确返回id:
1. 在插入数据时,没有设置id字段的值,而是使用了自增主键,因此需要在插入数据后使用@SelectKey来获取自增的id值。但是,可能存在无法正确获取自增id的情况,可以尝试检查数据库的设置是否正确或者修改@SelectKey的参数。
2. 在调用insertAndGetId方法时,没有正确传入MediaFile对象,导致无法正确插入数据或者获取id。可以尝试检查调用insertAndGetId方法时传入的MediaFile对象是否正确。
3. 在插入数据时,存在重复的name、type和url组合,导致无法插入或者获取id。可以尝试检查数据库中是否存在重复的数据记录。
阅读全文