【MongoDB】spring-data-mongo配置
admin
2023-02-06 11:00:03
0
  • config.properties

#mongodb setting
mongo.host=127.0.0.1
mongo.port=27017
mongo.connectionsPerHost=100
mongo.threadsAllowedToBlockForConnectionMultiplier=50
mongo.connectTimeout=1000
mongo.maxWaitTime=1500
mongo.autoConnectRetry=true
mongo.socketKeepAlive=true
mongo.socketTimeout=0
mongo.slaveOk=true


  • spring_mongo.xml






	

















	
	







  • entity

@Document(collection = "user")
public class User 
{
	@Id
	private int id;
	private String name;
	private int age;
	private String city;
	private String mote;
	
	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public int getAge() {
		return age;
	}
	public void setAge(int age) {
		this.age = age;
	}
	public String getCity() {
		return city;
	}
	public void setCity(String city) {
		this.city = city;
	}
	public String getMote() {
		return mote;
	}
	public void setMote(String mote) {
		this.mote = mote;
	}
	
}


  • dao配置

public interface MGUserDao extends MongoRepository
{
	/**
	 * 方法名的严格遵守规定
	 * @param age
	 * @param page
	 * @return
	 */
	public Page findByAgeGreaterThan(int age, Pageable page);
	
	/**
	 * 有@Query声明查询, 方法名不需要严格遵守规定
	 * @param name
	 * @param ageFrom
	 * @param ageTo
	 * @param pageable
	 * @return
	 */
	@Query("{'name':{'$regex':?0}, 'age': {'$gte':?1,'$lte':?2}}")
	public Page findByNameAndAgeRange(String name, int ageFrom, int ageTo, Pageable pageable);
	
	@Query("{?0:?1}")
	public List findByAttribute(String key, String value);
}


  • dao层的使用

    MongoRepository实现了的只是最基本的增删改查的功能,要想增加额外的查询方法,可以按照以下规则定义接口的方法。自定义查询方法,格式为“findBy+字段名+方法后缀”,方法传进的参数即字段的值,此外还支持分页查询,通过传进一个Pageable对象,返回Page集合。 例如:

//查询大于age的数据 
public Page findByAgeGreaterThan(int age,Pageable page) ;

    

    下面是支持的查询类型,每三条数据分别对应:(方法后缀,方法例子,mongodb原生查询语句)

GreaterThan(大于) 
findByAgeGreaterThan(int age) 
{"age" : {"$gt" : age}}

LessThan(小于) 
findByAgeLessThan(int age) 
{"age" : {"$lt" : age}}

Between(在...之间) 
findByAgeBetween(int from, int to) 
{"age" : {"$gt" : from, "$lt" : to}}

IsNotNull, NotNull(是否非空) 
findByFirstnameNotNull() 
{"age" : {"$ne" : null}}

IsNull, Null(是否为空) 
findByFirstnameNull() 
{"age" : null}

Like(模糊查询) 
findByFirstnameLike(String name) 
{"age" : age} ( age as regex)

(No keyword) findByFirstname(String name) 
{"age" : name}

Not(不包含) 
findByFirstnameNot(String name) 
{"age" : {"$ne" : name}}

Near(查询地理位置相近的) 
findByLocationNear(Point point) 
{"location" : {"$near" : [x,y]}}

Within(在地理位置范围内的) 
findByLocationWithin(Circle circle) 
{"location" : {"$within" : {"$center" : [ [x, y], distance]}}}

Within(在地理位置范围内的) 
findByLocationWithin(Box box) 
{"location" : {"$within" : {"$box" : [ [x1, y1], x2, y2]}}}


    尽管以上查询功能已经很丰富,但如果还不能满足使用情况的话可以用一下方法---基于mongodb原本查询语句的查询方式。

    例一:在原接口中加入,注释Query里面的就是mongodb原来的查询语法,我们可以定义传进来的查询参数,通过坐标定义方法的参数。

@Query("{ 'name':{'$regex':?2,'$options':'i'}, sales': {'$gte':?1,'$lte':?2}}")
public Page findByNameAndAgeRange(String name,double ageFrom,double ageTo,Pageable page);

    例二:还可以在后面指定要返回的数据字段,如上面的例子修改如下,则只通过person表里面的name和age字段构建person对象。

@Query(value="{ 'name':{'$regex':?2,'$options':'i'}, sales':{'$gte':?1,'$lte':?2}}",fields="{ 'name' : 1, 'age' : 1}") 
public Page findByNameAndAgeRange(String name,double ageFrom,double ageTo,Pageable page);


相关内容

热门资讯

玩家攻略科普“大师棋牌开挂器”... 网上科普关于“大师棋牌有没有挂”话题很是火热,小编也是针对大师棋牌作*弊开挂的方法以及开挂对应的知识...
【今日要闻】“顺欣茶坊有挂吗”... 有 亲,根据资深记者爆料顺欣茶坊是可以开挂的,确实有挂(咨询软件无需打开...
玩家攻略科普“红豆牛牛到底有挂... 有 亲,根据资深记者爆料红豆牛牛是可以开挂的,确实有挂(咨询软件无需打开...
玩家最新攻略“九九牌游十三水有... 有 亲,根据资深记者爆料九九牌游十三水是可以开挂的,确实有挂(咨询软件无...
今日重大消息“人海炸/金/花开... 今日重大消息“人海炸/金/花开挂器”外卦神器下载您好,人海炸/金/花这个游戏其实有挂的,确实是有挂的...
台媒:台立法机构确认“赖清德弹... 【环球网报道 记者 徐思琦】据台湾中时新闻网报道,台立法院机构启动“赖清德弹劾案”,1月14日、15...
【第一资讯】“喜扣游戏到底有挂... 您好:喜扣游戏这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在这款游戏...
今日重大发现“科乐麻将究竟有挂... 您好:科乐麻将这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在这款游戏...
终于明白“湘乐究竟有挂吗”外卦... 家人们!今天小编来为大家解答湘乐透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪里买很多人...
原创 国... 今年国内车企最关键的任务就是让固态电池量产上车,这样才能在未来几年站稳脚跟,大家都清楚,电动车行业的...