การใช้งานทั่วไปของแหล่งเก็บข้อมูล DDD ดูไม่ OO มากเช่นsave()
วิธีการ:
package com.example.domain;
public class Product { /* public attributes for brevity */
public String name;
public Double price;
}
public interface ProductRepo {
void save(Product product);
}
ส่วนโครงสร้างพื้นฐาน:
package com.example.infrastructure;
// imports...
public class JdbcProductRepo implements ProductRepo {
private JdbcTemplate = ...
public void save(Product product) {
JdbcTemplate.update("INSERT INTO product (name, price) VALUES (?, ?)",
product.name, product.price);
}
}
อินเทอร์เฟซดังกล่าวคาดว่าProduct
จะเป็นรูปแบบของโลหิตจางอย่างน้อยก็ด้วย getters
ในทางตรงกันข้าม OOP บอกว่าProduct
วัตถุควรรู้วิธีการบันทึกตัวเอง
package com.example.domain;
public class Product {
private String name;
private Double price;
void save() {
// save the product
// ???
}
}
สิ่งคือเมื่อProduct
รู้วิธีการบันทึกตัวเองก็หมายความว่ารหัสโครงสร้างไม่ได้แยกออกจากรหัสโดเมน
บางทีเราสามารถมอบหมายการบันทึกไปยังวัตถุอื่น:
package com.example.domain;
public class Product {
private String name;
private Double price;
void save(Storage storage) {
storage
.with("name", this.name)
.with("price", this.price)
.save();
}
}
public interface Storage {
Storage with(String name, Object value);
void save();
}
ส่วนโครงสร้างพื้นฐาน:
package com.example.infrastructure;
// imports...
public class JdbcProductRepo implements ProductRepo {
public void save(Product product) {
product.save(new JdbcStorage());
}
}
class JdbcStorage implements Storage {
private final JdbcTemplate = ...
private final Map<String, Object> attrs = new HashMap<>();
private final String tableName;
public JdbcStorage(String tableName) {
this.tableName = tableName;
}
public Storage with(String name, Object value) {
attrs.put(name, value);
}
public void save() {
JdbcTemplate.update("INSERT INTO " + tableName + " (name, price) VALUES (?, ?)",
attrs.get("name"), attrs.get("price"));
}
}
อะไรคือวิธีที่ดีที่สุดในการบรรลุเป้าหมายนี้? เป็นไปได้หรือไม่ที่จะใช้พื้นที่เก็บข้อมูลเชิงวัตถุ?