Форум программистов, компьютерный форум, киберфорум
Node.js
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.63/8: Рейтинг темы: голосов - 8, средняя оценка - 4.63
1 / 1 / 0
Регистрация: 20.04.2013
Сообщений: 283

закрыть соединение с МонгоДБ

14.01.2020, 12:51. Показов 1635. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
добрый день. Пытаюсь реализовать простой клас для управления таблицей в монговской ДБ
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
class DBcontroller {
 
    constructor(DBaddress,DBstring,DBtable) {
      this.DBaddress = DBaddress;
      this.DBstring = DBstring;
      this.DBtable = DBtable;
    }
  
    sayHi() {console.log(this.DBaddress+this.DBstring+"\\"+this.DBtable);}
    insert (newobj){
     let inserADD= this.DBaddress;
     let insertDB= this.DBstring;
     let insertTB= this.DBtable;
 
        MongoClient.connect(this.DBaddress,{
             useNewUrlParser: true,
             useUnifiedTopology: true
          },function(err,client){
 
          var db = client.db(insertDB);
            
    db.collection(insertTB, function (err, collection) {collection.insertOne(newobj);});
    
   
    });
 
    
  }}
 
let controller = new DBcontroller("mongodb://localhost:27017/",'EmployeeDB','Persons');
 
controller.insert({ id: 2, firstName: 'mister', lastName: 'white' });
Пока хотя бы добавление. Проблема в следующем. Оно добавляет, но консоль продолжает выполнять програму и не закрываети процесс. То есть ,как понимаю, оно поддерживает дальше соединение с БД пока не нажму контрол+С . А как сделать так, чтоб оно после выполнения операции добавления (дальше буду добавлять удаление\изменение...) само закрывало соединение и завершало выполнение програмы?
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
14.01.2020, 12:51
Ответы с готовыми решениями:

Socket.io закрыть соединение при смены страницы
У меня только лишь на определенной странице сайта работают сокеты для обмена сообщениями. Если я перейду на другую страницу то соединение...

Закрыть соединение с локальной БД
Здравствуйте! Подскажите, пожалуйста. В своей программе использую локальную базу данных (Service-Based Database). Хочу сделать...

Как закрыть COM соединение?
Добрый день! УТ 10,3, платформа 8,2 Соединяюсь через СОМобъект с другой базы, все прекрасно, все замечательно, данные передаются ...

3
413 / 304 / 113
Регистрация: 28.08.2013
Сообщений: 807
14.01.2020, 13:46
Лучший ответ Сообщение было отмечено Dimitrii как решение

Решение

После того как получишь ответ от БД, обработаешь его, и добавь
JavaScript
1
2
3
db.close(function(){
    console.log('DB connection is closed.');
})
1
1 / 1 / 0
Регистрация: 20.04.2013
Сообщений: 283
14.01.2020, 17:44  [ТС]
спасибо)
А не подскажете еще как тут сделать чтоб функция возвращала значения полученые из базы
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
find(param,value){
 
 
        let insertDB= this.DBstring;
        let insertTB= this.DBtable;
        let answer;
        MongoClient.connect(this.DBaddress,{
            useNewUrlParser: true,
            useUnifiedTopology: true
        },  function(err,client){
            var db = client.db(insertDB);
            var finded={};
            finded[param]=value;
            let A= db.collection('Persons').find(finded);
           
            A.toArray(function(err,results){console.log(results)});
           
         
            client.close();
           
        });
 
 
        
        return answer;
 
    }
0
413 / 304 / 113
Регистрация: 28.08.2013
Сообщений: 807
14.01.2020, 18:10
Что-то вроде этого, но надо тестить.
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
function find(param, value, callback){
    let insertDB = this.DBstring;
    let insertTB = this.DBtable;
    MongoClient.connect(this.DBaddress,{
        useNewUrlParser: true,
        useUnifiedTopology: true
    },
    function(err, client){
        if(err){ console.error(err); }
        else{
            var db = client.db(insertDB);
            var finded = {};
            finded[param] = value;
            db.collection('Persons').find(finded).toArray(function(err, results){
                if(err){ console.error(err); }
                else{
                    client.close();
                    callback(results);
                }
            });
        }
    });
}
 
find('name', 'John', function(results){
    if(results){
        for(var i=0; i<results.length; i++){
            console.log(results[i]);
        }
    }
    else{
        console.log('No results.');
    }
});
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
14.01.2020, 18:10
Помогаю со студенческими работами здесь

Закрыть соединение со стороны клиента
Как в boost::asio закрыть соединение со стороны клиента?

Закрыть соединение GridView с БД Access
Привязал элемент GridView к БД Access. Но теперь БД все время открыта. Вручную открываю её, закрываю, а соединение все равно остается...

Как закрыть соединение с сервером?
При нажатии на кнопку(Connect), клиент берет записи из JTextField'a и отправляет их на сервер. Сервер печатает их в JTextArea. При первом...

Как закрыть мертвое соединение
Ребята подскажите, в документации к питону есть реализация эхо сервера import asyncore import socket class...

Аккуратно закрыть соединение TCP (shutdown)
Пишу серверное приложение. Когда клиент отправляет файл, он открывается и читается, пока сервер работает. Когда сервер не работает файл...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru