java - JOOQ Cast String to Enum 使用转换器内联

标签 java sql-server enums jooq

如这里所问,后续问题 #58538732

按照 Lukas Eder 的建议,我编写了一个 EnumConverterInteger 转换为 DayOfWeek

public class DOWConverter extends EnumConverter<Integer, DayOfWeek>  {

    public DOWConverter()
    {
        super(Integer.class, DayOfWeek.class);           
    }               
}

select 现在看起来如下

DataType<DayOfWeek> typeDOW = SQLDataType.INTEGER.asConvertedDataType(new DOWConverter() /*ERROR*/);
Field<DayOfWeek> fieldDOW = DSL.field("{0}", typeDOW, lecture.DAY_OF_WEEK);

create.select( ..., fieldDOW, ...)...

错误信息:

Exception in thread "main" java.lang.Error: Unresolved compilation problem:
No enclosing instance of type QueryFeaturesTask is accessible. Must qualify the allocation with an enclosing instance of type QueryFeaturesTask (e.g. x.new A() where x is an instance of QueryFeaturesTask).

如前所述,在 CodeGen 时间使用转换器目前不是一种选择。

最佳答案

您似乎将DOWConverter 放在了另一个类中,从而创建了一个inner class。 .我建议您将转换器放在顶层,放在它自己的文件中,使其成为顶级类。如果必须创建嵌套类,请通过将其设为静态来确保它不是内部类:

public class Enclosing {
    // Make this class here static:
    public static class DOWConverter extends EnumConverter<Integer, DayOfWeek> {
        public DOWConverter() {
            super(Integer.class, DayOfWeek.class);           
        }               
    }
}

Oracle's tutorial on nested classes explains this really well .

关于java - JOOQ Cast String to Enum 使用转换器内联,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58586868/

相关文章:

java - 软件良好实践 - 设置和获取方法

java - Flexjson 中的 ConcurrentModificationException

sql - Microsoft SQL 计数问题

sql - 如何在SQL Server中查找字符串是否以数字和括号开头?

ruby-on-rails - Rails 5 - 使用枚举,当枚举值是保留字时怎么办?

java - ProGuard 避免接口(interface)实现的混淆

java - 使用基于 Grails JAX-RS 插件的 RESTful API 上传文件

sql 选择计数 > 1 的记录,其中至少一条记录具有值

c# - 提供的类型必须是枚举

java - 带有美元符号和数字 .class 的 java 文件名是什么意思 (name$1.class)?