亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

mongo數(shù)據(jù)集合屬性中存在點(diǎn)號(hào)(.)的解決方法

 更新時(shí)間:2018年10月10日 10:50:37   作者:雞犬相聞  
這篇文章主要給大家介紹了關(guān)于mongo數(shù)據(jù)集合屬性中存在點(diǎn)號(hào)(.)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

前言

MongoDB是面向集合存儲(chǔ)的文檔型數(shù)據(jù)庫(kù),其涉及到的基本概念與關(guān)系型數(shù)據(jù)庫(kù)比有所不同。本文主要介紹關(guān)于mongo數(shù)據(jù)集合屬性存在點(diǎn)號(hào)(.)的相關(guān)內(nèi)容,下面話不多說(shuō)了,來(lái)一起看看詳細(xì)的介紹吧

基本知識(shí)點(diǎn):

1.似乎mongo3.6之前不允許插入帶點(diǎn)(.)或美元符號(hào)($)的鍵,但是當(dāng)我使用mongoimport工具導(dǎo)入包含點(diǎn)的JSON文件時(shí),它工作正常。

2.在使用spring-data-mongodb處理mongodb的增刪改查時(shí)會(huì)通過(guò)一個(gè)MappingMongoConverter(Document和Modle轉(zhuǎn)換類)轉(zhuǎn)換數(shù)據(jù)

3.具體對(duì)點(diǎn)號(hào)的轉(zhuǎn)換在DBObjectAccessor(spring-data-mongodb-1.10.13)或者DocumentAccessor(spring-data-mongodb-2.0.9),如下:

//插入時(shí)轉(zhuǎn)換
public void put(MongoPersistentProperty prop, Object value) {
 Assert.notNull(prop, "MongoPersistentProperty must not be null!");
 String fieldName = prop.getFieldName();
 if (!fieldName.contains(".")) {
  dbObject.put(fieldName, value);
  return;
 }
 Iterator<String> parts = Arrays.asList(fieldName.split("\\.")).iterator();
 DBObject dbObject = this.dbObject;
 while (parts.hasNext()) {
  String part = parts.next();
  if (parts.hasNext()) {
   dbObject = getOrCreateNestedDbObject(part, dbObject);
  } else {
   dbObject.put(part, value);
  }
 }
}

//查詢時(shí)轉(zhuǎn)換
public Object get(MongoPersistentProperty property) {
 String fieldName = property.getFieldName();
 if (!fieldName.contains(".")) {
  return this.dbObject.get(fieldName);
 }
 Iterator<String> parts = Arrays.asList(fieldName.split("\\.")).iterator();
 Map<String, Object> source = this.dbObject;
 Object result = null;
 while (source != null && parts.hasNext()) {
  result = source.get(parts.next());
  if (parts.hasNext()) {
   source = getAsMap(result);
  }
 }
 return result;
}

//判斷值是否為空
public boolean hasValue(MongoPersistentProperty property) {
 Assert.notNull(property, "Property must not be null!");
 String fieldName = property.getFieldName();
 if (!fieldName.contains(".")) {
  return this.dbObject.containsField(fieldName);
 }
 String[] parts = fieldName.split("\\.");
 Map<String, Object> source = this.dbObject;
 Object result = null;
 for (int i = 1; i < parts.length; i++) {
  result = source.get(parts[i - 1]);
  source = getAsMap(result);
  if (source == null) {
   return false;
  }
 }
 return source.containsKey(parts[parts.length - 1]);
}

4.點(diǎn)號(hào)在mongodb中有子集合的含義

例如查詢A.B屬性:查詢的是集合中A對(duì)應(yīng)子集合中的屬性B的值,并不是查詢集合中A.B的屬性  

問(wèn)題描述:文檔在數(shù)據(jù)庫(kù)中的樣子:

{
 "_id": ObjectId("5bae00765500af6307755111"),
 "name": "java",
 "age": 26,
 "A.B": "nnnn"
}

因此在Model中使用@Field("A.B")查詢不出集合中的"A.B"的值

@Field("A.B")
@JSONField(serialzeFeatures = SerializerFeature.DisableCircularReferenceDetect)
private Integer ab;  

5.解決方法:

查閱多方資料有以下幾點(diǎn)體會(huì):點(diǎn)號(hào)在MongoDB中可以插入應(yīng)該開始于3.6版本,官方文檔雖然說(shuō)可以支持點(diǎn)號(hào),但是第三方驅(qū)動(dòng)、spring-data-mongodb并沒(méi)有支持,但是因?yàn)橐婚_始項(xiàng)目已經(jīng)使用了spring-data-mongodb難以替換,所以就想到覆蓋轉(zhuǎn)換方法。

怎么覆蓋spring-data-mongodb包中的文件?

新建一個(gè)和DBObjectAccessor轉(zhuǎn)換文件一樣的目錄,重新建DBObjectAccessor類復(fù)制代碼自定義修改,編譯之后或優(yōu)先使用新建的類。

//查詢時(shí)轉(zhuǎn)換
public Object get(MongoPersistentProperty property) {
 String fieldName = property.getFieldName();
 return this.dbObject.get(fieldName);
}
 
//判斷值是否為空
public boolean hasValue(MongoPersistentProperty property) {
 Assert.notNull(property, "Property must not be null!");
 String fieldName = property.getFieldName();
 return this.dbObject.containsField(fieldName);
}

 注意:盡量不要修改put方法,應(yīng)為低版本的MongoDB本不支持點(diǎn)號(hào),插入會(huì)報(bào)錯(cuò)

 當(dāng)然最好不要發(fā)生屬性中有點(diǎn)號(hào)的情況。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

  • mongodb 3.4下遠(yuǎn)程連接認(rèn)證失敗的解決方法

    mongodb 3.4下遠(yuǎn)程連接認(rèn)證失敗的解決方法

    這篇文章主要給大家介紹了在mongodb 3.4下遠(yuǎn)程連接認(rèn)證失敗的解決方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編一起來(lái)學(xué)習(xí)學(xué)習(xí)吧。
    2017-06-06
  • MongoDB數(shù)據(jù)庫(kù)性能監(jiān)控詳解

    MongoDB數(shù)據(jù)庫(kù)性能監(jiān)控詳解

    MongoDB作為圖片和文檔的存儲(chǔ)數(shù)據(jù)庫(kù),為啥不直接存MySQL里,還要搭個(gè)MongoDB集群,麻不麻煩?這篇文章就帶你介紹MongoDB數(shù)據(jù)庫(kù)性能監(jiān)控,感興趣的同學(xué)可以參考閱讀
    2023-03-03
  • MongoDB的聚合框架Aggregation Framework入門學(xué)習(xí)教程

    MongoDB的聚合框架Aggregation Framework入門學(xué)習(xí)教程

    MongoDB中的聚合aggregate主要用于處理數(shù)據(jù)計(jì)算,這里我們就來(lái)詳細(xì)整理MongoDB的聚合框架Aggregation Framework入門學(xué)習(xí)教程,需要的朋友可以參考下
    2016-07-07
  • mongodb三分鐘入門大全

    mongodb三分鐘入門大全

    MongoDB是一個(gè)介于關(guān)系數(shù)據(jù)庫(kù)和非關(guān)系數(shù)據(jù)庫(kù)之間的產(chǎn)品,是非關(guān)系數(shù)據(jù)庫(kù)當(dāng)中功能最豐富,最像關(guān)系數(shù)據(jù)庫(kù)的,接下來(lái)通過(guò)本文給大家介紹mongodb三分鐘入門大全,感興趣的朋友一起看看吧
    2022-01-01
  • MongoDB連接和創(chuàng)建數(shù)據(jù)庫(kù)的方法講解

    MongoDB連接和創(chuàng)建數(shù)據(jù)庫(kù)的方法講解

    這篇文章介紹了MongoDB連接和創(chuàng)建數(shù)據(jù)庫(kù)的方法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-03-03
  • Linux系統(tǒng)下MongoDB的簡(jiǎn)單安裝與基本操作

    Linux系統(tǒng)下MongoDB的簡(jiǎn)單安裝與基本操作

    這篇文章主要介紹了Linux系統(tǒng)下MongoDB的簡(jiǎn)單安裝與基本操作,需要的朋友可以參考下
    2015-04-04
  • MongoDB的mongo shell常用操作方法及操作腳本筆記

    MongoDB的mongo shell常用操作方法及操作腳本筆記

    mongo shell即相當(dāng)于SQL語(yǔ)句在關(guān)系型數(shù)據(jù)庫(kù)中的作用,MongoDB使用JavaScript作為shell操作命令,這里我們就來(lái)整理MongoDB的mongo shell常用操作方法及操作腳本筆記
    2016-07-07
  • MongoDB中4種日志的詳細(xì)介紹

    MongoDB中4種日志的詳細(xì)介紹

    這篇文章主要給大家介紹了關(guān)于MongoDB中4種日志的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用MongoDB具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • 關(guān)于CentOS 8 搭建MongoDB4.4分片集群的問(wèn)題

    關(guān)于CentOS 8 搭建MongoDB4.4分片集群的問(wèn)題

    在MongoDB里面存在另一種集群,就是分片技術(shù),可以滿足MongoDB數(shù)據(jù)量大量增長(zhǎng)的需求。這篇文章主要介紹了CentOS 8 搭建MongoDB4.4分片集群的問(wèn)題,需要的朋友可以參考下
    2021-10-10
  • 解決mongodb在ubuntu下啟動(dòng)失敗,提示couldn‘t remove fs lock errno:9 Bad file descriptor的錯(cuò)誤

    解決mongodb在ubuntu下啟動(dòng)失敗,提示couldn‘t remove fs lock errno:9 Bad

    之前MongoDB啟動(dòng)的時(shí)候是蠻正常的,不知道后來(lái)啟動(dòng)報(bào)錯(cuò)了,就把粘貼出來(lái)查詢了。經(jīng)過(guò)一番百度,才找的處理的辦法,分享給大家
    2014-08-08

最新評(píng)論