- Today
- Total
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 재능이의 돈버는 일기
- StresslessLife
- K_JIN2SM
- 소소한 일상
- My Life Style & Memory a Box
- Blog's generation
- 공감 스토리
- 취객의 프로그래밍 연구실
- Love Me
- Dream Archive
- 세상에 발자취를 남기다 by kongmingu
- hanglesoul
- 카마의 IT 초행길
- 느리게.
- 미친듯이 즐겨보자..
- Joo studio
- Gonna be insane
- 악 다 날아갔어!! 갇대밋! 왓더...
- xopowo05
- 맑은공기희망운동
- 엔지니어 독립운동
- 혁준 블로그
- Simple in Complex with Simple
- 무의식이 의식을 지배한다
목록★─Programing/☆─DBMS (16)
드럼치는 프로그래머
[출처] http://walkingfox.tistory.com/31https://code.i-harness.com/ko/q/ff292해당 URL의 소중한 자료 정독 후 프로그래밍 학습에 도움이 되었음을 밝힙니다.MSSQL 에서 랜덤넘버를 발생하는 코드는 간단하다. Select rand() 하지만, 위의 코드로 여러 행에 걸쳐서 랜덤한 숫자를 발생시키려 하면 각 행마다 같은 랜덤넘버가 적용되어버린다. 이럴때는이렇게 처리하면 된다. select rand(convert(varbinary, newid())) 1000에서 9999 사이의 난수 생성 :FLOOR(RAND(CHECKSUM(NEWID()))*(9999-1000)+1000)
에러) Exception in thread "main" java.sql.SQLException: Column 'COL_NM' not found. 해결) JDBC 커넥션 맺을때 아래 옵션 추가 useOldAliasMetadataBehavior=true 출처: http://hothoony.tistory.com/430 [organizing]
MSSQL을 사용하면 ~에서 ~까지 검색을 하기 위해 between 을 많이 사용합니다. between?? select * from 테이블 where 컬럼명 between '시작' and '끝' ex) select * from products where idx between 1 and 100 (products테이블에서 IDX 값이 1~100까지를 검색하라) 라는 방식으로 많이 쓰입니다. 그리고 많이 사용하는것이 몇일부터 몇일까지 데이터를 추출할때도 많이 사용합니다. select * from 테이블 where 컬럼명 between '시작일' and '끝일' ex) select * from products where registdate between '2013-03-01' and '2013-03-04' (2..
DB 테이블을 다룰 때, 특정 조건의 데이터가 존재하는 경우에는 해당 row를 원하는 값으로 update하고, 없는 경우에는 새로운 데이터를 insert를 해야하는 경우가 왕왕 있습니다. 이럴 때 보통은 select 쿼리를 먼저해보고 데이터가 있는지 없는지 판단을 해서 update를 할 지 insert를 할 지 분기해서 처리했었는데요. oracle에서 MERGE INTO라는 구문을 쓰면 하나의 쿼리로 두가지 경우에 모두 대처할 수 있습니다. 아래와 같이 쓰면 됩니다. table을 지정했기 때문에 MATCHED, NOT MATCHED 이하에 update문과 insert문에 table_name은 생략됩니다. MERGE INTO table_name alias USING (table | view | subque..
MSSQL IDENTITY 값 초기화하기 자동으로 증가되는 IDENTITY(시퀀스)의 값을 변경하기 위한 쿼리입니다. 테이블에 있는 데이터를 삭제해도 IDENTITY의 값은 변경되지 않습니다. 그러므로 아래의 명령어를 사용하여 명시적으로 변경해줘야합니다. 아래의 쿼리를 실행하면 현재 IDENTITY의 값을 확인할 수 있습니다.(변경되지 않음) DBCC CHECKIDENT(테이블명, NORESEED) 아래의 쿼리를 실행하면 IDENTITY의 값이 1로 초기화됩니다. 현재 존재하는 데이터의 MAX(SEQ)를 마지막 파라미터에 넣어주면 자동으로 그 다음 번호가 일련번호로 생성됨 DBCC CHECKIDENT(테이블명, RESEED, 0) 아래의 쿼리를 실행하면 IDENTITY의 값이 현재 컬럼보다 작을 경우 값..
[MySQL] INFORMATION_SCHEMA INFORMATION_SCHEMA는 데이터베이스의 메타데이터를 조회하게 해준다. 데이터들의 데이터라 불리는 메타!!데이터!! 중요하다!! 데이터베이스 또는 테이브르이 이름, 컬럼의 데이터 타입, 또는 접근권한과 같은 것을 말한다. 어디서는 DD(Data dictionary) 라고도 함 INFORMATION_SCHEMA는 정보데이터베이스로 MySQL서버가 운영하는 모든 다른 데이터베이스에 대한 정보를 저장하는 장소이다. [테이블 종류] INFORMATION_SCHEMA.TABLE : 데이터베이스에 있는 테이블에 대한 정보 제공 INFORMATION_SCHEMA.COLUMNS : 테이블에 있는 컬럼의 정보를 제공함 INFORMATION_SCHEMA.STATIS..
right("000000"+convert(varchar(6),@last_num),6) 손님 님이 쓰신 글 > ---------------------------------------------------------- > OS : Microsoft Windows 2000 Server / Advanced Server > SQL : Microsoft SQL Server 2000 Standard / Enterprise Edition > > 주문번호를 만드는 프로시져인데 날짜 YYYYMMDD다음6자리 순번을 붙입니다. > 헌데 > @yyyymmdd+right("000000"+convert(varchar(6),@last_num),6); > 이 부분에서 자꾸 아래와 같은 에러가 납니다. > varchar 값 "2004..
게시판에서 상세페이지 들어갔을때, 하단에 현재 글을 기준으로 이전글, 다음글로 이동하는 부분이 있습니다. 이를 쿼리로 어떻게 구해오는지를 말씀드리겠습니다. 만약 게시판 테이블이 다음과 같이 있다고 합니다. [board] seq : 시퀀스 title : 제목 ... 이전글의 시퀀스는 다음의 쿼리로 구해옵니다. select max(seq) from board where seq $seq 그리고 제목은 위에서 구한 시퀀스를 가지고 select 해오시면 됩니다. select title from b..
select num, title, lead(title,1,'다음글') over (order by num) next_title, lag(title,1,'이전글') over (order by num ) pre_title, from Tboard 요렇게 하면 간단하게 위에 레코드(lead), 아래 레코드(lag)를 참조하여 값을 가져올수가 있다. 주의 할 점은 where num='3' 과 같이 하면 next,title, pre_title 값이 null이 된다. where 절을 사용 할 시에는 경우에 따라 다음과 같이 해줘야 한다. select * from ( select num, title, lead(title,1,'다음글') over (order by num) next_title, lag(title,1,'이전..
- MSSQL 날짜 변환표 (기준날짜를 대상으로 CONVERT 실행하여 날짜 형변환) 번호 쿼리 결과 코드 0 CONVERT(CHAR(19), DATETIME, 0) 01 02 2000 1:14PM MM DD YYYY H:MM 1 CONVERT(CHAR(10), DATETIME, 1) 01/02/2000 MM/DD/YYYY 2 CONVERT(CHAR(8), DATETIME, 2) 00.01.02 YY.MM.DD 3 CONVERT(CHAR(8), DATETIME, 3) 02/01/00 DD/MM/YY 4 CONVERT(CHAR(8), DATETIME, 4) 02.01.00 DD.MM.YY 5 CONVERT(CHAR(8), DATETIME, 5) 02-01-00 DD-MM-YY 6 CONVERT(CHAR(8..