MongoDB
 sql >> Teknologi Basis Data >  >> NoSQL >> MongoDB

Mongodb:db.printShardingStatus() / sh.status() panggilan di Java (dan JavaScript)

Banyak fungsi pembantu shell tidak tersedia untuk eksekusi kode sisi server. Dalam kasus printShardingStatus() , masuk akal karena tidak ada konsol yang digunakan untuk mencetak output dan Anda lebih suka mengembalikan string. Untungnya, Anda seharusnya dapat mengambil sumber dari fungsi shell dan mengimplementasikannya kembali di aplikasi Anda (misalnya, menggabungkan string yang dikembalikan alih-alih mencetak secara langsung).

$ mongo
MongoDB shell version: 2.2.0
connecting to: test
> db.printShardingStatus
function (verbose) {
    printShardingStatus(this.getSiblingDB("config"), verbose);
}

Jadi, mari kita lihat printShardingStatus() fungsi...

> printShardingStatus
function (configDB, verbose) {
    if (configDB === undefined) {
        configDB = db.getSisterDB("config");
    }
    var version = configDB.getCollection("version").findOne();

    // ...
}

Sebelum mengubah semua pernyataan keluaran menjadi rangkaian string, Anda ingin memastikan bahwa semua metode DB lainnya tersedia untuk Anda. Dari segi kinerja, saya pikir opsi terbaik adalah mem-port bagian dalam fungsi ini ke Java dan menghindari evaluasi JS sisi server sama sekali. Jika Anda menyelam lebih dalam ke printShardingStatus() fungsi, Anda akan melihatnya hanya mengeluarkan find() pada database konfigurasi bersama dengan beberapa group() kueri.

Jika Anda ingin tetap mengevaluasi JS dan lebih suka tidak menyimpan kode ini dalam aplikasi Java Anda, Anda juga dapat melihat ke menyimpan fungsi JS sisi server .



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Bagaimana cara mengatur dbpath default untuk mongoDB di windows 7?

  2. Mongoose :jangan masukkan jika elemen sudah tersimpan

  3. MongoDB:kueri Array untuk nilai 'benar' pada indeks n

  4. Temukan catatan terakhir setiap hari

  5. Temukan Lokasi di dalam Lingkaran yang tersimpan