큰 기업은 보통 SQL / 스타트업기업이나 데이터 이동 삭제 변경이 자주 되는곳은 NOSQL
DB 연결하기
DB 데이터 넣기
doc= {
'name':'bob',
'age':27
}
db.users.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.users.insert_one({'name':'boby','age':27})
db.users.insert_one({'name':'john','age':20})
db.users.insert_one({'name':'ann','age':20})
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}})
조건 -> 어떻게 바꿔라
DB 데이터 삭제하기 ( 거의 사용 안함 )
db.users.delete_one({'name':'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 저장
웹스크래핑 결과 이용하기
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 아님