DB 종류

큰 기업은 보통 SQL / 스타트업기업이나 데이터 이동 삭제 변경이 자주 되는곳은 NOSQL

 

 

 

DB 연결하기

 

데이터베이스에 접속할 ID/PW

 

 

2가지 패키지 설치 // pymongo, dnspython
connect 누른 후 밑줄  클릭
사용할 드라이버 버전 선택
dbprac 파일 생성

 

복사 후
URL 입력

 

<password> 지우고 DB접속 패스워드 입력 net/ 뒤에 Cluster0 입력 ( 다른게 입력 되있다면 지우고 )
Cluster0 입력한건 이거임

 

DB 데이터 넣기

doc= {
    'name':'bob',
    'age':27
}

db.users.insert_one(doc)

users 컬렉션 안에 데이터가 잘 담긴 모습 // DB연결 확인

 

from pymongo import MongoClient
client = MongoClient('mongodb+srv://test:sparta@cluster0.hxjcjic.mongodb.net/Cluster0?retryWrites=true&w=majority')
db = client.dbsparta


db.users.insert_one({'name':'boby','age':27})
db.users.insert_one({'name':'john','age':20})
db.users.insert_one({'name':'ann','age':20})

이런식으로도 db에 데이터 입력 가능
보통 이렇게 사용 많이 함

 

 

 

DB (모든 값), (특정 값)검색하기

_id 값은 mongo db에서 자동으로 띄워주는거 밑에 처럼 삭제한 후 사용

 

all_users = list(db.users.find({},{'_id':False}))

for user in all_users:
    print(user)

보통 이걸로 복사해서 많이 사용됨

 

user = db.users.find_one({'name':'bobby'})
print(user)

하나만 찾고 싶을때 사용

user = db.users.find_one({'name':'bobby'})
print(user['age'])

나이만 찾고 싶을때 사용

 

 

DB 데이터 수정하기

 

db.users.update_one({'name':'bobby'},{'$set':{'age':19}})

조건 -> 어떻게 바꿔라 

REFRESH 후 age가 19로 바뀐 모습

 

 

DB 데이터 삭제하기 ( 거의 사용 안함 )

 

db.users.delete_one({'name':'bobby'})

REFRESH 후 bobby가 삭제 된 모습

 

Pymongo DB 코드 요약

# 저장 - 예시
doc = {'name':'bobby','age':21}
db.users.insert_one(doc)

# 한 개 찾기 - 예시
user = db.users.find_one({'name':'bobby'})

# 여러개 찾기 - 예시 ( _id 값은 제외하고 출력)
all_users = list(db.users.find({},{'_id':False}))

# 바꾸기 - 예시
db.users.update_one({'name':'bobby'},{'$set':{'age':19}})

# 지우기 - 예시
db.users.delete_one({'name':'bobby'})

 

 

 

insert 연습하기 - 웹스크래핑 결과를 DB에 저장하기

import requests
from bs4 import BeautifulSoup

from pymongo import MongoClient
client = MongoClient('mongodb+srv://test:sparta@cluster0.hxjcjic.mongodb.net/Cluster0?retryWrites=true&w=majority')
db = client.dbsparta


headers = {'User-Agent' : 'Mozilla/5.0 (Windows NT 10.0; Win64; x64)AppleWebKit/537.36 (KHTML, like Gecko) Chrome/73.0.3683.86 Safari/537.36'}
data = requests.get('https://movie.naver.com/movie/sdb/rank/rmovie.naver?sel=pnt&date=20210829',headers=headers)

soup = BeautifulSoup(data.text, 'html.parser')


movies = soup.select('#old_content > table > tbody > tr')



for movie in movies:
    a = movie.select_one('td.title > div > a')


    if a is not None:
        title = a.text
        rank = movie.select_one('td:nth-child(1) > img')['alt']
        star = movie.select_one('td.point').text
        doc = {
            'title':title,
            'rank':rank,
            'star':star,
        }
        db.movies.insert_one(doc)

from pymongo import MongoClient
client = MongoClient('mongodb+srv://test:sparta@cluster0.hxjcjic.mongodb.net/Cluster0?retryWrites=true&w=majority')
db = client.dbsparta

DB 연결

 

doc = {
    'title':title,
    'rank':rank,
    'star':star,
}
db.movies.insert_one(doc)

dbprac에 insert(저장)예시 참고해서 해당 값 입력 // 마지막 줄 users에 저장말고 새로운 movies 저장

movies에 데이터들이 저장된 모습

 

 

 

웹스크래핑 결과 이용하기

 

'가버나움'의 평점과 같은 평점의 영화 제목들을 가져오기

 

from pymongo import MongoClient
client = MongoClient('mongodb+srv://test:sparta@cluster0.hxjcjic.mongodb.net/Cluster0?retryWrites=true&w=majority')
db = client.dbsparta

all_movies = list(db.movies.find({'star':'9.59'},{'_id':False}))
for movie in all_movies:
    print(movie['title'])

나는 이렇게 코드를 작성해봤는데 답이랑은 좀 틀리다. 내가 파악을 잘못한거 같다. 가버나움의 평점을 알고 있을때는 나처럼 코딩해도 되지만 가버나움 평점을 모를때는 밑에 처럼 하는게 맞는거 같다.

 

from pymongo import MongoClient
client = MongoClient('mongodb+srv://test:sparta@cluster0.hxjcjic.mongodb.net/Cluster0?retryWrites=true&w=majority')
db = client.dbsparta

movie = db.movies.find_one({'title':'가버나움'})
star = movie['star']

all_movies = list(db.movies.find({'star':star},{'_id':False}))
for m in all_movies:
    print(m['title'])

 

 

db.movies.update_one({'title':'가버나움'},{'$set':{'star':'0'}})

가버나움 평점을 문자열 '0' 으로 바꾸기 // 그냥 숫자 0 아님

+ Recent posts