검색결과 리스트
전체에 해당되는 글 153건
- 2010.03.02 로그파일 줄이기
- 2010.02.04 [자바스크립트] trim 문자열 자르기
- 2010.02.04 자바스크립트 날짜 함수
- 2010.01.26 msSql 숫자
- 2010.01.19 MS- SQL 날짜 시간
- 2009.10.06 엄무 분석부터 시스템 개발 설계를 위한 UML 실무 태크닉 정리~!
- 2009.09.28 Eclipse + Spring 설치
- 2009.09.28 Eclipse 오류 (JVM terminated. Exit code=-1) (windows7 64 eclipse)
- 2009.09.28 Head First Design Patterns 생각해 볼만한 글.
- 2009.09.28 Eclipse + Maven2 플러그인 설치
글
1.MSSQL서버매니저에서
새쿼리를 선택해서 backup log DB명 with no_log 를 실행
2.개체탐색기의 해당 DB명에서 우클릭으로 작업>축소>파일 을 선택
3.파일축소 팝업화면에서
파일유형:로그 선택
축소작업:사용하지 않는 공간 해제 선택
확인버튼 클릭
(처리는 1~2초정도)
4.로그파일 싸이즈 확인(97G -> 1.25M)
[출처] [mssql]로그파일 축소방법|작성자
설정
트랙백
댓글
글
자바 트름 없음 .. ㅡ..ㅡ ;; 만들었다 퍼왔다 .. 인터넷에 널리고 널렸다 나하하 .. 저건 정규화다
function trim(str){
return str.replace(/(^\s*)|(\s*$)/g,"");
}
function trim(str){
return str.replace(/(^\s*)|(\s*$)/g,"");
}
설정
트랙백
댓글
글
**
* 날짜관련 자바스크립트 공통함수
*
* 분단위 이하(= 초)는 고려하지 않았습니다.
* YYYYMMDDHHMI 형식의 String => 'Time'으로 칭함
*
* 주로 YYYYMMDD 까지만 쓰인다면 아래 함수들을
* YYYYMMDD 형식의 String => 'Date'로 하여 적당히
* 수정하시거나 아니면 함수를, 예를들어 isValidDate()처럼,
* 추가하시기 바랍니다.
*
* @version 2.0, 2001/01/28
* @author 박종진(JongJin Park), jongjpark@lgeds.lg.co.kr
*/
/**
* 유효한(존재하는) 월(月)인지 체크
*/
function isValidMonth(mm) {
var m = parseInt(mm,10);
return (m >= 1 && m <= 12);
}
/**
* 유효한(존재하는) 일(日)인지 체크
*/
function isValidDay(yyyy, mm, dd) {
var m = parseInt(mm,10) - 1;
var d = parseInt(dd,10);
var end = new Array(31,28,31,30,31,30,31,31,30,31,30,31);
if ((yyyy % 4 == 0 && yyyy % 100 != 0) || yyyy % 400 == 0) {
end[1] = 29;
}
return (d >= 1 && d <= end[m]);
}
/**
* 유효한(존재하는) 시(時)인지 체크
*/
function isValidHour(hh) {
var h = parseInt(hh,10);
return (h >= 1 && h <= 24);
}
/**
* 유효한(존재하는) 분(分)인지 체크
*/
function isValidMin(mi) {
var m = parseInt(mi,10);
return (m >= 1 && m <= 60);
}
/**
* Time 형식인지 체크(느슨한 체크)
*/
function isValidTimeFormat(time) {
return (!isNaN(time) && time.length == 12);
}
/**
* 유효하는(존재하는) Time 인지 체크
* ex) var time = form.time.value; //'200102310000'
* if (!isValidTime(time)) {
* alert("올바른 날짜가 아닙니다.");
* }
*/
function isValidTime(time) {
var year = time.substring(0,4);
var month = time.substring(4,6);
var day = time.substring(6,8);
var hour = time.substring(8,10);
var min = time.substring(10,12);
if (parseInt(year,10) >= 1900 && isValidMonth(month) &&
isValidDay(year,month,day) && isValidHour(hour) &&
isValidMin(min)) {
return true;
}
return false;
}
/**
* Time 스트링을 자바스크립트 Date 객체로 변환
* parameter time: Time 형식의 String
*/
function toTimeObject(time) { //parseTime(time)
var year = time.substr(0,4);
var month = time.substr(4,2) - 1; // 1월=0,12월=11
var day = time.substr(6,2);
var hour = time.substr(8,2);
var min = time.substr(10,2);
return new Date(year,month,day,hour,min);
}
/**
* 자바스크립트 Date 객체를 Time 스트링으로 변환
* parameter date: JavaScript Date Object
*/
function toTimeString(date) { //formatTime(date)
var year = date.getFullYear();
var month = date.getMonth() + 1; // 1월=0,12월=11이므로 1 더함
var day = date.getDate();
var hour = date.getHours();
var min = date.getMinutes();
if (("" + month).length == 1) { month = "0" + month; }
if (("" + day).length == 1) { day = "0" + day; }
if (("" + hour).length == 1) { hour = "0" + hour; }
if (("" + min).length == 1) { min = "0" + min; }
return ("" + year + month + day + hour + min)
}
/**
* Time이 현재시각 이후(미래)인지 체크
*/
function isFutureTime(time) {
return (toTimeObject(time) > new Date());
}
/**
* Time이 현재시각 이전(과거)인지 체크
*/
function isPastTime(time) {
return (toTimeObject(time) < new Date());
}
/**
* 주어진 Time 과 y년 m월 d일 h시 차이나는 Time을 리턴
* ex) var time = form.time.value; //'20000101000'
* alert(shiftTime(time,0,0,-100,0));
* => 2000/01/01 00:00 으로부터 100일 전 Time
*/
function shiftTime(time,y,m,d,h) { //moveTime(time,y,m,d,h)
var date = toTimeObject(time);
date.setFullYear(date.getFullYear() + y); //y년을 더함
date.setMonth(date.getMonth() + m); //m월을 더함
date.setDate(date.getDate() + d); //d일을 더함
date.setHours(date.getHours() + h); //h시를 더함
return toTimeString(date);
}
/**
* 두 Time이 몇 개월 차이나는지 구함
* time1이 time2보다 크면(미래면) minus(-)
*/
function getMonthInterval(time1,time2) { //measureMonthInterval(time1,time2)
var date1 = toTimeObject(time1);
var date2 = toTimeObject(time2);
var years = date2.getFullYear() - date1.getFullYear();
var months = date2.getMonth() - date1.getMonth();
var days = date2.getDate() - date1.getDate();
return (years * 12 + months + (days >= 0 ? 0 : -1) );
}
/**
* 두 Time이 며칠 차이나는지 구함
* time1이 time2보다 크면(미래면) minus(-)
*/
function getDayInterval(time1,time2) {
var date1 = toTimeObject(time1);
var date2 = toTimeObject(time2);
var day = 1000 * 3600 * 24; //24시간
return parseInt((date2 - date1) / day, 10);
}
/**
* 두 Time이 몇 시간 차이나는지 구함
* time1이 time2보다 크면(미래면) minus(-)
*/
function getHourInterval(time1,time2) {
var date1 = toTimeObject(time1);
var date2 = toTimeObject(time2);
var hour = 1000 * 3600; //1시간
return parseInt((date2 - date1) / hour, 10);
}
/**
* 현재 시각을 Time 형식으로 리턴
*/
function getCurrentTime() {
return toTimeString(new Date());
}
/**
* 현재 시각과 y년 m월 d일 h시 차이나는 Time을 리턴
*/
function getRelativeTime(y,m,d,h) {
/*
var date = new Date();
date.setFullYear(date.getFullYear() + y); //y년을 더함
date.setMonth(date.getMonth() + m); //m월을 더함
date.setDate(date.getDate() + d); //d일을 더함
date.setHours(date.getHours() + h); //h시를 더함
return toTimeString(date);
*/
return shiftTime(getCurrentTime(),y,m,d,h);
}
/**
* 현재 年을 YYYY형식으로 리턴
*/
function getYear() {
/*
var now = new Date();
return now.getFullYear();
*/
return getCurrentTime().substr(0,4);
}
/**
* 현재 月을 MM형식으로 리턴
*/
function getMonth() {
/*
var now = new Date();
var month = now.getMonth() + 1; // 1월=0,12월=11이므로 1 더함
if (("" + month).length == 1) { month = "0" + month; }
return month;
*/
return getCurrentTime().substr(4,2);
}
/**
* 현재 日을 DD형식으로 리턴
*/
function getDay() {
/*
var now = new Date();
var day = now.getDate();
if (("" + day).length == 1) { day = "0" + day; }
return day;
*/
return getCurrentTime().substr(6,2);
}
/**
* 현재 時를 HH형식으로 리턴
*/
function getHour() {
/*
var now = new Date();
var hour = now.getHours();
if (("" + hour).length == 1) { hour = "0" + hour; }
return hour;
*/
return getCurrentTime().substr(8,2);
}
/**
* 오늘이 무슨 요일이야?
* ex) alert('오늘은 ' + getDayOfWeek() + '요일입니다.');
* 특정 날짜의 요일을 구하려면? => 여러분이 직접 만들어 보세요.
*/
function getDayOfWeek() {
var now = new Date();
var day = now.getDay(); //일요일=0,월요일=1,...,토요일=6
var week = new Array('일','월','화','수','목','금','토');
return week[day];
}
// 여기서 퍼옴
http://ihelpers.x2soft.co.kr/programming/tipntech.php?CMD=view&IDX=540&source=overture#wf
설정
트랙백
댓글
글
제일 자주 쓰는 집계 함수입니다
mssql 랜덤 숫자값 구하기 : select convert(int, abs(rand()*100) ) 0~99까지
출쳐 http://jajking.textcube.com/54
함수종류 |
내용 |
COUNT | 인수들의 총 수 |
SUM | 인수들의 총 합 |
AVG | 인수들의 평균 |
GROUPING | 그룹함수(cube,rollup관련) |
MAX | 식의 최고값 |
MIN | 식의 최소값 |
VARP | 해당 값의 모집단에 대한 분산 |
VAR | 분산 |
STDEV | 표준편차 |
STDEVP | 해당 값의 모집단에 대한 표준편차 |
CHECKSUM | 해당 목록에 대한 검사값 |
CHECKSUM_AGG | Null값을 |
함수종류 |
내용 |
ABS | 절대값 |
RAND | 0과1사이의 랜덤값 |
ROUND | 반올림(사사오입) |
CEILING | 해당값보다 큰 최소 정수값 |
FLOOR | 해당값보다 작은 최대 정수값 |
SIN | 사인 |
COS | 코사인 |
TAN | 탄젠트 |
ASIN | 아크사인 |
ACOS | 아크코사인 |
ATAN | 아크탄젠트 |
ATN2 | 아크탄젠트 |
COT | 코탄젠트 |
DEGREES | 라디안의 단위 |
EXP | 지수 |
LOG | 자연대수 |
RADIANS | 라디안 |
POWER | 거듭제곱 |
PI | 원주율 |
LOG10 | 10을 저점으로한 자연대수 |
SIGN | 부호 |
SQIARE | 제곱 |
SQRT | 평방근 |
mssql 랜덤 숫자값 구하기 : select convert(int, abs(rand()*100) ) 0~99까지
출쳐 http://jajking.textcube.com/54
설정
트랙백
댓글
글
--**********************************************************************
-- 함수(날짜열)
--**********************************************************************
함수(날짜열) | |||
DATE구분 | 구분약자 | DATE구분 | 구분약자 |
year | yy | week | wk |
quarter | hour | hh | |
month | mm | minute | mi |
day of year | dy | second | ss |
day | dd | millisecond | ms |
항목 | 내용 | ||
GETDATE() | 시스템에서 제공하는 날짜와 시간 값 | ||
산술연산 | -- date + NUMBER -- date - NUMBER |
MSSQL] 날짜 형식 변환
date 를 convert 시킬때 형식
SELECT convert(char(10),getdate(),126)
-> 2006-06-02
SELECT convert(char(10),getdate(),102)
-> 2006.06.02
SELECT convert(char(10),getdate(),111)
-> 2006/06/02
SELECT convert(char(10),getdate(),112)
-> 20060602
* 문자열 변환
SELECT convert(char(10),convert(datetime, convert(char(8),cast('20060602' as decimal (10))) ,120),102)
설정
트랙백
댓글
글
컴포넌트 기반의 개발
1) 개발하기전에 충분히 엄무를 분석하여 시스템의 도입 목적을 명시.
2) 엄무 프로세스별로 구분한다.
3) SOA(Serivce Orented Architecture)
2) 엄무 프로세스별로 구분한다.
3) SOA(Serivce Orented Architecture)
모델 드리분 아키텍처 (MDA : Model Driven Architecture)
→ 모델 중심으로 시스템을 개발해 가는 이론으로서 UML의 사양을 관리하는 OME
목적은 여러가지 변화에 유연하게 대응할 수 있는 시스템을 개발하는 것이다.
1) CIM
2) PIM
3) PSM
목적은 여러가지 변화에 유연하게 대응할 수 있는 시스템을 개발하는 것이다.
1) CIM
2) PIM
3) PSM
설정
트랙백
댓글
글
1. help - instra new software
2. 등록 싸이트 http://springide.org/updatesite 이름 Spring
3. add 하면 이와 같은 화면이 출력
3.선택해주고 next
4. next 하면 위에같은 화면
5. 스프링 업데이트 목록 가서 동의 해준다.
6. 완료하면 업데이트 진행한다 완료 .. 이 작업후 에러 화면이 나타날 지도 모른다 ... -_- 이때 eclipse.ini 파일에서 256m 이부분을 한칸 띄어준다.
2. 등록 싸이트 http://springide.org/updatesite 이름 Spring
3. add 하면 이와 같은 화면이 출력
3.선택해주고 next
4. next 하면 위에같은 화면
5. 스프링 업데이트 목록 가서 동의 해준다.
6. 완료하면 업데이트 진행한다 완료 .. 이 작업후 에러 화면이 나타날 지도 모른다 ... -_- 이때 eclipse.ini 파일에서 256m 이부분을 한칸 띄어준다.
설정
트랙백
댓글
글
이클립스 설치후 처음 실행시 JVM terminated. Exit code=-1 로 시작하는 메시지가 뜨면서 실행이 안되는 경우 eclipse.ini파일에서 256M 부분 앞쪽에 한칸 띄워주면 해결된다. 정말 어이가 없다. 이 에러는 Eclipse IDE for Java EE Developers에서 발생하였다. Eclipse Classic 3.3.2은 문제 없이 잘 실행이 되었다.
-----------------------------------------------------------
집에와서 이클리스 설치하니까위와같은 에러 ..
원인은 JDK 64 비트를 깔아서 그런것임.. 다시 32비트로 고고싱 .. 그럼 잘됌 ..-_- ++ 졸린대 말야 ..
참고: http://powerjava.net/blog/soulcarta/201
설정
트랙백
댓글
글
<----> 나름 기억 하고 싶은 말들 <---->
■ 원칙
1. 애플리케이션에서 달라지는 부분을 찾아 내고, 달라지지 않는 부분으로부터 분리 시킨다.
설정
트랙백
댓글
글
자동으로 플러그인 설치 하기.
1. Help - > install new Software 실행
2. add 시킨다 .Name : Maven2 ..... location : http://m2eclipse.sonatype.org/update/
3. maven Integration - > maven integration for Eclipse
4. 화면이 나오는데 . 이화면에서 라이센스 부분에서 동의한다음에 next 선택하면 설치가 진행된다 설치가 완료후
이클립스 재시작한다는 메세지가 나타난다 메세지 확인후 사용하면 끝.
세기 포함 안함(yy)
세기 포함(yyyy)
표준
입력/출력**
--------------------------------------------------------------------------------
날짜 포맷 변환
--------------------------------------------------------------------------------
[ 형식 : 'YYYY.MM.DD' ]
1. Oracle : TO_CHAR(date_exp, 'YYYY.MM.DD')
2. MSSQL : CONVERT(VARCHAR, date_exp, 102)
3. DB2 : REPLACE(CHAR(DATE(date_exp),ISO), '-', '.')
[ 형식 : 'HH:MI:SS' ]
1. Oracle : TO_CHAR(date_exp, 'HH:MI:SS')
2. MSSQL : CONVERT(VARCHAR, date_exp, 108)
3. DB2 : CHAR(TIME(date_exp) , JIS )
[ 형식 : 'YYYY/MM/DD' ]
1. Oracle : TO_CHAR(date_exp, 'YYYY/MM/DD')
2. MSSQL : CONVERT(VARCHAR, date_exp, 111)
3. DB2 : REPLACE(CHAR(DATE(date_exp), ISO), '-', '/')
[ 형식 : 'YYYYMMDD' ]
1. Oracle : TO_CHAR(date_exp, 'YYYYMMDD')
2. MSSQL : CONVERT(VARCHAR, date_exp, 112)
3. DB2 : CHAR(DATE(date_exp))
[ 형식 : 'HH24:MI:SS' ]
1. Oracle : TO_CHAR(date_exp, 'HH24:MI:SS')
2. MSSQL : CONVERT(VARCHAR(8), date_exp, 114)
3. DB2 : CHAR(TIME(date_exp))
[ 형식 : 'YYYY.MM.DD HH24:MI' ]
1. Oracle : TO_CHAR(date_exp, 'YYYY.MM.DD HH24:MI')
2. MSSQL : CONVERT(VARCHAR, date_exp, 102) + ' ' + CONVERT(VARCHAR(5), date_exp, 114)
3. DB2 : REPLACE(CHAR(DATE(date_exp), ISO), '-', '.') || CAST( TIME(date_exp) AS CHAR(5))
[ 형식 : 'YYYY/MM/DD HH24:MI:SS' ]
1. Oracle : TO_CHAR(date_exp, 'YYYY/MM/DD HH24:MI:SS')
2. MSSQL : CONVERT(VARCHAR, date_exp, 111) + ' ' + CONVERT(VARCHAR(8), date_exp, 114)
3. DB2 : REPLACE(CHAR(DATE(date_exp), ISO), '-', '/') || CAST( TIME(date_exp))
-- 숫자만 추출 예제
CREATE FUNCTION ep_GetOnlyNumber(@Str VARCHAR(MAX))
RETURNS VARCHAR(MAX)
AS
BEGIN
DECLARE @retStr varchar(MAX)
SET @retStr = ''
DECLARE @i int
SET @i = 1
While @i <= Len(@Str)
BEGIN
--if isnumeric(substring(@str,@i,1)) = 1 -- isnumeric 사용하면 '-' 도 가져오기 때문에 안됨.
IF substring(@Str,@i,1) BETWEEN '0' AND '9'
SET @retStr = @retStr + substring(@Str,@i,1)
SET @i = @i + 1
END
RETURN @retStr
END
--예제 용 10분뒤의 날짜 20100118000000 14자리형으로 변환
dbo.ep_GetOnlyNumber(CONVERT(varchar, dateadd(mi, -10, getdate()),20))
-->
--********************************************************************
-- YEAR,MONTH,DAY,DATEDIFF함수(날짜열)
--********************************************************************
--year, month, day 해당일의 년월일 값을 돌려준다.
select year(getdate())'year',
month(getdate())'month',
day(getdate())'day'
--datediff(part,date1,date2)/두 날짜 사이의 DATE구분 사이 값을 계산함.
-- (part, date1, date2)
select datediff(dd,'1999/02/15','2000/02/15')'day',
datediff(mm,'1999/02/15','2000/02/15')'month',
datediff(yy,'1999/02/15','2000/02/15')'year'
--
select datediff(dd,'1999/11/06','2000/02/15')'day',
datediff(mm,'1999/11/06','2000/02/15')'month',
datediff(yy,'1999/11/06','2000/02/15')'year'
--회원테이블의 생일과 오늘의 일수 차이를 검색! (Alias는 회원명, 생일, 오늘, 태어난지?)
select mem_name"회원명", mem_bir"생일",
getdate()"오늘",
datediff(dd,mem_bir,getdate())"태어난지?"
from member
--본인의 생년월일과 오늘의 일수 차이를 비교 검색!
select datediff(dd,'1972/08/14',getdate()) "차이는"
--*******************************************************************
-- Datename, Datepart함수(날짜열)
--*******************************************************************
--datename(part,date)/date에서 datepart부분의 ASCII값(구분문자)
--datepart(part,date)/date에서 datepart부분의 정수값(구분숫자)
select convert(char,getdate()), '<==현재날짜'
select datename(yy,getdate()),datepart(yy,getdate()),'<==년도'
select datename(qq,getdate()),datepart(qq,getdate()),'<==분기'
select datename(mm,getdate()),datepart(mm,getdate()),'<==월'
select datename(dy,getdate()),datepart(dy,getdate()),'<==일수'
select datename(dd,getdate()),datepart(dd,getdate()),'<==해당일'
select datename(wk,getdate()),datepart(wk,getdate()),'<==주수'
select datename(dw,getdate()),datepart(dw,getdate()),'<==요일'
select datename(hh,getdate()),datepart(hh,getdate()),'<==시간'
--회원테이블에서 구길동회원의 생일의 DATENAME 과 DATEPART를 검색!
--(Alias 는 회원명, 생일, 기타 上 同)
select mem_name"회원명", mem_bir"생일",
datename(dw,mem_bir)'기타上同',
datepart(dw,mem_bir)'기타上同'
from member
where mem_name='구길동'
/* 월 (2002년 2월)만 입력받아 해당월의 시작일과 종료일을 검색!
Alias는 해당월, 시작일, 종료일) */
--******************** 1. 2002-02-01의 1달 후 -1....
select '200년02월' 해당월, '200-02-01' 시작일,
dateadd(mm,1,'2000-02-01')-1 "종료일"
--******************** 2. 2002-03-01의 1일 전....
select '200년02월' 해당월, '200-02-01' "시작일",
dateadd(dd,-1,'2000-03-01') "종료일"
SQL 기타 함수
select convert(numeric,'123456.9') result1,
cast('123456.9' as numeric) result2
--
select convert(numeric(10,2),'123456.9') result1,
cast('123456.9' as numeric(10,2)) result2
--
select convert(float,'123456.9') result1,
cast('123456.9' as float) result2
--
select convert(decimal,'123456.9') result1,
cast('123456.9' as decimal) result2
--***********************************************************************
-- 함수(conversion) : 날짜로 치환
--***********************************************************************
--날짜로 치환/모양만 날짜형인 문자를 DATE로 치환
select'19990101'result1,'1999-01-01'result2,
'1999-01-01 00:00:00.000'result3
--
select convert(datetime,'20201025',112)" result1",
convert(datetime,'20201025')" result2",
convert(datetime,'2020-10-25 10:15:20.000') " result3",
cast('2020-10-25 10:15:20.000' as datetime) " result4"
--
--회원테이블에서 주민등록번호1을 날짜로 치환한 후 검색!
--(Alias는 회원명, 주민등록번호1, 치환날짜)
select mem_name 회원명, mem_regno1 주민등록번호1,
convert(datetime,'19'+mem_regno1) 치환날짜
from member
--1900년대 사람들만 있다고 가정했을 경우 19를 더해서 밀레니엄버그를 없앨 수 가 있다.
--회원테이블에서 주민등록번호1을 날짜로 치환한 후 500일을 더한 날짜를 검색!
--(Alias는 회원명, 주민등록번호1, 치환날짜)
select mem_name 회원명, mem_regno1 주민등록번호1,
convert(datetime,'19'+mem_regno1) + 500 치환날짜
from member
--회원테이블에서 주민등록번호1을 날짜로 치환한 후 '1974-01-01'부터 '1975-12-31'사이의 날짜를 검색!
--(Alias 회원명, 주민등록번호1, 치환날짜)
select mem_name 회원명, mem_regno1 주민등록번호1,
convert(datetime,'19'+mem_regno1) 치환날짜
from member
where convert(datetime,'19'+mem_regno1)between'1974-01-01'and'1975-12-31'
--회원테이블에서 생일을 문자로 치환한 후 LIKE '1975%'의 조건을 사용하여 해당회원을 검색!
--Alias는 회원명, 생일)
select mem_name 회원명, mem_bir 생일
from member
where convert(char, mem_bir, 121) like '1975%'
--is null, is not null /null값인지 아닌지 비교
--isnull(c,d)/c가 null값이면 d값으로 치환!
--nullif(c,d)/c와 d를 비교하여 같으면 null을, 다르면 c값을 돌려준다.
--AVG(columm)/조회범위 내에 해당 컬럼들의 평균값
-- /DISTINCT : 중복된 값은 제외
-- /ALL : Default로써 모든 값을 포함(all을 쓰지 않아도 Default값으로 적용)
-- /Column명 : NULL값은 제외
-- /* : NULL값도 포함(COUNT함수만 사용)
-- isnull을 사용하여 NUll값은 '0'등으로 나오게 한다.
--ISDATE(c) / 타당한 날짜 포맷인지 확인 : 날짜면 1, 아니면 0
--ISNUMERIC(n) / 타당한 숫자포맷인지 확인 : 숫자면 1, 아니면 0
--CASE WHEN / 연속적인 조건문(자주활용되는 함수)
-- CASE WHEN ~ THEN ~ ELSE ~ END