- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在设立一个 P.O.C.使用 Neo4j,并且技术上拥有我需要工作但希望其设置正确的一切。
作为快速概述 - 我可以创建节点和关系,并遍历图表(即返回特定市场中可用的所有功能),以便我知道这些节点/关系已创建。
但是,当我查询仅根据 ID 返回节点时,它仅返回该节点的数据 - 而不是任何关系或连接的节点,例如其可用的市场。
我在网上查看了很多地方,这些地方不仅返回了一个节点,而且还返回了后续节点 - 尽管我遵循他们正在做的事情,但我似乎无法让它与我的一起工作。
功能存储库:
@Repository
public interface FeatureRepository<T extends Feature> extends Neo4jRepository<T, Long> {
...
}
颜色存储库:
@Repository
public interface ColourRepository extends FeatureRepository<Colour>{
@Query("CREATE(feat:Colour:Feature {marketingDesc:{marketing}, engineeringDesc:{engineering}, code:{code}})")
Colour createColour(@Param("marketing") String marketingDesc, @Param("engineering") String engineeringDesc, @Param("code") String code);
@Query("MATCH (c:Colour {code:{colourCode}}) MATCH (c)-[:AVAILABLE_IN]->(market) RETURN c AS colour, COLLECT(market) AS markets")
Colour getColourByCode(@Param("colourCode") String colourCode);
Colour findByCode(@Param("code") String code);
}
功能实体:
@NodeEntity(label = "Feature")
@Getter
@Setter
@AllArgsConstructor
@NoArgsConstructor
public class Feature {
@Id
@GeneratedValue
private Long id;
private String marketingDesc;
private String engineeringDesc;
@Index(unique = true)
private String code;
@Relationship(type = "HAS_OPTION", direction = Relationship.INCOMING)
private List<Option> options = new ArrayList<>();
@Relationship(type = "AVAILABLE_IN")
private List<Market> markets = new ArrayList<>();
@Relationship(type = "HAS_PREREQUISITE", direction = Relationship.UNDIRECTED)
private List<Prerequisite> prerequisites = new ArrayList<>();
}
颜色实体:
@AllArgsConstructor
@NodeEntity(label = "Colour")
public class Colour extends Feature {
}
市场实体:
@NodeEntity(label = "Market")
@Getter
@Setter
@AllArgsConstructor
@NoArgsConstructor
public class Market {
@Id
@GeneratedValue
private Long id;
@Index(unique = true)
private String code;
private String market;
@Relationship(type = "AVAILABLE_IN", direction = Relationship.INCOMING)
private List<Option> features = new ArrayList<>();
}
关系实体(将功能连接到可以购买的市场):
@RelationshipEntity(type = "AVAILABLE_IN")
@Getter
@Setter
@AllArgsConstructor
@NoArgsConstructor
public class Available {
@Id
@GeneratedValue
private Long Id;
private List<String> availableIn = new ArrayList<>();
@StartNode
private Feature feature;
@EndNode
private Market market;
}
Controller :
@RestController
public class ConfigController {
private final Handler configHandler;
public ConfigController(Handler configHandler) {
this.configHandler = configHandler;
}
@PostMapping(path = "/create/colour", consumes = APPLICATION_JSON_VALUE, produces = APPLICATION_JSON_VALUE)
public SimpleResponse createColour(@RequestBody Colour request) {
ColourService service = new ColourService(configHandler);
Colour created = service.createColour(request);
return SimpleResponse.builder().result("Created:", created).build();
}
@PostMapping(path = "/create/market", consumes = APPLICATION_JSON_VALUE, produces = APPLICATION_JSON_VALUE)
public SimpleResponse createMarket(@RequestBody Market request) {
MarketService service = new MarketService(configHandler);
Market created = service.createMarket(request);
return SimpleResponse.builder().result("Created", created).build();
}
@PostMapping(path = "/create/relationship/availableIn", consumes = APPLICATION_JSON_VALUE, produces = APPLICATION_JSON_VALUE)
public SimpleResponse createAvailableInRelationship(@RequestBody OptionAvailInRequest request){
RelationshipService service = new RelationshipService(configHandler);
Object result = service.createAvailableInRelationship(request);
return SimpleResponse.builder().result("Result:", result).build();
}
@GetMapping(path = "/colour/{code}")
public SimpleResponse getColourByCode(@PathVariable(value = "code") String code) {
ColourService service = new ColourService(configHandler);
Colour colour = service.getColourByCode(code);
return SimpleResponse.builder().result("Colour:", colour).build();
}
@GetMapping(path = "/features/available/{mrktCode}")
public SimpleResponse getFeaturesInMarket(@PathVariable(value = "mrktCode") String mrktCode){
RelationshipService service = new RelationshipService(configHandler);
Collection<Feature> features = service.getFeaturesInMarket(mrktCode);
return SimpleResponse.builder().result("Features:", features).build();
}
}
Neo4j配置文件:
@Configuration
@EnableNeo4jRepositories(basePackages = "package.location")
@EnableTransactionManagement
public class Neo4jConfig {
@Bean
public org.neo4j.ogm.config.Configuration configuration() {
org.neo4j.ogm.config.Configuration configuration =
new org.neo4j.ogm.config.Configuration.Builder().build();
return configuration;
}
@Bean
public SessionFactory sessionFactory(org.neo4j.ogm.config.Configuration configuration) {
return new SessionFactory(configuration,"package.location");
}
@Bean
public Neo4jTransactionManager transactionManager(SessionFactory sessionFactory) {
return new Neo4jTransactionManager(sessionFactory);
}
}
例如,在这里我可以创建一个颜色节点:
示例值:
{
"code": "string",
"engineeringDesc": "string",
"id": 0,
"marketingDesc": "string",
"markets": [
{
"code": "string",
"features": [
{}
],
"id": 0,
"market": "string"
}
],
"options": [
{}
],
"prerequisites": [
{}
]
}
我发送的内容:
{
"code": "BLU",
"engineeringDesc": "Blue engineering",
"marketingDesc": "Blue marketing"
}
这样就成功创建了一个颜色节点:
{
"result": {
"Created:": {
"id": 0,
"marketingDesc": "Blue marketing",
"engineeringDesc": "Blue engineering",
"code": "BLU",
"options": [],
"markets": [],
"prerequisites": []
}
},
"error": null
}
我可以创建一个市场节点:示例值:
{
"code": "string",
"features": [
{}
],
"id": 0,
"market": "string"
}
我发送的内容:
{
"code": "UB",
"market": "England"
}
成功创建市场节点:
{
"result": {
"Created": {
"id": 1,
"code": "UB",
"market": "England",
"features": []
}
},
"error": null
}
然后我可以在两者之间创建关系,表示该颜色在该市场上可用:
{
"featureCode": "BLU",
"marketCode": "UB"
}
我可以通过点击以下命令来验证是否已创建:本地主机:8080/features/available/UB
{
"result": {
"Features:": [
{
"id": 0,
"marketingDesc": "Blue marketing",
"engineeringDesc": "Blue engineering",
"code": "BLU",
"options": [],
"markets": [],
"prerequisites": []
}
]
},
"error": null
}
但是,当我返回颜色节点本身时:本地主机:8080/颜色/BLU
{
"result": {
"Colour:": {
"id": 0,
"marketingDesc": "Blue marketing",
"engineeringDesc": "Blue engineering",
"code": "BLU",
"options": [],
"markets": [],
"prerequisites": []
}
},
"error": null
}
“市场”选项始终为空。我已经尝试过使用 Neo4j 帮助器(例如 findByCode 等)自定义查询和构建查询,我能找到的每个示例都会成功返回相关节点,但我似乎无法得到我的。
有人可以帮忙吗?附:如果还有其他内容对您有帮助,请告诉我。几天来一直试图解决这个问题......
最佳答案
找到了这个问题的答案...
功能实体应该是:
@Relationship(type = "AVAILABLE_IN")
@ApiModelProperty(hidden = true)
private Set<Available> markets = new HashSet<>();
市场实体应该是:
@Relationship(type = "AVAILABLE_IN", direction = Relationship.INCOMING)
@ApiModelProperty(hidden = true)
private Set<Available> features = new HashSet<>();
这使得 JSON 特征的市场部分不再为空...
现在我遇到的问题是,两个类之间存在无限递归循环,其中一个功能显示市场,而市场显示该功能
编辑:
对于遇到此/类似问题的其他人,我找到了一个非常好的 github 资源。 GitHub neo4j ogm walkthrough
帮助很大。
关于java - 从 neo4j 返回的 NodeEntity 不包含关系或连接的节点,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56884660/
在C语言中,当有变量(假设都是int)i小于j时,我们可以用等式 i^=j^=i^=j 交换两个变量的值。例如,令int i = 3,j = 5;在计算 i^=j^=i^=j 之后,我有 i = 5,
我为以下问题编写了以下代码: 给定一个由 N 个正整数组成的序列 A,编写一个程序来查找满足 i > A[j]A[i](A[i] 的 A[j] 次方 > A[j] 的 A[i] 次方)。 我的代码通过
这个表达式是从左到右解析的吗?我试图解释解析的结果,但最后的结果是错误的。 int j=10, k=10; j+=j-=j*=j; //j=j+(j-=j*=j)=j+(j-j*j) k+=k*=
给定一个整数数组 A ,我试图找出在给定位置 j ,A[j] 从每个 i=0 到 i=j 在 A 中出现了多少次。我设计了一个如下所示的解决方案 map CF[400005]; for(int i=0
你能帮我算法吗: 给定 2 个相同大小的数组 a[]和 b[]具有大于或等于 1 的整数。 查找不相等的索引 i和 j ( i != j ) 使得值 -max(a[i]*b[i] + a[i] * b
每次用J的M.副词,性能显着下降。因为我怀疑艾弗森和许比我聪明得多,我一定是做错了什么。 考虑 Collatz conjecture .这里似乎有各种各样的内存机会,但不管我放在哪里M. ,性能太差了
假设一个包含各种类型的盒装矩阵: matrix =: ('abc';'defgh';23),:('foo';'bar';45) matrix +---+-----+--+|abc|defgh|23|+
是否有可能对于两个正整数 i 和 j,(-i)/j 不等于 -(i/j)?我不知道这是否可能......我认为这将是关于位的东西,或者 char 类型的溢出或其他东西,但我找不到它。有什么想法吗? 最
假设两个不同大小的数组: N0 =: i. 50 N1 =: i. 500 应该有一种方法可以获得唯一的对,只需将两者结合起来即可。我发现的“最简单”是: ]$R =: |:,"2 |: (,.N0)
我是 J 的新用户,我只是想知道 J 包中是否实现了三次样条插值方法? 最佳答案 我自己不熟悉,但是我确实安装了所有的包,所以 $ rg -l -i spline /usr/share/j/9.02
在 Q/kdb 中,您可以使用 ': 轻松修改动词,它代表每个优先级。它会将动词应用于一个元素及其之前的邻居。例如 =': 检查值对是否相等。在 J 中,您可以轻松折叠 /\ 但它是累积的,是否有成对
嗨,我有一个 4x4 双矩阵 A 1+2i 2-1i -3-2i -1+4i 3-1i -3+2i 1-3i -1-3i 4+3i 3+5i 1-2i -1-4i
刚刚发现 J 语言,我输入: 1+^o.*0j1 I expected the answer to be 0 ,但我得到了 0j1.22465e_16。虽然这非常接近于 0,但我想知道为什么 J 应该
这个问题在这里已经有了答案: With arrays, why is it the case that a[5] == 5[a]? (20 个答案) 关闭 3 年前。 我正在阅读“C++ 编程语言”
当第一行是 1, 1/2 , 1/3 ....这是支持该问题的图像。 是否存在比朴素的 O(n^2) 方法更有效的方法? 我在研究伯努利数时遇到了这个问题,然后在研究“Akiyama-Tanigawa
我写了一段Java代码,它在无限循环中运行。 下面是代码: public class TestProgram { public static void main(String[] args){
for (int i = n; i > 0; i /= 2) { for (int j = 0; j 0; i /= 2) 的第一个循环结果 O(log N) . 第二个循环for (int
如问题中所述,需要找到数组中 (i,j) 对的总数,使得 (1) **ia[j]** 其中 i 和 j 是数组的索引。没有空间限制。 我的问题是 1) Is there any approach w
for l in range(1,len(S)-1): for i in range(1,len(S)-l): j=i+l for X in N:
第二个for循环的复杂度是多少?会是n-i吗?根据我的理解,第一个 for 循环将执行 n 次,但第二个 for 循环中的索引设置为 i。 //where n is the number elemen
我是一名优秀的程序员,十分优秀!