project-neo4j
一、功能介绍:
-
连接mysql、neo4j,实现将mysql数据插入neo4j中!
-
对neo4j数据进行增删改查,统计分析、关系遍历等功能 !
二、JAR说明:
-
springboot【1.5.9】
-
pring-boot-starter-data-neo4j【4.2.9】
-
mybatis-spring-boot-starter【1.3.1】
-
mapper-spring-boot-starter【1.1.4】
-
pagehelper-spring-boot-starter【1.2.1】
-
druid-spring-boot-starter【1.1.0】
-
fastjson【1.2.12】
-
com.google.guava【19.0】
三、部署说明
-
下载neo4j安装程序
http://download.csdn.net/download/npf_java/10197711 -
创建mysql数据库
a)运行opensearch.sql脚本创建数据库
b)通过navicat工具初始化数据,还原180118183225.psc文件 -
将mysql数据导入neo4j中
执行junit测试类KeyWordTest中的addKeyWordNode、addNewsNode方法
四、更新说明
2018-01-24(统计)
2018-01-23(D3.js实现页面效果展示)
建议使用D3.js作为前端展示效果 (Neo4j内置的页面展示使用的是D3.js库)
-
【D3.js官网】
-
https://d3js.org/
-
-
【D3.js中文实例、API】
-
https://github.com/d3/d3/wiki/CN-Home
-
-
【D3.js[2.5.0] 学习网站】
-
http://www.ourd3js.com/wordpress/category/data-driven-documents/
-
-
【D3.js[4.12.2] 力导向图的制作】
-
https://github.com/d3/d3-force
-
https://bl.ocks.org/mbostock/9a8124ccde3a4e9625bc413b48f14b30
-
-
【springBoot thymeleaf模板】
-
http://jisonami.iteye.com/blog/2301387
-
-
Maven的资源文件目录:/src/java/resources
-
spring-boot项目静态文件目录:/src/java/resources/static
-
spring-boot项目模板文件目录:/src/java/resources/templates
-
spring-boot静态首页的支持,即index.html放在以下目录结构会直接映射到应用的根目录下:
-
classpath:/META-INF/resources/index.html
-
classpath:/resources/index.html
-
classpath:/static/index.html
-
calsspath:/public/index.html
2018-01-18(框架初步完成,初始化提交)
-
初始化提交项目相关代码
-
通过KeyWordTest类可以将mysql数据库中的keyword和news数据导入neo4j中
-
/**
-
* 包名:com.dbs.test.mysql
-
* 功能:TODO 对关键字进行提取
-
* 作者:hualn
-
* 日期:2018年1月18日 下午4:25:02
-
*/
-
@RunWith(SpringJUnit4ClassRunner.class)
-
@SpringBootTest(classes = Neo4jApplication.class)
-
public class KeyWordTest {
-
-
private Logger logger = LoggerFactory.getLogger(getClass());
-
-
/**
-
* 关键字操作类
-
*/
-
@Autowired
-
private KeyWordRepository keyWordRepository;
-
-
/**
-
* 新闻操作类
-
*/
-
@Autowired
-
private NewsRepository newsRepository;
-
-
/**
-
* mysql--JDBC连接
-
*/
-
@Autowired
-
private JdbcTemplate jdbcTemplate;
-
-
/**
-
* 将keyWord关键字全部抽取到neo4j中
-
*/
-
@Test
-
public void addKeyWordNode(){
-
String keySql = "select t.AIRCRAFT from news_keyword t group by t.AIRCRAFT ";
-
-
List
<Map<String, Object>> keyList = jdbcTemplate.queryForList(keySql);
-
-
for (Map
<String, Object> obj : keyList) {
-
String keyword = obj.get("AIRCRAFT").toString();
-
if(StringUtils.isNotBlank(keyword)){
-
keyWordRepository.save(new KeyWord(keyword));
-
}
-
}
-
-
logger.info("******************共导入关键字("+keyList.size()+")个***********************");
-
-
}
-
-
/**
-
* 将新闻节点全部抽取到neo4j中
-
*/
-
@Test
-
public void addNewsNode(){
-
String newsSql = "select n.TITLE,max(t.AIRCRAFT) keyword from news_keyword t
-
left join datasource_new n on t.NEWID = n.ID GROUP BY n.TITLE ";
-
-
List
<Map<String, Object>> newsList = jdbcTemplate.queryForList(newsSql);
-
-
//新闻类
-
News news= null;
-
//关键字
-
KeyWord keyWord = null;
-
for (Map
<String, Object> obj : newsList) {
-
String title = obj.get("TITLE").toString();
-
String keyword = obj.get("KEYWORD").toString();
-
-
news = new News(title);
-
keyWord = keyWordRepository.findByName(keyword);
-
news.setKeywords(Lists.newArrayList(keyWord));
-
newsRepository.save(news);
-
}
-
-
}
-
-
}
-
2018-01-15------>2018-01-17(框架搭建中)
- 学习Neo4j推荐书籍
《Neo4j权威指南 图数据库 大数据时代的新利器》
- 参考网站
-
【官网】
-
https://neo4j.com/
-
-
【Neo4j 图数据库在社交网络等领域的应用】 **(重点看)**
-
http://gitbook.cn/books/5a33782c5778440a9d906017/index.html
- 实例学习
-
【中文学习教程】https://www.w3cschool.cn/neo4j/
-
-
【英文学习教程】https://neo4j.com/graphgists/?category=sports-and-recreation
- 安装
-
Neo4j 下载地址:https://neo4j.com/download/other-releases/
-
-
【Neo4j 第一篇:在Windows环境中安装Neo4j】
-
https://www.cnblogs.com/ljhdo/archive/2017/05/19/5521577.html
-
- 效果展示
-
搜狗人物搜索 https://www.sogou.com/tupu/person.html?q=姚明
-
-
搜索引擎和知识图谱那些事 http://blog.csdn.net/eastmount/article/details/46874155
- Java操作neo4j
-
http://bboyjing.github.io/2016/07/15/Neo4j学习笔记九【Spring-Data-Neo4j】/
-
-
https://github.com/bboyjing/neo4j_sample
-
-
【springboot和neo4j的集成】
-
https://www.jianshu.com/p/33d50fac06b4
-
-
-
【官网API】
-
https://docs.spring.io/spring-data/neo4j/docs/4.2.9.RELEASE/reference/html/
-
https://docs.spring.io/spring-data/neo4j/docs/4.2.9.RELEASE/api/
-
-
【github相关demo】
-
https://github.com/neo4j-examples/
-
https://github.com/neo4j-examples/movies-java-spring-data-neo4j
-
https://github.com/neo4j-examples/neo4j-sdn-ogm-issue-report-template