Spring Data MongoDB 环境搭建详解大数据
2023-06-13 09:20:27 时间
使用Maven管理jar包
project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd" modelVersion 4.0.0 /modelVersion groupId mongos /groupId artifactId mongos /artifactId packaging jar /packaging version 0.0.1-SNAPSHOT /version name mongos /name url http://maven.apache.org /url properties org.springframework-version 4.0.6.RELEASE /org.springframework-version org.hibernate-version 4.3.1.Final /org.hibernate-version project.build.sourceEncoding UTF-8 /project.build.sourceEncoding /properties dependencies !-- mongodb spring -- dependency groupId org.springframework.data /groupId artifactId spring-data-mongodb /artifactId version 1.4.1.RELEASE /version /dependency dependency groupId org.springframework.data /groupId artifactId spring-data-commons-core /artifactId version 1.4.1.RELEASE /version /dependency !-- spring jar -- dependency groupId org.springframework /groupId artifactId spring-core /artifactId version ${org.springframework-version} /version /dependency dependency groupId org.springframework /groupId artifactId spring-context /artifactId version ${org.springframework-version} /version !-- Exclude Commons Logging in favor of SLF4j -- exclusions exclusion groupId commons-logging /groupId artifactId commons-logging /artifactId /exclusion /exclusions /dependency dependency groupId org.springframework /groupId artifactId spring-context-support /artifactId version ${org.springframework-version} /version /dependency dependency groupId org.springframework /groupId artifactId spring-test /artifactId version ${org.springframework-version} /version /dependency dependency groupId org.springframework /groupId artifactId spring-aop /artifactId version ${org.springframework-version} /version /dependency dependency groupId org.springframework /groupId artifactId spring-beans /artifactId version ${org.springframework-version} /version /dependency dependency groupId org.springframework /groupId artifactId spring-orm /artifactId version ${org.springframework-version} /version /dependency dependency groupId org.springframework /groupId artifactId spring-aspects /artifactId version ${org.springframework-version} /version /dependency dependency groupId org.springframework /groupId artifactId spring-webmvc /artifactId version ${org.springframework-version} /version /dependency dependency groupId org.springframework /groupId artifactId spring-tx /artifactId version ${org.springframework-version} /version /dependency dependency groupId org.springframework /groupId artifactId spring-web /artifactId version ${org.springframework-version} /version /dependency !-- hiberante 4 -- dependency groupId org.hibernate /groupId artifactId hibernate-core /artifactId version ${org.hibernate-version} /version /dependency dependency groupId org.hibernate /groupId artifactId hibernate-validator /artifactId version ${org.hibernate-version} /version /dependency dependency groupId javax.validation /groupId artifactId validation-api /artifactId version 1.0.0.GA /version scope provided /scope /dependency dependency groupId org.hibernate /groupId artifactId hibernate-entitymanager /artifactId version ${org.hibernate-version} /version /dependency dependency groupId org.apache.commons /groupId artifactId commons-dbcp2 /artifactId version 2.0.1 /version /dependency dependency groupId org.slf4j /groupId artifactId slf4j-log4j12 /artifactId version 1.6.1 /version /dependency dependency groupId log4j /groupId artifactId log4j /artifactId version 1.2.17 /version /dependency dependency groupId junit /groupId artifactId junit /artifactId version 4.11 /version scope test /scope /dependency dependency groupId com.google.code.gson /groupId artifactId gson /artifactId version 2.2.4 /version /dependency dependency groupId javax.servlet /groupId artifactId javax.servlet-api /artifactId version 3.0.1 /version scope provided /scope /dependency !-- jackson -- dependency groupId com.fasterxml.jackson.core /groupId artifactId jackson-core /artifactId version 2.1.0 /version /dependency dependency groupId com.fasterxml.jackson.core /groupId artifactId jackson-databind /artifactId version 2.1.0 /version /dependency dependency groupId com.fasterxml.jackson.core /groupId artifactId jackson-annotations /artifactId version 2.1.0 /version /dependency dependency groupId cglib /groupId artifactId cglib-nodep /artifactId version 2.2.2 /version /dependency dependency groupId javax.servlet.jsp.jstl /groupId artifactId jstl-api /artifactId version 1.2 /version /dependency /dependencies build finalName mongos /finalName /build /project三、db.xml
spring mongodb 核心配置
?xml version="1.0" encoding="UTF-8"? beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p" xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx" xmlns:mongo="http://www.springframework.org/schema/data/mongo" xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tool="http://www.springframework.org/schema/tool" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.0.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.0.xsd http://www.springframework.org/schema/tool http://www.springframework.org/schema/tool/spring-tool-4.0.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd http://www.springframework.org/schema/data/mongo http://www.springframework.org/schema/data/mongo/spring-mongo-1.0.xsd" !-- context:property-placeholder location="classpath:sysconfig/properties/mongodb.properties" / !-- 定义mongo对象,对应的是mongodb官方jar包中的Mongo,replica-set设置集群副本的ip地址和端口 -- mongo:mongo id="mongo" host="127.0.0.1" port="27017" !-- 一些连接属性的设置 -- mongo:options connections-per-host="8" threads-allowed-to-block-for-connection-multiplier="4" connect-timeout="1000" max-wait-time="1500" auto-connect-retry="true" socket-keep-alive="true" socket-timeout="1500" slave-ok="true" write-number="1" write-timeout="0" write-fsync="true" / /mongo:mongo !-- mongo的工厂,通过它来取得mongo实例,dbname为mongodb的数据库名,没有的话会自动创建 -- mongo:db-factory id="mongoDbFactory" dbname="mydb" mongo-ref="mongo" / !-- 映射转换器,扫描back-package目录下的文件,根据注释,把它们作为mongodb的一个collection的映射 -- mongo:mapping-converter base-package="com.ithome.bean" id="mongoConverter" / !-- mongodb的主要操作对象,所有对mongodb的增删改查的操作都是通过它完成 -- bean id="mongoTemplate" constructor-arg name="mongoDbFactory" ref="mongoDbFactory" / constructor-arg name="mongoConverter" ref="mongoConverter" / /bean !-- mongodb bean的仓库目录,会自动扫描扩展了MongoRepository接口的接口进行注入 -- mongo:repositories base-package="com.ithome.bean" / bean id="personDao" property name="mongoTemplate" ref="mongoTemplate" / /bean /beans四、实体 Bean
import java.io.Serializable; public class Person implements Serializable { private static final long serialVersionUID = 1L; private String id; private String name; // 姓名 private String sex; // 性别 private String idCard; // 身份证号码 private String note; // 备注 /** * 省略 set() get() }五、接口 PersonDao
import java.util.List; import com.ithome.bean.Person; public interface PersonDao { /** * 插入数据 * @param u public void insert(Person u); /** * 查询全部 * @return public List Person queryAll(); }六、接口实现 PersonDaoImpl
import java.util.List; import org.springframework.data.mongodb.core.MongoOperations; import org.springframework.stereotype.Repository; import com.ithome.bean.Person; import com.ithome.dao.PersonDao; @Repository public class PersonDaoImpl implements PersonDao { private MongoOperations mongoTemplate; public void setMongoTemplate(MongoOperations mongoTemplate) { this.mongoTemplate = mongoTemplate; @Override public void insert(Person u) { mongoTemplate.insert(u); @Override public List Person queryAll() { List Person user = mongoTemplate.findAll(Person.class); return user; }七、测试类
import java.util.List; import org.junit.BeforeClass; import org.junit.Test; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.test.context.ContextConfiguration; import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; import com.ithome.bean.Person; import com.ithome.dao.PersonDao; @org.junit.runner.RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(locations = { "classpath:db.xml" }) public class PersonTest { @BeforeClass public static void setUpBeforeClass() throws Exception { @Autowired public PersonDao personDao; @Test public void insert() { Person person = new Person(); person.setName("zhangsan"); person.setSex("男"); person.setIdCard("110112100589911"); person.setNote("无"); personDao.insert(person); @Test public void getAll() { List Person list = personDao.queryAll(); for (Person p : list) { System.out.println("ID: " + p.getId() + " 姓名:" + p.getName()); }
原创文章,作者:Maggie-Hunter,如若转载,请注明出处:https://blog.ytso.com/9660.html
分布式文件系统,分布式数据库区块链并行处理(MPP)数据库,数据挖掘开源大数据平台数据中台数据分析数据开发数据治理数据湖数据采集相关文章
- Spring Data MongoDB 分页查询详解大数据
- MongoDB:注释技巧分享(mongodb注释)
- MongoDB 配置最佳均衡器实现最佳性能(mongodb均衡器)
- MongoDB:为数据存储带来全新时代(mongoDB后缀)
- Spring update方法:更新指定的实体对象
- 取数据MongoDB:如何获取数据(mongodb怎么读)
- 构建云上MongoDB数据库,开创更简单的数据航程(云数据库mongodb)
- MongoDB数据挖掘:挖掘高效可靠的数据(mongodb数据挖掘)
- 索引MongoDB中的多边形索引:原理及其应用(mongodb多边形)
- 使用 MongoDB实现分组数据查询(mongodb分组查询)
- 据访问利用MongoDB实现安全高效的并发数据访问(mongodb并发数)
- MongoDB:如何删除数据(mongodb删除数据)
- MongoDB极速合并数据实现快速分析(mongodb数据合并)
- MongoDB:从数据损坏中恢复(mongodb数据恢复)
- MongoDB索引:提高性能的关键步骤(mongodb索引)
- 使用MongoDB测试工具提高开发效率和数据质量(mongodb测试工具)
- 使用MongoDB创建高效表格(mongodb创建表)
- 深入探究MongoDB的统计功能,实现数据分析的高效管控(mongodb统计)
- MongoDB用户权限: 安全授权数据访问(mongodb给用户权限)
- 利用mongodump工具导出MongoDB数据的快速指南(导出mongodb数据)
- 树莓派上安装 MongoDB:简单又实用(树莓派安装mongodb)
- Mongodb异步: 改善数据读写效率的有效方法(mongodb异步)
- Mongodb解决中文乱码问题的方法详解(mongodb中文乱码)
- MongoDB:开启新的数据链接之旅(mongodb链接)
- MongoDB:实现数据拷贝的最佳方法(mongodb拷贝)