有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

在WebFlux的Spring引导中,H2和R2DBC出现java列未找到错误

我使用WebFlux反应式模块、H2内存数据库和R2DBC反应式驱动程序创建了一个Java Spring引导服务。这在端口8081上构建并运行良好

我添加了一个模式。main/resources下的sql文件,其中包含以下内容:

CREATE TABLE contentitem ( contentItemId INT GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, localizedName VARCHAR(100) NOT NULL);

我用数据填充表格。同一目录中的sql文件:

INSERT INTO contentitem (contentItemId, localizedName) VALUES (0, 'Zero');
INSERT INTO contentitem (contentItemId, localizedName) VALUES (1, 'One');
INSERT INTO contentitem (contentItemId, localizedName) VALUES (2, 'Two');

我的ContentItem模型是:

@Data
@AllArgsConstructor
@NoArgsConstructor
@Table("contentitem")
public class ContentItem {
    @Id
    private Integer contentItemId;
    private String localizedName;

我的ContentItemController是:

@RestController
@RequestMapping("/contentItems")
public class ContentItemController {
    @Autowired
    private ContentItemService contentItemService;

    @GetMapping("/{contentItemId}")
    public Mono<ResponseEntity<ContentItem>> getContentItemByUserId(@PathVariable Integer contentItemId){
        Mono<ContentItem> contentItem = contentItemService.getContentItemById(contentItemId);
        return contentItem.map( u -> ResponseEntity.ok(u))
                .defaultIfEmpty(ResponseEntity.notFound().build());
    }

我的ContentItemService是:

@Service
@Slf4j
@Transactional
public class ContentItemService {

    @Autowired
    private ContentItemRepository contentItemRepository;

    public Mono<ContentItem> getContentItemById(Integer contentItemId){
        return contentItemRepository.findByContentItemId(contentItemId);
    }

}

我的ContentItemRepository是:

public interface ContentItemRepository extends ReactiveCrudRepository<ContentItem,Integer> {
    Mono<ContentItem> findByContentItemId(Integer contentItemId);
}

当我用http://localhost:8081/contentItems/1调用正在运行的服务时,我在get上得到一个500服务器错误,日志中有以下内容:

org.springframework.data.r2dbc.BadSqlGrammarException: executeMany; bad SQL grammar [SELECT contentitem.content_item_id, contentitem.localized_name FROM contentitem WHERE contentitem.content_item_id = $1]; nested exception is io.r2dbc.spi.R2dbcBadGrammarException: [42122] [42S22] Column "CONTENTITEM.CONTENT_ITEM_ID" not found; SQL statement:

几个问题:

  1. 为什么我的简单、明确、一致的列名(例如“contentItemId”)会被扭曲成带下划线的版本(例如“CONTENT_ITEM_ID”)?为了好玩,我尝试在“contentItemId”数据成员上方添加“@Column”(“content_item_id”)”注释,但得到了相同的结果
  2. 为什么找不到“contentItemId”(或“CONTENT_ITEM_ID”)列

更复杂的是,我在应用程序中启用了H2控制台。当我用http://localhost:8081/h2-console调用属性文件时,spring.h2.console.enabled=true的属性文件失败,出现404 Not Found错误


共 (1) 个答案

  1. # 1 楼答案

    您需要在实体类中使用列注释

    @Data
    @AllArgsConstructor
    @NoArgsConstructor
    @Table("contentitem")
    public class ContentItem {
        @Id
        @Column("contentItemId")
        private Integer contentItemId;
        @Column("localizedName")
        private String localizedName;
    }
    

    或者你应该用_来命名列

    CREATE TABLE contentitem ( content_item_id INT GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, localized_name VARCHAR(100) NOT NULL);