<6> tsconfig.json 을 통한 컴파일 옵션 설정
tsconfig.json 을 통해 컴파일 옵션을 설정할 수 있다.
- 컴파일 방법
$ tsp --p tsconfig.json
{
"compilerOptions": {
"target": "es6",
"module": "commonjs",
"moduleResolution": "node",
"sourceMap": true,
"emitDecoratorMetadata": true,
"experimentalDecorators": true,
"removeComments": false,
"noImplicitAny": false
},
"exclude": [
"node_modules"
]
}
"target": "es6" // 결과물 ECMAScript 버전 설정
"module": "commons" // 모듈설정
"moduleResolution": "node" // 모듈 해석방식 설정
"sourceMap": true // 소스맵(*.map) 파일 생성 여부
"emitDecoratorMetadata": true //
"experimentalDecorators": true // ES Decorator 에 대한 실험적 기능 사용 여부
"removeComments": false // 주석 삭제
"noImplicitAny": false //
이러한 옵션들이 있다고 한다.. (https://vomvoru.github.io/blog/tsconfig-compiler-options-kr/)
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 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 | { "include": [ "src/**/*" ], "exclude": [ "node_modules" ], "compilerOptions": { "target": "ES2017", // 결과물 ECMAScript 버전 설정 /////////// module /////////// "module": "CommonJS", // 모듈 설정 "moduleResolution": "node", // 모듈 (검색)해석 방식 설정 "allowSyntheticDefaultImports": false, // export default 를 export 한 값들을 가지는 객체로 설정 "forceConsistentCasingInFileNames": false, // 파일명에 대소문자 구분하지 않아도 되는 기능 사용 여부 // 직역: 파일 이름에 일관된 casing 강제 적용 /////////// path /////////// "baseUrl": ".", // Non-relativ 모듈 혹은 paths 옵션의 기준 디렉토리 "paths": { // baseUrl 옵션을 기준디렉토리로 불러올 모듈의 위치 설정이 가능 "*": ["*"] }, // "rootDirs": [ ], // 가상 디덱토리를 설정 "rootDir": "./", // 입력파일의 rootDir 설정 // outDir옵션을 사용할때만 사용 "outDir": "dest", // 출력할 디덱토리 // @TODO 테스트 필요 // "outFile": "", // 단일파일로 출력시 파일명 // @TODO 테스트 필요 /////////// declaration /////////// "declaration": false, // .d.ts 파일의 생성 여부 "declarationDir": "", // .d.ts 파일이 생성되는 디렉토리 설정 /////////// log /////////// "diagnostics": false, // @TODO 테스트 필요 // Show diagnostic information. "traceResolution": false, // 모듈 검색에 대한 로그메세지 출력 여부 "listEmittedFiles": false, // 컴파일된 결과 파일들 이름을 터미널에 출력 "listFiles": true, // 컴파일된 파일들 이름을 터미널에 출력 "locale": "ko", // 에러메세지 출력 언어 설정 "pretty": true, // 에러 메시지를 예쁘게 설정 // @TODO 테스트 필요 /////////// React /////////// // "jsx": "preserve", // jsx 지원 // "jsxFactory": "React.createElement", // jsx 팩토리 함수 설정, /////////// JS /////////// // "allowJs": false, // 자바스크립트 파일 컴파일 허용 여부. // "checkJs": false, // allowJs 옵션이 true여서 js파일 모듈을 사용시 js파일의 오류 검사 여부 // "maxNodeModuleJsDepth": 0, // js 모듈을 검색할 최대 깊이 /////////// Lint /////////// "strict": true, // 모든 엄격한 타입 검사 옵션을 활성화 // noImplicitAny, noImplicitThis, alwaysStrict, strictNullChecks, strictFunctionTypes "allowUnreachableCode": false, // 도달 불가능한 코드에 대한 허용 여부. "allowUnusedLabels": false, // 사용하지 않는 라벨에 대한 허용 여부 "noFallthroughCasesInSwitch": true, // 잘못 적혔다고 판단되는 switch문에 대한 에러 발생 "noImplicitReturns": true, // 함수의 모든 경로가 값을 반환하지 않으면 에러 발생 "suppressExcessPropertyErrors": false, // 객체 리터럴에 대한 초과 속성 검사 억제 여부 // @TODO 부가설명 필요 "suppressImplicitAnyIndexErrors": false, // 인덱스 서명이없는 개체를 인덱싱하는 경우 --noImplicitAny 오류 억제여부 // 자세한 내용은 문제 #1232를 참조 // @TODO 부가설명 필요 "noStrictGenericChecks": true, // 함수에서 generic의 엄격한 검사 해제 여부 "noUnusedLocals": true, // 사용안된 지역변수에 대한 오류 보고 여부 "noUnusedParameters": true, // 사용안된 파라미터에 대한 오류 보고 여부 /////////// edit outfile /////////// "charset": "utf8", // 입력파일의 문자집합 형식 "emitBOM": false,// 출력 파일의 시작 부분에 UTF-8 바이트 순서표 (BOM) 추가여부 // "newLine": "lf", // end of line sequence 설정 "removeComments": true, // 주석 삭제 // @TODO '/*!' 주석 테스트 필요 "disableSizeLimit": false, // @TODO 테스트 필요 // Disable size limitation on JavaScript project. "noEmit": false, // 결과파일을 저장하지 않음 // @TODO 테스트 필요 "noEmitOnError": false, // 에러 발생시 결과파일을 저장하지 않음 "preserveConstEnums": false, // const enum형 선언을 지우지 않을건지 여부 /////////// more spec /////////// "lib": [], // 컴파일에 포함될 라이브러리 파일 목록 "downlevelIteration": false, // target이 ES3 및 ES5 일때도 for..of, spread, destructuring 문법 지원 "experimentalDecorators": true, // ES Decorator에 대한 실험적 기능 사용 여부 "stripInternal": false, // /** @ internal * /JSDoc annotation이 있는 코드에 대한 선언을 내 보내지 않을지 여부 // @TODO 부가설명 필요 /////////// optimization /////////// "importHelpers": true, // tslib에서 helpers (e.g. __extends, __rest, etc..)를 가져온다. /////////// sourceMap /////////// "inlineSourceMap": false, // 소스맵을 결과코드에 추가 // @TODO 테스트 필요 "mapRoot": "./map", // "source map 파일을 저장할 root 디렉토리 지정 // 지정하지 않으면 변환된 파일과 동일한 디렉토리에 저장된다. "sourceMap": true, // 소스맵(*.map) 파일 생성 여부 // "sourceRoot": "", // 디버거가 알아야될 .ts파일 root 위치. 소스맵(*.map)에 적용된다. // @TODO 테스트 필요 "inlineSources": false, // 변환전 파일 .ts 코드를 결과코드에 추가 // @TODO 테스트 필요 /////////// etc /////////// "noImplicitUseStrict": false, // @TODO 테스트 필요 "noLib": false, // 기본 라이브러리(lib.d.ts)를 가져오지 않는다. // @TODO 옵션 사용처 "plugins": [ ], // 편집환경을 더 좋게 변경하기 위한 플러그인 기능 "preserveSymlinks": false, // Symlink파일에서 다른 모듈을 import시 기준경로를 Symlink 경로로 설정 // 기존에는 Symlink파일에서 다른 모듈을 import시 // Symlink파일의 실제 경로에서 모듈을 가져왔다. // https://nodejs.org/api/cli.html#cli_preserve_symlinks "skipLibCheck": false, // 모든 선언파일(*.d.ts)의 유형검사를 건너뛸지 여부 "watch": false, // 파일 변경시 컴파일 /////////// ??? /////////// "isolatedModules": false, // @TODO 뭘까... // https://github.com/Microsoft/TypeScript/issues/2499 "emitDecoratorMetadata": false, // @TODO 테스트 필요 // Emit design-type metadata for decorated declarations in source. See issue #2577 for details. "noResolve": false // @TODO 테스트 필요 } } | cs |
'H6 > backend (Node.js, tsc)' 카테고리의 다른 글
<7> REST API & CRUD (0) | 2018.01.31 |
---|---|
<5> node-mysql (Typescript) (0) | 2018.01.22 |
<4> MySQL & node-mysql (0) | 2018.01.22 |
<3> 에러처리.. (0) | 2018.01.22 |
<2> app.ts 및 server.ts 만들기 (0) | 2018.01.22 |
[1149] RGB 거리
기본 DP2
- d[n][k] : n번째 집을 컬러 k로 칠했을 때, 1~n번째 집을 칠하는데 드는 최소비용.
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 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 | #include <stdio.h> int rgb[1001][3]; int d[1001][3]; int min(int a, int b) { return a > b ? b : a; } int go(int n, int k) { int ans; if(n == 0) return rgb[0][k]; if(d[n][k]) return d[n][k]; if(k == 0) { ans = go(n-1, 1); ans = min(ans, go(n-1, 2)); } else if(k == 1) { ans = go(n-1, 0); ans = min(ans, go(n-1, 2)); } else { ans = go(n-1, 0); ans = min(ans, go(n-1, 1)); } return d[n][k] = ans + rgb[n][k]; } int main() { int i, j, n; int ans; scanf("%d", &n); for(i=0; i<n; i++) for(j=0; j<3; j++) scanf("%d", &rgb[i][j]);; ans = go(n-1, 0); ans = min(ans, go(n-1, 1)); ans = min(ans, go(n-1, 2)); printf("%d\n", ans); return 0; } | cs |
>> 실은 6개월전에 해결했던 문제다.
하지만 과거에 코드를 보니, 한동안 ps를 안해서 그런지 더 멍청해진것 같다는 생각이 든다...
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 | #include <stdio.h> int rgb[1001][3], d[1001][3]; int min(int a, int b) { return a > b ? b : a; } int go(int n, int color) { int ret; if(n < 0) return 0; if(d[n][color]) return d[n][color]; ret = go(n-1, (color+1)%3); ret = min(ret, go(n-1, (color+2)%3)); return d[n][color] = ret+rgb[n][color]; } int main() { int i, j, n, ans; scanf("%d", &n); for(i=0; i<n; i++) for(j=0; j<3; j++) scanf("%d", &rgb[i][j]); ans = go(n-1, 2); ans = min(ans, go(n-1, 1)); ans = min(ans, go(n-1, 0)); printf("%d\n", ans); return 0; } | cs |
- 백준해설
i번째 집의 이웃은 i-1번째 집과 i+1번째 집. (연속)
처음집과 마지막 집은 이웃이 아니다..!!
다이나믹에서 중요한 조건중에 하나인 "연속"이라는 조건이 포함된 문제..!!
앞의 집과의 색만 다르게 칠하면 된다.
- 아래 코드는 바텀업.
1 2 3 4 5 6 7 | for(int i=1; i<=n; i++) { d[i][0] = min(d[i-1][1], d[i-1][2]) + a[i][0]; d[i][1] = min(d[i-1][0], d[i-1][2]) + a[i][0]; d[i][2] = min(d[i-1][0], d[i-1][1]) + a[i][0]; } cout << min({d[n][0], d[n][1], d[n][2]}) << '\n'; | cs |
>> 0번째는 비워두고 하는것이 좋다.
>> min({a, b, c}); // a, b, c 중 최소값.
>> c++11 문법으로 아래가 함수의 원형인 것 같다. 즉 리스트로 들어가서 그 리스트들 중 최소값이
리턴되는 방식인 것 같다.
template<class T> T min( std::initializer_list<T> ilist) { return *std::min_element(ilist.begin(), ilist.end()); }
'BOJ > DP' 카테고리의 다른 글
[2302] 극장 좌석 (0) | 2018.02.05 |
---|---|
[1937] 욕심쟁이 판다 (0) | 2018.02.01 |
[1309] 동물원 (0) | 2018.02.01 |
[1932] 숫자삼각형 (0) | 2018.02.01 |
[1463] 1로 만들기 (0) | 2018.01.26 |
<1-3> 연산자
동영상 강의 : http://pythonkim.tistory.com/notice/77
# Day_01_02_Operator.py
# 연산자 : 산술, 관계, 논리, 비트
- 산술 : + - * / // % **
1 2 3 4 5 6 7 8 9 | # 산술 : + - * / // % ** a, b = 17, 5 print(a+b) # 22 print(a-b) # 12 print(a*b) # 85 print(a/b) # 3.4 print(a//b) # 3 print(a%b) # 2 , mod print(a**b) # 1419857, 17^5 | cs |
# 문제
1 2 3 4 5 6 | n = 37 a1 = n//10 a2 = n%10 n = a2*10 + a1 print(n) # 73 | cs |
- 관계 : > >= < <= == !=
1 2 3 4 5 6 7 8 9 10 11 | # 관계 : > >= < <= == != a, b = 17, 5 print(a, b) print(a > b) # T print(a >= b) # T print(a < b) # F print(a <= b) # F print(a == b) # F print(a != b) # T | cs |
- 단어에도 대소가 있다. >> 아스키 코드로 비교.
- 대문자보다 소문자가 크다.
- 한글은 유니코드 사용
- True 나 False 도 숫자로 이루어져 있다.
>> 데이터 변환을 통해 확인.
# 형변환(casting) : int float str bool
1 2 3 4 5 6 7 | # 형변환(casting) : int, float, str, bool print(int(True)) # 1 print('345') # 345 print(int('345')) # 345 print(int(a != b)) # 1 print(int(False)) # 0 | cs |
# 문제
# 10대인지 판단해보기.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | # 문제 # 10대인지 판단해보기. age = 15 b1 = age >= 10 # T, F b2 = age <= 19 # T, F # T * T = T # T * F = F # F * T = F # F * F = F print(bool(b1*b2)) # True print(age >= 10 * age <= 19) # False print((age >= 10) * (age <= 19)) # 1 print(10 <= age <= 19) # True (python only) |
- 논리 : and or not
>> 관계 연산자를 묶을 때 사용한다.
1 2 3 4 5 6 7 8 | # 논리 : and or not print(True and True) # True print(True and False) # False print(False and True) # False print(False and False) # False print(age >= 10 and age <= 19) # True |
- 비트 연산자는 pass
'Language > Python' 카테고리의 다른 글
<1-7> 정규표현식 with Python (0) | 2018.02.03 |
---|---|
<1-6> 정규표현식 (Regular Expression) (0) | 2018.02.02 |
<1-5> 함수(function) (0) | 2018.02.01 |
<1-4> 제어문(if) (0) | 2018.01.31 |
<1-2> 파이썬 입문 (0) | 2018.01.29 |
<1-1> How To Play River Flows In You On Guitar (arranged by Sunga Jung) (guitar lesson / tutorial) Part 1
How To Play River Flows In You On Guitar (arranged by Sunga Jung) (guitar lesson / tutorial) Part 1
Tutorial : https://www.youtube.com/watch?v=f4KKQUf7bQc
Fret, String
2 CaFo
3F1S, 2F4S : 1, 4 together
2F1S, 2F4S : 1, 3 together
3F1S, 2F4S : 1, 2 together
2F1S, 2F4S : 1, 3 together
3F1S, 3F2S, 3F5S : 1, 5 together
3F1S, 3F2S, 3F5S : 2, 3 together
3F1S, 1F2S : 1
3F1S, 1F2S : 2, 3 together
2, 3 and repeat.
2, 3
3F1S, 2F4S : 1, 4 together
2F1S, 2F4S : 1, 3 together
3F1S : 1
2F4S : 4 then 2
2F1S : 1, 3 together
3F1S : 1
3F1S, 3F2S, 3F5S : 5 then 3 then 2 then 1
1F2S, 3F4F : 5 then 3 then 2
3F3S, 3F6S : 3, 6 together
4F3S : 3
1F2S : 2 (index finger)
3F2S : 4, 3, 2, toghether quickly
2
2F3S : 4, 3 together
'Play the guitar.' 카테고리의 다른 글
시대를 초월할 마음 Ep.01-02 (0) | 2018.03.24 |
---|---|
<1-2> How To Play "River Flows In You" On Guitar (arranged by Sunga Jung) (guitar lesson / tutorial) Part 2 (0) | 2018.02.12 |
<1-2> 파이썬 입문
동영상 강의 : http://pythonkim.tistory.com/notice/77
IDE : PyCharm
# Day_01_01_Basic.py
1 | print('Hello python!') |
- 위 한줄을 실행(구동). Run 메뉴 - Run... // 단축키 art+shit+F10
- ... 은 바로 실행되지 않고, 별도의 창이 뜬다는 뜻.
- 파이참은 파일 기반으로 원하는 파일을 선택하여 실행
- 실행한 파일을 다시 실행할 땐, shift+F10
# 문제
# Hello, python! 을 3회 출력하는 코드를 3가지 만들어보기
1 2 3 4 5 6 7 8 9 | print('Hello python!Hello python!Hello python!') print('Hello python!'*3) print('Hello python!') print('Hello python!') print('Hello python!') print("Hello python!" "Hello python!" "Hello python!") | cs |
- 이런 방법들이 있다.
- 마지막의 경우처럼 큰 따옴표를 여러개 늘어놓는 방법도 있다. (작은 따옴표로도 가능하다.)
- 파이썬에서 문자열을 '...' 와 "..."가 완벽하게 동일하다고 한다.
- 마지막의 경우는 하나를 여러개로 나누고 싶을 때 사용한다.
1 2 3 | print("Hello python!" \ "Hello python!" \ "Hello python!") | cs |
- 백슬래쉬( \ ) 로 윗줄과 아랫줄을 연결을 한다.
- 눈에 보이는 그대로 나열을 할 수 있게 된다. (중요..!!)
- 데이터와 데이터를 쉼표로 분리하기.
1 2 | print("Hello python!" "Hello python!" "Hello python!") # Hello python!Hello python!Hello python! | cs |
>> 다른 언어를 사용해봤다면 생각해야 한다고 하신다. 반성합니다....
- 모든 프로그래밍 언어는 출력하는 함수는 한번에 여러개를 전달하는 옵션을 제공한다.
( 가변인자 )
- print 함수( print() ) 는 따옴표로 묶어 놓은 것을을 화면에 출력한다.
# 프로그래밍 : 프로그램을 만드는 과정
# 프로그램의 구성 요소 : 코드, 데이터
# 데이터 : 변수(변하는 데이터), 상수(변하지 않는 데이터)
# 데이터 : 숫자(실수 float, 정수 integer), 문자(문자열, string), 논리값(boolean)
- 여러가지 형태의 데이터 출력해보기.
1 2 | print(3.14, 56, "string", True) print(type(3.14), type(56), type("string"), type(True)) | cs |
- 실행결과
3.14 56 string True
<class 'float'> <class 'int'> <class 'str'> <class 'bool'>
# 파이썬에서는 실제로 데이터 타입(자료형)은 존재하지 않는다. 하지만 내부적으로는 구분을 한다.
# 3.14 는 내부적으로 float 이라는 이름을 사용한다.
# 내가 만들지 않은 데이터를 확인할 때 type() 을 사용한다.
# 여기서 56은 56으로만 사용 가능하다. 그래서 상수라고 한다.
- 변수 만들기
1 2 | a = 3.14 print(3.14, a) | cs |
- 실행결과
3.14 3.14
# = 는 대입연산자(assignment), 오른쪽에 있는 값을 왼쪽에 있는 변수에 넣겠다.
# 여기서 a 는 변수.
1 2 3 4 5 | a = 3.14 print(3.14, a, type(a)) a = 56 print(a, type(a)) | cs |
- 실행결과
3.14 3.14 <class 'float'>
56 <class 'int'>
# 상수는 읽기만 하는 변수.
# 변수는 읽기도 하고 , 쓰기도 할 수 있는 변수.
# 상수가 하는 일은 변수가 다 할 수 있지만, 변수가 하는 일은 상수가 다 하지 못한다.
- newline '\n'
1 | print('Hell\no python!') # newline, 개행문자 | cs |
- 작은따옴표와 큰따옴표를 쓰고싶을 때.
1 2 | print('"Hello"') # "Hello" print("'Hello'") # 'Hello' | cs |
- 줄 긋기...
1 | print('-'*50) # -------------------------------------------------- | cs |
- 참고로 주석('#')의 단축키는 command+'/' (Win 에서는 Ctrl + / )
>> 블럭지정 후 한번에 주석처리 가능하다.
- swap
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | a = 7 b = 19 print(a, b) # 7, 19 # 문제 # 아래쪽 코드에서 거꾸로 출력하도록 코드 추가하기 # a와 b를 서로 교환한다. # a = 19 # b = 7 # 위에서 값을 변경하면 이 코드는 의미가 없어진다. # 콜라와 주스가 담긴 컵이 있다. 내용물을 바꾸고 싶다. 어떻게? tmp = a # 빈컵이 필요..!! a = b b = tmp print(a, b) | cs |
>> 전에 튜터링을 하면서 지우개 두 개로 설명을 해줬는데, 그때는 공중부양을 시켜 바꿨던 튜티가
생각이 난다. 앞으로 콜라와 주스를 통해 설명해줘야겠다.
- 다중치환
1 2 | a, b = b, a print(a, b) | cs |
>> 하지만 python 에서 위와 같은 방법은 멍청한 짓이다.
>> 대입 연산자를 통해 값을 여러개 전달 가능하다.
>> 성능은 위보다는 조금 느리다고 한다.
- 위에서 두 개의 변수를 만들어 초기화 하는 방법은 아래와 같이 할 수 있다.
1 2 3 | # a = 7 # b = 19 a, b = 7, 19 | cs |
- 한 줄에 여러줄을 표현하고 싶을 땐 ';'으로 구분할 수는 있다.
1 | a = 7; b = 19 |
>> 권장하는 문법은 아니다. 파이썬에서는 ';'를 잘 사용하지 않는다.
'Language > Python' 카테고리의 다른 글
<1-7> 정규표현식 with Python (0) | 2018.02.03 |
---|---|
<1-6> 정규표현식 (Regular Expression) (0) | 2018.02.02 |
<1-5> 함수(function) (0) | 2018.02.01 |
<1-4> 제어문(if) (0) | 2018.01.31 |
<1-3> 연산자 (0) | 2018.01.30 |
[1463] 1로 만들기
DP1 - basic
- go(n) : 3개의 연산을 적절히 사용했을 때, n을 1로 만드는 회수의 최소값.
< 소스코드 - top down >
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 | #include <stdio.h> #define INF 0x3f3f3f3f int d[1000001]; int go(int n) { int a, b, c, ans; a = b = c = INF; if(n == 1) return 0; if(d[n]) return d[n]; if(n%3 == 0) a = go(n/3)+1; if(n%2 == 0) b = go(n/2)+1; c = go(n-1)+1; ans = a < b ? a : b; ans = ans < c ? ans : c; return d[n] = ans; } int main() { int n; scanf("%d", &n); printf("%d\n", go(n)); return 0; } | cs |
< 소스코드 - bottom up >
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | #include <stdio.h> int main() { int i, n, d[1000001]; scanf("%d", &n); d[1] = 0; for(i=2; i<=n; i++) { d[i] = d[i-1] + 1; if(i%2 == 0 && d[i] > d[i/2]+1) d[i] = d[i/2]+1; if(i%3 == 0 && d[i] > d[i/3]+1) d[i] = d[i/3]+1; } printf("%d\n", d[n]); return 0; } | cs |
-
'BOJ > DP' 카테고리의 다른 글
[2302] 극장 좌석 (0) | 2018.02.05 |
---|---|
[1937] 욕심쟁이 판다 (0) | 2018.02.01 |
[1309] 동물원 (0) | 2018.02.01 |
[1932] 숫자삼각형 (0) | 2018.02.01 |
[1149] RGB 거리 (0) | 2018.01.30 |
<5> node-mysql (Typescript)
-mysql module 정의하기
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | import * as mysql from 'mysql'; /** MySQL DB 연결 */ export module mysqlUtil { export const pool = mysql.createPool({ host : 'host', user : 'user', password : 'password', database : 'database', timezone : 'UTC', connectionLimit : 50, waitForConnections : true }); } | cs |
>> 다수의 Connection 관리 기법인 Connection Pool 방식을 사용하였다.
Pool 에서 Connection을 사용하고, Pool 에 반납.
(https://nesoy.github.io/articles/2017-04/Nodejs-MySQL)
DB Connection Pool 에 대한 이야기는 아래 URL 참고.
https://www.holaxprogramming.com/2013/01/10/devops-how-to-manage-dbcp/
>> mysql.createPool(option);
>> connectionLimit : 최대 커넥션 갯수
>> waitForConnections : pool 에 여유 커넷션이 없는 경우 대기 여부 설정
'H6 > backend (Node.js, tsc)' 카테고리의 다른 글
<7> REST API & CRUD (0) | 2018.01.31 |
---|---|
<6> tsconfig.json 을 통한 컴파일 옵션 설정 (0) | 2018.01.31 |
<4> MySQL & node-mysql (0) | 2018.01.22 |
<3> 에러처리.. (0) | 2018.01.22 |
<2> app.ts 및 server.ts 만들기 (0) | 2018.01.22 |
<4> MySQL & node-mysql
https://www.opentutorials.org/course/2136/12020 참고
< 설치 >
- 비트나미를 이용한 설치 (https://bitnami.com/stack/mamp)
- 설치중 맨 아래를 제외하고 체크 해제.
- pw 설정
$ cd /App(tab)/mamp(tab)/mysql/bin
$ ./mysql -uroot -p
>> 설정한 pw 입력
mysql>
정상설치..!!
< 구조 >
테이블
레코드(행)
필드(열)
데이터베이스 (연관된 테이블들의 묶음)
하나의 애플리케이션이 하나의 데이터베이스에 대응.
하나의 PC에는 여러 개의 애플리케이션이 설치.
이것들을 그룹핑하는 것이 데이터베이스 서버 라는 것..!! (opentutorials.ort:3306)
...
< MySQL 사용하기 >
$ ./mysql (-hlocalhost) -uroot -p
$ ./mysql -hopentutorial.org -P3306 -uroot -p // 이런식으로도 접속 가능
즉 데이터베이스 서버에 접속을 하고 인증 과정을 거친 상태..!!
다음으로는 데이터베이스의 테이블을 만들기 위해 데이터베이스를 만들어야 함.
( 데이터베이스 서버 != 데이터베이스 )
mysql>
데이터베이스 보기
1 | show databases; |
데이터베이스 생성
1 | CREATE DATABASE o2 CHARACTER SET utf8 COLLATE utf8_general_ci; |
데이터베이스 선택
1 | use o2; |
테이블 생성
1 2 3 4 5 6 7 | CREATE TABLE `topic` ( `id` int (11) NOT NULL AUTO_INCREMENT, `title` varchar (100) NOT NULL , `description` text NOT NULL , `author` varchar (30) NOT NULL , PRIMARY KEY (id) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; |
생성된 테이블 확인
1 | show tables; |
데이터 삽입
1 2 | INSERT INTO topic (title, description, author) VALUES ( 'JavaScript' , 'Computer language for web.' , 'egoing' ); INSERT INTO topic (title, description, author) VALUES ( 'NPM' , 'Package manager' , 'leezche' ); |
테이블 내용 확인
mysql> select * from topic; // topic 테이블에 있는 모든 행을 가져온다.
< MySQL UPDATE & DELETE >
mysql> update topic set TITLE='npm' where id='2'; // topic 테이블에서 id가 2인 TITLE 을 npm 으로 변경
mysql> delete from topic where id='2';
< node-mysql : 접속 & SELECT & INSERT & UPDATE & DELETE >
- js로 어떻게 mysql 을 제어하는가
- node-mysql 설치
$ npm install --save node-mysql
https://github.com/mysqljs/mysql 참고
코드 예시
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 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 | var mysql = require('mysql'); var conn = mysql.createConnection({ host : 'localhost', user : 'root', password : '111111', database : 'o2' }); conn.connect(); var sql = 'SELECT * FROM topic'; conn.query(sql, function(err, rows, fields){ if(err){ console.log(err); } else { for(var i=0; i<rows.length; i++){ console.log(rows[i].title); } } }); var sql = 'INSERT INTO topic (title, description, author) VALUES(?, ?, ?)'; var params = ['Supervisor', 'Watcher', 'graphittie']; conn.query(sql, params, function(err, rows, fields){ if(err){ console.log(err); } else { console.log(rows.insertId); } }); var sql = 'UPDATE topic SET title=?, author=? WHERE id=?'; var params = ['NPM', 'leezche', 1]; conn.query(sql, params, function(err, rows, fields){ if(err){ console.log(err); } else { console.log(rows); } }); var sql = 'DELETE FROM topic WHERE id=?'; var params = [1]; conn.query(sql, params, function(err, rows, fields){ if(err){ console.log(err); } else { console.log(rows); } }); conn.end(); | cs |
- 21, 30 행 확인해보기..!!
- ? 는 치환자를 두고 치환자의 순서에 따라 파라미터를 실제 값을 배열로 생성한 다음 쿼리문의 두번째 인재 값으로 전달 가능 // 보안 관련 sql injection attack 을 막을 수 있음..!!
'H6 > backend (Node.js, tsc)' 카테고리의 다른 글
<6> tsconfig.json 을 통한 컴파일 옵션 설정 (0) | 2018.01.31 |
---|---|
<5> node-mysql (Typescript) (0) | 2018.01.22 |
<3> 에러처리.. (0) | 2018.01.22 |
<2> app.ts 및 server.ts 만들기 (0) | 2018.01.22 |
<1> Node.js, Express, Typescript 환경설정 (0) | 2018.01.21 |
<3> 에러처리..
-
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 35 36 | import * as express from 'express'; import * as bodyParser from 'body-parser'; //import { testRoutes } from './apis/test/route/test.route'; export class Server { /** app 에 대한 타입 설정 */ public app: express.Application; constructor() { /** express 설정을 위한 express 선언 */ this.app = express(); /** bodyParser 선언 */ this.app.use(bodyParser.urlencoded({extended: false})); /** 라우터 */ //this.app.user(testRoutes.testRouter); /** Not Found */ this.app.use( (req: express.Request, res: express.Response, next: Function) => { /** * Error 라는 정의가 있지만 Error 에는 status 라는 정의가 없어서 any 설정 */ const err: any = new Error('not_found'); err.status = 404; next(err); }); /** 에러 처리 */ this.app.use((err: any, req: express.Request, res: express.Response) => { err.status = err.status || 500; console.error(`error on request ${req.method} | ${req.url} | $err.status}`); console.error(err.stack || `${err.message}`); err.message = err.status == 500 ? 'Somthing bad happened.' : err.message; res.status(err.status).send(err.message); }); } } | cs |
- '가 아닌 `
- 아직 잘 모르겠음. 추후 포스팅 하기..
'H6 > backend (Node.js, tsc)' 카테고리의 다른 글
<6> tsconfig.json 을 통한 컴파일 옵션 설정 (0) | 2018.01.31 |
---|---|
<5> node-mysql (Typescript) (0) | 2018.01.22 |
<4> MySQL & node-mysql (0) | 2018.01.22 |
<2> app.ts 및 server.ts 만들기 (0) | 2018.01.22 |
<1> Node.js, Express, Typescript 환경설정 (0) | 2018.01.21 |
<2> app.ts 및 server.ts 만들기
< app.ts >
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | import * as express from 'express'; import * as bodyParser from 'body-parser'; import { testRoutes } from './apis/test/route/test.route'; export class Server { /** app 에 대한 타입 설정 */ public app: express.Application; constructor() { /** express 설정을 위한 express 선언 */ this.app = express(); /** bodyParser 선언 */ this.app.use(bodyParser.urlencoded({extended: false})); /** 라우터 */ this.app.user(testRoutes.testRouter); } } | cs |
$ npm install body-parser --save
- 모듈 가져오기
>> import * as express from 'express'; 를 통해 모듈을 불러올 수 있다
< body-parser >
- npm 모듈 중 request body 를 json 형식으로 변환해 주는 모듈
- express 를 통해 만든 app 객체의 .use() 를 활용하여 bodyParser.urlencoded() 를 해준다.
- extended 는 아래 설명대로... (https://stackoverflow.com/questions/29960764/what-does-extended-mean-in-express-4-0)
If extended is false, you can not post "nested object" person[name] = 'caw' // Nested Object = { person: { name: cw } } If extended is true, you can do whatever way that you like. |
참고 2 : http://sjh836.tistory.com/154
< server.ts >
1 2 3 4 5 6 7 8 9 10 11 | import { Server } from './app'; import * as express from 'express'; const port: number = 80; const app: express.Application = new Server().app; app.set('port', port); app.listen(app.get('port'), () => { console.log('server listening on port ' + port); }).on('error', err => { console.error(err); }); | cs |
컴파일 후
$ sudo node server 를 통해 서버를 실행시킬 수 있다.
'H6 > backend (Node.js, tsc)' 카테고리의 다른 글
<6> tsconfig.json 을 통한 컴파일 옵션 설정 (0) | 2018.01.31 |
---|---|
<5> node-mysql (Typescript) (0) | 2018.01.22 |
<4> MySQL & node-mysql (0) | 2018.01.22 |
<3> 에러처리.. (0) | 2018.01.22 |
<1> Node.js, Express, Typescript 환경설정 (0) | 2018.01.21 |