기본 콘텐츠로 건너뛰기

[MongoDB] CRUD 작업하기

[MongoDB] CRUD 작업하기

1. 자료형

몽고디비는 자바스크립트 문법을 사용하므로 자바스크립트의 자료형을 따릅니다.

그 외에 추가로 몇가지 자료형이 더 있습니다.

Date나 정규표현식 같은 자바스크립트 객체를 자료형으로 사용할 수 있고,

Binary Data, ObjectId, Int, Long, Decimal, Timestamp, Javascript 등의 추가적인 자료형이 있습니다.

( 추가적인 자료형 중에서 ObjectId와 Binary Data, Timestamp 외에는 잘 사용되지 않습니다. )

2. Create (생성)

컬렉션에 컬럼을 정의하지 않아도 되므로 컬렉션에는 아무 데이터나 넣을 수 있습니다.

1 ) 다큐먼트 생성 : db.컬렉션명.save(다큐먼트)

nodejs 데이터베이스안에 users 컬렉션안에 데이터를 추가하는 예시입니다.

몽고디비 프롬프트를 실행하며 다음 명령어를 실행해봅니다.

$ mongo > use nodejs switched to db nodejs > db.users.save({ name: 'hyemin', age: 25, married: false, comment: '안녕하세요', createdAt: new Date() }); WriteResult({ "nInserted" :1 }) > db.users.save({ name: 'tufu', age: 8, married: false, comment: '난 두부', createdAt: new Date() }); WriteResult({ "nInserted" :1 })

2 ) 아이디 참조 후 데이터 추가

comments 컬렉션에도 데이터를 넣습니다. tufu의 댓글을 추가해봅니다.

> db.users.find({ name: 'tufu' }), { _id: 1 }); { "_id" : ObjectId{"고유아이디"})

이렇게 아이디를 찾으면 tufu의 ObjectId 가 나옵니다.

ObjectId는 MySQL에서 기본키로 쓰이는 값과 비슷한 역할을 합니다.

> db.comments.save({ commenter: Objectid('고유 아이디'), comment: '안녕하세요 두부 댓글이에용', createdAt: new Date() }); WriteResult({ "nInserted" : 1 })

2. Read (조회)

방금 생성한 다큐먼트를 조회합니다.

1 ) 전체조회 : db.컬렉션명.find({})

컬렉션 내의 모든 다큐먼트를 조회하는 것 입니다.

2) 특정 필드 조회: db.컬렉션명.find({}, { 조회할 필드: true or false })

name과 married 값만 가져오길 원한다면, 아래와 같은 명령어를 활용하면 됩니다.

> db.users.find({}, {_id: 0, name: 1, married: 1});

3) 조회 시 조건 추가: db.컬렉션명.find({ 필드명: { 조건 } }, { 조회할 필드 })

조회 시 조건을 주려면 find 메서드의 첫번째 인자 객체에 기입해 주면 됩니다.

조회에 자주 쓰이는 연산자들은 아래와 같습니다.

$gt : 초과

$gte : 이상

$lt : 미만

$lte : 이하

$ne : 같지 않음

$or : 또는

$in : 배열 요소 중 하나

age가 10 미만인 다큐먼트의 이름과 나이를 조회하는 예시,

> db.users.find({ age: { $lt: 10 }},{ _id: 0, name: 1, age: 1 });

or 연산을 사용해 10 미만이거나 married가 false인 경우를 조회하는 예시,

> db.users.find({ $or: [{ age: $lt: 10 }},{ married: false }] }, { _id: 0, name: 1, age: 1 });

sort : 정렬

내림차순은 -1, 오름차순은 1입니다.

> db.users.find({}, { _id: 0, name: 1, age: 1 }).sort({ age: -1 })

limit : 조회할 다큐먼트 개수 설정

1개만 조회할 때 예시

> db.users.find({}, { _id: 0, name: 1, age: 1 }).sort({ age: -1 }).limit(1)

skip : 몇 개를 건너뛸지 설정

한개 건너뛰고 조회하는 예시

> db.users.find({}, { _id: 0, name: 1, age: 1}).sort({ age: -1 }).limit(1).skip(1)

3. Update (수정): db.컬렉션명.update({ 수정할 다큐먼트 지정 }, { 수정할 내용을 입력 })

첫번째 객체는 수정할 다큐먼트를 지정하는 객체고, 두번째 객체는 수정할 내용을 입력하는 객체입니다.

$set이라는 연산자를 활용하면 어떤 필드를 수정할지 정할 수 있습니다.

$set을 사용하지 않고 일반 객체를 넣을 경우 다큐먼트가 통째로 두번째 객체로 인자로 주어진 객체로 수정됩니다.

일부 필드 수정을 원할 때는 반드시 $set 연산자를 활용해야 합니다.

comment만 수정하는 예시

> db.users.update({ name: 'tufu' }, { $set: { comment: '댓글 수정해보기' }});

4. Delete (삭제): db.컬렉션명.remove({ 삭제할 다큐먼트 })

삭제할 다큐먼트에 대한 정보가 담긴 객체를 첫번째 인자로 사용합니다.

> db.users.remove({ name: 'tufu' })

from http://hyem-study.tistory.com/123 by ccl(A) rewrite - 2020-03-19 20:54:05

댓글

이 블로그의 인기 게시물

AWS CI/CD 파이프라인에 Slack 알람 적용(Lambda, CloudWatch Events 연동)

AWS CI/CD 파이프라인에 Slack 알람 적용(Lambda, CloudWatch Events 연동) 이번 글에서는 구축된 CI/CD 파이프라인과 Slack 알람을 연동하는 방법에 대해서 알아볼 것이다. CI/CD 파이프라인 시작/종료(성공/실패) 시 Amazon CloudWatch Events에서 해당 이벤트를 감지한 후 AWS Lambda로 트리거 신호를 보내면 AWS Lambda에서 Slack채널로 알람을 보내는 프로세스다. 글의 순서는 다음과 같다. Amazon CloudWatch Events, AWS Lambda란? 실습 전 준비사항 Slack Webhook 생성 AWS Lambda 함수 생성 AWS CloudWatch Events 생성 테스트 위와 같은 방식으로 구축을 하면 최종 프로세스는 다음 그림과 같다 (우리가 이 글에서 진행하는 내용은 빨간색으로 표시된 부분) 1. Amazon CloudWatch Events, AWS Lambda란? 1-1. Amazon CloudWatch Events란? Amazon CloudWatch Event(혹은 AWS CloudWatch Events)는 AWS 상태 변경 등을 감시할 수 있는 기능이다. 만약 사용자가 만든 규칙에 맞는 이벤트가 발생하게 되면 해당 이벤트가 사정에 정의된 규칙과 일치할 경우 하나 이상의 대상 작업을 호출한다. 이벤트 유형에 따라 알람을 보내거나, 이벤트 정보를 캡쳐하거나, 교정작업을 수행하거나, 이벤트를 시작하거나, 기타 작업을 수행할 수 있다. 이벤트가 발생할 경우 대상 작업은 AWS Lambda함수, AWS Kinesis 스트림, AWS SQS, Amazon SNS 등이 있다. 사용되는 사례로는 1) 이벤트가 발생하면 Lambda함수를 사용하여 Slack채널로 알림을 전달하거나, 2) AWS 상태 이벤트가 발생하면 Lambda 및 CloudWatch Events를 사용하여 Amazon SNS로 사용자 지정 텍스트 또는 SMS 알림을 보내는 등...

[Mac OS X] 데스크탑 응용프로그램 개발시작

[Mac OS X] 데스크탑 응용프로그램 개발시작 현재 회사에서 다음 프로젝트로 Mac OS X를 개발해야 하는 일정이 생겨 난생 처음 데스크탑 응용프로그램을 개발하기 공부를 시작했고 여러가지 플랫폼이 있다는것을 발견했다. 어떤 플랫폼을 사용해야할 지 먼저 고민해보자. 무엇으로 개발할것인가? Xcode & Swfit or Objective-C Mac OS X 는 objective-c를 기반으로 만들어졌다. apple에서 제공하는 Xcode와 objective-c 혹은 Swift로 응용 프로그램을 만들 수 있다. Electron Electron 프레임워크를 사용하면 javascript, HTML, CSS를 사용하여 크로스 플랫폼 데스크탑 응용 프로그램을 만들 수 있다. react-native-desktop Qt 프레임 워크를 기반으로하는 크로스 플랫폼이다. react-native 와 javascript로 응용 프로그램을 만들 수 있다. Qt는 컴퓨터 프로그래밍에서 GUI 프로그램 개발에 널리 쓰이는 크로스 플랫폼 프레임워크. 각 플랫폼의 장단점은 무엇인가? Xcode & Swfit or Objective-C - 장점 모든 OSX API에 직접 접근할 수 있다. Xcode를 통해 App Store에 쉽게 배포할 수 있다. - 단점 Windows 전용 응용 프로그램을 다시 개발해야한다. Swift언어를 모른다면 새로 공부해야 한다. Electron - 장점 웹스택을 가지고 빠르게 만들 수 있다. 다양한 플랫폼을 지원한다. - 단점 Native언어로 개발할때 보다 성능이 떨어질 이슈가있다. OS X API를 사용하는데 복잡하다. *API에 대한 JavaScript 래퍼가 없으면 자체 래퍼를 작성하지 않는 한 프로젝트에서 사용할 수 없습니다. React-native-desktop - 장점 현재 개발스택과 완전히 동일하므로 더 빠르게 개발 할 수 있다. 다양한 플랫폼을 지원한다. - 단점 N...

[2020-angstromCTF] web - A peculiar query write-up

[2020-angstromCTF] web - A peculiar query write-up English write-up UI seems like below. If you click the 'the source' link, you can get back-end source code. const express = require("express"); const rateLimit = require("express-rate-limit"); const app = express(); const { Pool, Client } = require("pg"); const port = process.env.PORT || 9090; const path = require("path"); const client = new Client({ user: process.env.DBUSER, host: process.env.DBHOST, database: process.env.DBNAME, password: process.env.DBPASS, port: process.env.DBPORT }); async function query(q) { const ret = await client.query(`SELECT name FROM Criminals WHERE name ILIKE '${q}%';`); return ret; } app.set("view engine", "ejs"); app.use(express.static("public")); app.get("/src", (req, res) => { res.sendFile(path.join(__dirname, "index.js")); }); app.get("/", async (req, res) => { if (req.query...