전체 글 79

Django - ManyToManyField.through_fields

Django 에서 ManyToManyField를 사용하다 보면 중간 테이블이 자동으로 만들어 지는 것이 아닌 내가 원하는 정보를 넣어서 중간 테이블을 커스텀 하려고 하는 경우가 발생한다. (필자의 경우 오늘 그랬다.) 나의 경우에는 유저와 게시물로 Like를 다대다관계로 만들었고 그 중에서 Like 발생 날짜를 테이블에 넣어주고자 했다. from django.db import models class User(models.Model): name = models.CharField(max_length=100) def __str__(self): return self.name class Post(models.Model): title = models.CharField(max_length=100) desc = mod..

Python/Django 2022.09.15

SQL - ONLY_FULL_GROUP_BY SQL 쿼리 실패

GROUP BY를 사용하는 경우, SELECT할 수 있는 컬럼은 GROUP BY에 나열된 컬럼과 SUM(), COUNT() 같은 집계 함수로 한정 됩니다. SQL 표준 문법은 GROUP BY 사용시 SELECT 의 칼럼 중 집계함수에 쓰이는 것을 제외한 모든 칼럼을 기입해야 한다. 내가 사용한 해결법 비 집계 칼럼에 ANY_VALUE() 함수 사용하여 문제를 해결 했다. 업데이트 예정 기본적인 해결 방법 - sql_mode 에서 ONLY_FULL_GROUP_BY 설정을 제외한다. ex) SET SESSION sql_mode = 'NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES'; - 설정파일(my.cnf)에서 ONLY_FULL_GROUP_BY 를 찾아 삭제한다.

카테고리 없음 2022.09.07

SQL - HAVING

HAVING? HAVING 절은 개별로 사용이 불가하고 GROUP BY와 함께쓰며 그룹을 나타내는 결과 즉 , 필터링 하는데 사용 됩니다. 여기서 COUNT,MIN,MAX와 같은 집계 함수는 HAVING 과 함께 사용할 수 있습니다. Example. SELECT COUNT(customer_id), country FROM Customers GROUP BY country HAVING COUNT(customer_id) > 1; 예시를 보면, country로 그룹화를 하여서 rows의 수를 계산합니다. 그리고 COUNT(customer_id) > 1 로 1보다 크면 결과 그룹을 반환합니다. 여기에서 또 알아야 하는 것이 가장 많이 쓴다고 할 수 있는 WHERE 과 HAVING의 차이점이다. 먼저 요약 하자면 H..

Data 2022.09.06

SQL - GROUP BY

GROUP BY? SQL 에서 GROUP BY 구문은 하나 이상의 rows(열) 로 columns(행) 을 그룹화할 때 사용 됩니다. GROUP BY 구문은 MIN(),MAX(),SUM(),AVG() 그리고 COUNT() 등 계산을 도와주는 함수와 함께 사용됩니다. Example. SELECT country , COUNT(*) AS number FROM customers GROUP BY country; 위의 SQL 구문은 country 로 그룹화 하고 있습니다. 그리고 COUNT(*)를 이용하여 그룹화 된 country의 갯수를 구하고 있습니다. 이미지 출처 : https://www.programiz.com/sql/group-by

Data 2022.09.06

SQL - Join

Join? Join문은 둘 이상의 테이블 사이의 related column 을 기반으로 두개의 테이블을 결합하는데 사용 됩니다. 기본구조 1) 일반 SELECT 테이블.컬럼, 테이블.컬럼 FROM 테이블1,테이블2 WHERE 조건 Join의 종류 INNER JOIN = 두 테이블에 모두 일치하는 데이터가 존재해야 조회됨 LEFT JOIN = 기준인 왼쪽테이블의 모든 데이터가 조회되고 JOIN되는 테이블에 관계되는 데이터가 존재할 경우에 해당 데이터를 참조 할 수 있다. [ 해당 JOIN 문을 가장 많이 사용한다고 알고 있음 ] RIGHT JOIN = 기준인 오른쪽테이블의 모든 데이터가 조회되고 JOIN되는 테이블에 관계되는 데이터가 존재할 경우에 해당 데이터를 참조 할 수 있다. FULL JOIN = F..

Data 2022.09.05

그룹단어체커 [22.09.04]

https://www.acmicpc.net/problem/1316 1316번: 그룹 단어 체커 그룹 단어란 단어에 존재하는 모든 문자에 대해서, 각 문자가 연속해서 나타나는 경우만을 말한다. 예를 들면, ccazzzzbb는 c, a, z, b가 모두 연속해서 나타나고, kin도 k, i, n이 연속해서 나타나기 때 www.acmicpc.net 나의 풀이 x = int(input()) group_word = 0 for _ in range(x): word = input() #전달받는 단어 error = 0 for idx in range(len(word)-1): if word[idx] != word[idx+1]: # ex) happy 에서 h와 a가 같지않을경우 new_word = word[idx+1:] # ..

Python/algorithm 2022.09.04

커트라인 [22.09.04]

https://www.acmicpc.net/problem/25305 25305번: 커트라인 시험 응시자들 가운데 1등은 100점, 2등은 98점, 3등은 93점이다. 2등까지 상을 받으므로 커트라인은 98점이다. www.acmicpc.net 나의 풀이 n, k = map(int,input().split()) score_list = list(map(int,input().split())) def cutline(tester, _pass, pt_list): pt_list.sort(reverse=True) passing_pt = _pass - 1 cut = pt_list[passing_pt] return cut print(cutline(n,k,score_list)) 루키의 풀이 n, k = map(int, inp..

Python/algorithm 2022.09.04

[자료구조] Array

Array Array(배열) 이란 연속된 메모리 공간에서 순차적으로 저장된 데이터의 모음입니다. array는 동일타입의 데이터만 저장이 가능하며 'int'를 선언 했을때는 float,char 와 같은 다른 타입의 데이터를 저장할 수 없습니다. 기본적으로 파이썬에서는 Array를 제공하지 않기 때문에 array 모듈을 사용해서 array를 생성 할 수 있습니다. array 모듈은 두가지 매개변수를 받으며 첫번째 매개변수는 type을 나타내는 typecode 이고 두번째는 대괄호로 묶인 요소 묶음입니다. ex) exam_arr = array('i',[1,3,2,4,5]) 자세한 typecode 에 대한 설명은 파이썬 공식문서를 참고하면 좋다. https://docs.python.org/ko/3/library..

Python/algorithm 2022.09.03

[Python] Map

함수의 기본 형태 map(function, iterable) 첫 번째 매개변수로는 적용 할 함수(function) , 두 번째 매개변수로는 리스트,튜플, str 등의 Iterable 한 객체가 들어갑니다. map이 반환 해주는 값은 map객체 이기 때문에 해당 객체를 list 혹은 tuple로 변환 시켜 줄 수 있습니다. 작동 방식은 주어진 2번째 매개변수인 iterable 객체를 하나씩 첫번째 매개변수인 funtion을 적용하여 하나씩 반환하여 최종적으로 목록을 반환합니다 ( map object) 예제 ] def exam(n): return n + n exam_numbers = [1,2,3,4,5,6] result = list(map(exam,exam_numbers)) print(result) # Ou..

Python 2022.09.01

[몸풀기] 자릿수 더하기(22.09.01)

문제 자연수 N이 주어지면, N의 각 자릿수의 합을 구해서 return 하는 solution 함수를 만들어 주세요. 예를들어 N = 123이면 1 + 2 + 3 = 6을 return 하면 됩니다. 나의 풀이 def solution(n): a = list(map(int, str(n))) answer = 0 for i in range(len(a)): answer += a[i] # [실행] 버튼을 누르면 출력 값을 볼 수 있습니다. return answer 다른사람의 풀이 def sum_digit(number): return sum([int(i) for i in str(number)]) # 아래는 테스트로 출력해 보기 위한 코드입니다. print("결과 : {}".format(sum_digit(123)));

Python/algorithm 2022.09.01