我正在编写简单的CRUD应用程序,该应用程序将从database提取人的记录,而我正在使用SparkJava框架,但我有工作代码可以从database提取记录,但是我会要提取JOOQ DSLContext代码并将其作为Bean注入并在另一个类中对其进行初始化,以获取更简洁的代码,但是我不确定如何实现它,这是当前的主要方法一切:
public static void main(String[] args) throws IOException {
final BasicDataSource ds = new BasicDataSource();
final Properties properties = new Properties();
properties.load(BankApiApplication.class.getResourceAsStream("/application.properties"));
ds.setDriverClassName(properties.getProperty("db.driver"));
ds.setUrl(properties.getProperty("db.url"));
ds.setUsername(properties.getProperty("db.username"));
ds.setPassword(properties.getProperty("db.password"));
final ConnectionProvider cp = new DataSourceConnectionProvider(ds);
final Configuration configuration = new DefaultConfiguration()
.set(cp)
.set(SQLDialect.H2)
.set(new ThreadLocalTransactionProvider(cp, true));
final DSLContext ctx = DSL.using(configuration);
final JSONFormat format = new JSONFormat().format(true).header(false).recordFormat(JSONFormat.RecordFormat.OBJECT);
port(8080);
get("/persons", (request, response) -> {
return ctx.select().from(Person.PERSON).fetch().formatJSON();
});
}
如何提取初始化Datasource并配置DSLContext的代码,取而代之的是我只注入DSLContext或某种DSLContextHolder并进行查询?
因此,通常,您要注入您可以使用的最高级别的对象。这与the Law of Demeter有关,简而言之,即组件可以知道其直接依赖关系,但不应该知道那些依赖关系的依赖关系。
在您的情况下,您实际上仅使用DSLContext
(ctx
)。 [这里的注释:您的代码有很多两个字母的名称-很难遵循。如果您写出例如ctx -> dslContext
,cp -> connectionProvider
。这意味着您实际上只希望您的方法知道DSLContext
,而不是其依赖性。因此,最好将以下内容放入模块中,然后注入just a DSLContext
:
Configuration
ConnectionProvider
Properties
BasicDataSource
如果仅在main()
中使用所有这些内容,则可以编写单个Provider
以返回DSLContext
。如果其中一些在多个地方使用(除了实例化此main()
的DSLContext
),那么它们可以使用自己的Provider
。例如,如果将Provider
放置在其自己的DSLContext
中,则Configuration
的Provider
外观如下所示:
public class MyModule extends AbstractModule {
// other providers
// ...
@Provides
@Singleton
public DSLContext dslContext(Configuration configuration) {
return SL.using(configuration);
}
}
然后在main()
中输入:
Injector injector = Guice.createInjector(yourModule());
DSLContext myContext = injector.getInstance(DSLContext.class);
// ... use it