MongoDB支持的java數(shù)據(jù)類型和測試?yán)?/h1>
更新時間:2014年05月29日 09:13:34 作者:
這篇文章主要介紹了MongoDB支持的java數(shù)據(jù)類型和測試?yán)?MongoDB除了本身自有的數(shù)據(jù)類型外,還為較流行的編程語言定制了該語言的數(shù)據(jù)類型,需要的朋友可以參考下
mongodb的java數(shù)據(jù)類型有:
Object Ids 自動ID
Regular Expressions 正則表達(dá)式搜索記錄
Dates/Times 時間
Database References 數(shù)據(jù)基礎(chǔ)結(jié)構(gòu)
Binary Data 二進(jìn)制流
Timestamp Data 時間標(biāo)記戳
Code Data 代碼數(shù)據(jù)
Embedded Documents 嵌入式文檔
Arrays 數(shù)組類型
詳細(xì)參考原來英文 http://docs.mongodb.org/ecosystem/drivers/java-types/
以下測試基礎(chǔ)的mongodb數(shù)據(jù)類型。
復(fù)制代碼 代碼如下:
package com.javaer.mongo;
import java.net.UnknownHostException;
import java.util.ArrayList;
import java.util.Date;
import java.util.regex.Pattern;
import org.bson.types.ObjectId;
import com.mongodb.BasicDBObject;
import com.mongodb.BasicDBObjectBuilder;
import com.mongodb.DB;
import com.mongodb.DBCollection;
import com.mongodb.DBCursor;
import com.mongodb.DBObject;
import com.mongodb.DBRef;
import com.mongodb.Mongo;
public class JavaTypes {
/**
* @param args
* @throws UnknownHostException
*/
public static void main(String[] args) throws UnknownHostException {
//基礎(chǔ)ID,自動增加 結(jié)構(gòu)類似503991d90364b431cdc798e2
ObjectId id = new ObjectId();
System.out.println(id);
id = new ObjectId();
System.out.println(id);
//5039924c0364f4a124555e42
// 5039924c0364f4a124555e43 連續(xù)使用,自動增加,否則隨機生成
Mongo m = new Mongo();
DB db = m.getDB("yuexiaosheng");
DBCollection coll = db.getCollection("mycollection");
//使用標(biāo)準(zhǔn)庫的正則表達(dá)式,可以搜索數(shù)據(jù)里記錄。類似mysql中條件 where title like '%name%'
Pattern john = Pattern.compile(".*?jack*.?",Pattern.CASE_INSENSITIVE);
BasicDBObject query = new BasicDBObject("title", john);
DBCursor cursor = coll.find(query);
try {
while(cursor.hasNext()) {
System.out.println(cursor.next());
}
} finally {
cursor.close();
}
//mongodb中的時間類型
Date now = new Date();
BasicDBObject time = new BasicDBObject("ts", now);
coll.save(time);
//插入的記錄 { "_id" : ObjectId("503993b20364129f6625d349"), "ts" : ISODate("2012-08-26T03:10:42.146Z") }
//mongodb中的數(shù)組結(jié)構(gòu)。
ArrayList x = new ArrayList();
x.add(1);
x.add(2);
x.add(new BasicDBObject("foo", "bar"));
x.add(4);
BasicDBObject doc = new BasicDBObject("x", x);
coll.save(doc);
//插入的記錄 { "_id" : ObjectId("503994500364bf9957b271a6"), "x" : [ 1, 2, { "foo" : "bar" }, 4 ] }
//存儲mongodb的數(shù)據(jù)結(jié)構(gòu)數(shù)據(jù)到數(shù)據(jù)庫里
DBRef addressRef = new DBRef(db, "foo.bar", id);
DBObject address = addressRef.fetch();
DBObject person = BasicDBObjectBuilder.start()
.add("name", "Fred")
.add("address", addressRef)
.get();
coll.save(person);
//插入的數(shù)據(jù)記錄
//{ "_id" : ObjectId("503995390364fcf1b54905b2"), "name" : "Fred", "address" : { "$ref" : "foo.bar", "$id" : ObjectId("503995390364fcf1b54905af") } }
DBObject fred = coll.findOne();
DBRef addressObj = (DBRef)fred.get("address");
System.out.println(addressObj);
// { "$ref" : "foo.bar", "$id" : "5039965c03648efcd6281311
}
}
您可能感興趣的文章:- MongoDB 常用的數(shù)據(jù)類型和基本操作
- Java將日期類型Date時間戳轉(zhuǎn)換為MongoDB的時間類型數(shù)據(jù)
- Mongodb 利用mongoshell進(jìn)行數(shù)據(jù)類型轉(zhuǎn)換的實現(xiàn)方法
- 基于MongoDB數(shù)據(jù)庫的數(shù)據(jù)類型和$type操作符詳解
- mongodb 數(shù)據(jù)類型(null/字符串/數(shù)字/日期/內(nèi)嵌文檔/數(shù)組等)
- Mongodb 數(shù)據(jù)類型及Mongoose常用CURD
- MongoDB常用數(shù)據(jù)類型分享
相關(guān)文章
-
JavaWeb dbutils執(zhí)行sql命令并遍歷結(jié)果集時不能查到內(nèi)容的原因分析
這篇文章主要介紹了JavaWeb dbutils執(zhí)行sql命令并遍歷結(jié)果集時不能查到內(nèi)容的原因分析及簡單處理方法,文中給大家介紹了javaweb中dbutils的使用,需要的朋友可以參考下 2017-12-12
-
在Java 8中將List轉(zhuǎn)換為Map對象方法
這篇文章主要介紹了在Java 8中將List轉(zhuǎn)換為Map對象方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下 2018-11-11
最新評論
mongodb的java數(shù)據(jù)類型有:
Object Ids 自動ID
Regular Expressions 正則表達(dá)式搜索記錄
Dates/Times 時間
Database References 數(shù)據(jù)基礎(chǔ)結(jié)構(gòu)
Binary Data 二進(jìn)制流
Timestamp Data 時間標(biāo)記戳
Code Data 代碼數(shù)據(jù)
Embedded Documents 嵌入式文檔
Arrays 數(shù)組類型
詳細(xì)參考原來英文 http://docs.mongodb.org/ecosystem/drivers/java-types/
以下測試基礎(chǔ)的mongodb數(shù)據(jù)類型。
package com.javaer.mongo;
import java.net.UnknownHostException;
import java.util.ArrayList;
import java.util.Date;
import java.util.regex.Pattern;
import org.bson.types.ObjectId;
import com.mongodb.BasicDBObject;
import com.mongodb.BasicDBObjectBuilder;
import com.mongodb.DB;
import com.mongodb.DBCollection;
import com.mongodb.DBCursor;
import com.mongodb.DBObject;
import com.mongodb.DBRef;
import com.mongodb.Mongo;
public class JavaTypes {
/**
* @param args
* @throws UnknownHostException
*/
public static void main(String[] args) throws UnknownHostException {
//基礎(chǔ)ID,自動增加 結(jié)構(gòu)類似503991d90364b431cdc798e2
ObjectId id = new ObjectId();
System.out.println(id);
id = new ObjectId();
System.out.println(id);
//5039924c0364f4a124555e42
// 5039924c0364f4a124555e43 連續(xù)使用,自動增加,否則隨機生成
Mongo m = new Mongo();
DB db = m.getDB("yuexiaosheng");
DBCollection coll = db.getCollection("mycollection");
//使用標(biāo)準(zhǔn)庫的正則表達(dá)式,可以搜索數(shù)據(jù)里記錄。類似mysql中條件 where title like '%name%'
Pattern john = Pattern.compile(".*?jack*.?",Pattern.CASE_INSENSITIVE);
BasicDBObject query = new BasicDBObject("title", john);
DBCursor cursor = coll.find(query);
try {
while(cursor.hasNext()) {
System.out.println(cursor.next());
}
} finally {
cursor.close();
}
//mongodb中的時間類型
Date now = new Date();
BasicDBObject time = new BasicDBObject("ts", now);
coll.save(time);
//插入的記錄 { "_id" : ObjectId("503993b20364129f6625d349"), "ts" : ISODate("2012-08-26T03:10:42.146Z") }
//mongodb中的數(shù)組結(jié)構(gòu)。
ArrayList x = new ArrayList();
x.add(1);
x.add(2);
x.add(new BasicDBObject("foo", "bar"));
x.add(4);
BasicDBObject doc = new BasicDBObject("x", x);
coll.save(doc);
//插入的記錄 { "_id" : ObjectId("503994500364bf9957b271a6"), "x" : [ 1, 2, { "foo" : "bar" }, 4 ] }
//存儲mongodb的數(shù)據(jù)結(jié)構(gòu)數(shù)據(jù)到數(shù)據(jù)庫里
DBRef addressRef = new DBRef(db, "foo.bar", id);
DBObject address = addressRef.fetch();
DBObject person = BasicDBObjectBuilder.start()
.add("name", "Fred")
.add("address", addressRef)
.get();
coll.save(person);
//插入的數(shù)據(jù)記錄
//{ "_id" : ObjectId("503995390364fcf1b54905b2"), "name" : "Fred", "address" : { "$ref" : "foo.bar", "$id" : ObjectId("503995390364fcf1b54905af") } }
DBObject fred = coll.findOne();
DBRef addressObj = (DBRef)fred.get("address");
System.out.println(addressObj);
// { "$ref" : "foo.bar", "$id" : "5039965c03648efcd6281311
}
}
- MongoDB 常用的數(shù)據(jù)類型和基本操作
- Java將日期類型Date時間戳轉(zhuǎn)換為MongoDB的時間類型數(shù)據(jù)
- Mongodb 利用mongoshell進(jìn)行數(shù)據(jù)類型轉(zhuǎn)換的實現(xiàn)方法
- 基于MongoDB數(shù)據(jù)庫的數(shù)據(jù)類型和$type操作符詳解
- mongodb 數(shù)據(jù)類型(null/字符串/數(shù)字/日期/內(nèi)嵌文檔/數(shù)組等)
- Mongodb 數(shù)據(jù)類型及Mongoose常用CURD
- MongoDB常用數(shù)據(jù)類型分享
相關(guān)文章
JavaWeb dbutils執(zhí)行sql命令并遍歷結(jié)果集時不能查到內(nèi)容的原因分析
這篇文章主要介紹了JavaWeb dbutils執(zhí)行sql命令并遍歷結(jié)果集時不能查到內(nèi)容的原因分析及簡單處理方法,文中給大家介紹了javaweb中dbutils的使用,需要的朋友可以參考下2017-12-12
在Java 8中將List轉(zhuǎn)換為Map對象方法
這篇文章主要介紹了在Java 8中將List轉(zhuǎn)換為Map對象方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-11-11

