버전올라가기전

create table 테이블명 (num int(11) not nulll default '0' auto_increment);

- default '0'  기본값 0부터시작하게 함

- auto_increment 기본값부터 1씩 레코드 입력될 때 마다 증가시킴


!! mysql 버전올라가면서 default값 넣는게 사라짐


버전올라간 후

create table 테이블명 (num int(11) not nulll auto_increment);

- auto_increment 디폴트값없이 자동증가만 넣어주면됨


블로그 이미지

왕왕왕왕

,

대소문자 관계 없다.



1. 테이블에 새로운 컬럼 추가하기


ALTER TABLE [테이블명] ADD COLUMN [추가할 컬럼명] [추가할 컬럼 데이타형];


2. 테이블에 컬럼 속성값 변경하기


ALTER TALBE [테이블명] MODIFY COLUMN [추가할 컬럼명] [추가할 컬럼 데이타형];


'데이터베이스 > Mysql' 카테고리의 다른 글

Mysql 주석처리  (0) 2015.07.04
Mysql 데이터값 자동증가  (0) 2015.07.03
Mysql 함수 - 날짜관련,날짜변환  (0) 2015.07.01
mysql 셀렉터를 이용한 검색  (0) 2015.06.11
mysql 열 추가 삭제 (기본 쿼리)  (0) 2014.05.20
블로그 이미지

왕왕왕왕

,

 출처 - http://selfesteem.tistory.com/7


- DAYOFWEEK(date) : 해당 날짜의 요일을 숫자로 반환한다. 일요일은 1, 토요일은 7 이다. 

- 예 : select DAYOFWEEK('1998-02-03'); 


- WEEKDAY(date) : 해당 날짜에 대한 요일을 반환한다. 월요일은 0, 일요일은 6 이다. 

- 예 : select WEEKDAY('1997-10-04 22:23:00'); 


- DAYOFYEAR(date) : 해당 날짜의 1월 1일부터의 날수를 반환한다. 결과값은 1에서 366 까지이다. 

- 예 : select DAYOFYEAR('1998-02-03'); 


- YEAR(date) : 해당 날짜의 년을 반환한다. 

- 예 : select YEAR('98-02-03'); 


- MONTH(date) : 해당 날짜의 월을 반환한다. 

- 예 : select MONTH('1998-02-03'); 


- DAYOFMONTH(date) : 해당 날짜의 일을 반환한다. 결과값은 1 에서 31 까지이다. 

- 예 : select DAYOFMONTH('1998-02-03'); 


- HOUR(time) : 해당날짜의 시간을 반환한다. 결과값은 0 에서 23 이다. 

- 예 : select HOUR('10:05:03'); 


- MINUTE(time) : 해당날짜의 분을 반환한다. 결과값은 0 에서 59 이다. 

- 예 : select MINUTE('98-02-03 10:05:03'); 


- SECOND(time) : 해당날짜의 초를 반환한다. 결과값은 0 에서 59 이다. 

- 예 : select SECOND('10:05:03'); 


- DAYNAME(date) : 해당 날짜의 요일 이름을 반환한다. 일요일은 'Sunday' 이다. 

- 예 : select DAYNAME("1998-02-05"); 


- MONTHNAME(date) : 해당 날짜의 월 이름을 반환한다. 2월은 'February' 이다. 

- 예 : select MONTHNAME("1998-02-05"); 


- QUARTER(date) : 해당 날짜의 분기를 반환한다. 결과값은 1 에서 4 이다. 


- WEEK(date,first) : 1월 1일부터 해당날가지의 주 수를 반환한다. 주의 시작을 일요일부터 할경우는 두번째 인자를 0, 월요일부터 시작할 경우는 1 을 넣는다. 결과값은 1 에서 52 이다. 

- 예 : select WEEK('1998-02-20',1); 


- PERIOD_ADD(P,N) : P (형식은 YYMM 또는 YYYYMM 이어야 한다.) 에 N 만큼의 달 수를 더한값을 반환한다. 주의할것은 두번째 인자는 숫자라는 것이다. 

- 예 : select PERIOD_ADD(9801,2); 


- PERIOD_DIFF(P1,P2) : 두개의 인자 사이의 달 수를 반환한다. 두개의 인자 모두 형식은 YYMM 또는 YYYYMM 이어야 한다. 


- DATE_ADD(date,INTERVAL expr type) : 날짜를 더한 날짜를 반환한다. 

- DATE_SUB(date,INTERVAL expr type) : 날짜를 뺀 날짜를 반환한다. 

- ADDDATE(date,INTERVAL expr type) : DATE_ADD(date,INTERVAL expr type) 와 동일하다. 

- SUBDATE(date,INTERVAL expr type) : DATE_SUB(date,INTERVAL expr type) 와 동일하다. 

- EXTRACT(type FROM date) : 날짜에서 해당 부분을 추출한다. 

- 예 : SELECT DATE_ADD("1997-12-31 23:59:59", INTERVAL 1 SECOND); 

SELECT DATE_ADD("1997-12-31 23:59:59", INTERVAL 1 DAY); 

SELECT DATE_ADD("1997-12-31 23:59:59", INTERVAL "1:1" MINUTE_SECOND); 

SELECT DATE_SUB("1998-01-01 00:00:00", INTERVAL "1 1:1:1" DAY_SECOND); 

SELECT DATE_ADD("1998-01-01 00:00:00", INTERVAL "-1 10" DAY_HOUR); 

SELECT DATE_SUB("1998-01-02", INTERVAL 31 DAY); 

SELECT EXTRACT(YEAR FROM "1999-07-02"); 

SELECT EXTRACT(YEAR_MONTH FROM "1999-07-02 01:02:03"); 

SELECT EXTRACT(DAY_MINUTE FROM "1999-07-02 01:02:03"); 

- 참고 : type 에 사용되는 키워드는 SECOND, MINUTE, HOUR, DAY, MONTH, YEAR, MINUTE_SECOND, HOUR_MINUTE, DAY_HOUR, YEAR_MONTH, HOUR_SECOND, DAY_MINUTE, DAY_SECOND 이다. 

- 주의 : 계산한 달의 날수가 작을 경우는 해당달의 마지막 날을 반환한다. 예를 들어 select DATE_ADD('1998-01-30', Interval 1 month); 의 경우 1998-02-28 을 반환한다. 


- TO_DAYS(date) : 0 년 부터의 날짜수를 반환한다. 이 함수는 1582 이전 날에 대해서는 계산하지 않는다. 

- 예 : select TO_DAYS(950501); 


- FROM_DAYS(N) : 해당 숫자만큼의 날짜를 반환한다. 이 함수는 1582 이전 날에 대해서는 계산하지 않는다. 

- 예 : select FROM_DAYS(729669); 


- DATE_FORMAT(date,format) : 날짜를 해당 형식의 문자열로 변환하여 반환한다. 

- 예 : select DATE_FORMAT('1997-10-04 22:23:00', '%W %M %Y'); 

select DATE_FORMAT('1997-10-04 22:23:00', '%H:%i:%s'); 

select DATE_FORMAT('1997-10-04 22:23:00', '%D %y %a %d %m %b %j'); 

select DATE_FORMAT('1997-10-04 22:23:00', '%H %k %I %r %T %S %w'); 

- 참고 : 형식은 다음과 같다. %M (달 이름), %W (요일 이름), %Y (YYYY 형식의 년도), %y (YY 형식의 년도), %a (요일 이름의 약자), %d (DD 형식의 날짜), %e (D 형식의 날짜), %m (MM 형식의 날짜), %c (M 형식의 날짜), %H (HH 형식의 시간, 24시간 형식), %k (H 형식의 시간, 24시간 형식), %h (HH 형식의 시간, 12시간 형식), %i (MM 형식의 분), %p (AM 또는 PM) 


- TIME_FORMAT(time,format) : DATE_FORMAT(date,format) 과 같은 방식으로 사용할수 있으나 날 이상의 것에 대해서는 NULL 이나 0 을 반환한다. 


- CURDATE() : 현재날짜를 반환한다. 숫자와 연산을 할경우 숫자로 변환된다. 형식은 'YYYY-MM-DD' 또는 YYYYMMDD 이다. 

- 예 : select CURDATE(); 

select CURDATE() + 0; 


- CURTIME() : 현재시간을 반환한다. 숫자와 연산을 할경우 숫자로 변환된다. 형식은 'HH:MM:SS' 또는 HHMMSS 이다. 

- 예 : select CURTIME(); 

select CURTIME() + 0; 


- SYSDATE() : 현재날짜시간을 반환한다. 숫자와 연산을 할경우 숫자로 변환된다. 형식은 'YYYY-MM-DD HH:MM:SS' 또는 YYYYMMDDHHMMSS 이다. 

- 예 : select NOW(); 

select NOW() + 0; 


- NOW() : SYSDATE() 와 동일하다. 


- UNIX_TIMESTAMP() : '1970-01-01 00:00:00' 부터의 초를 반환한다. 인자가 주어질 경우는 해당 날짜에 대한 유닉스 시간을 반환한다. 

- 예 : select UNIX_TIMESTAMP(); 

select UNIX_TIMESTAMP('1997-10-04 22:23:00'); 


- FROM_UNIXTIME(unix_timestamp) : 유닉스시간에서 날짜 형식으로 변환한다. 

- 예 : select FROM_UNIXTIME(875996580); 


- FROM_UNIXTIME(unix_timestamp,format) : 유닉스시간을 날짜형식으로 변환하고 DATE_FORMAT(date,format) 에서 설명한 포맷으로 변환하여 반환한다. 

- 예 : select FROM_UNIXTIME(UNIX_TIMESTAMP(), '%Y %D %M %h:%i:%s %x'); 


- TIME_TO_SEC(time) : 해당 시간의 0:0:0 에서부터의 초를 반환한다. 

- 예 : select TIME_TO_SEC('22:23:00'); 


- SEC_TO_TIME(seconds) : 초를 시간으로 바꾼다. 

- 예 : select SEC_TO_TIME(2378);

블로그 이미지

왕왕왕왕

,

select [destinct] 테이블명 {, 테이블명} * from  필드명 {. 필드명} * [where 검색조건] [order by 필드명 [asc or desc] {, 필드명 [asc or desc]} *] [group by 필드명 {, 필드명} *] [having  검색조건] ; 

1. 일반적 검색 
mysql>  select name, id  from uncle where level='a' ; 
=> uncle 테이블에 level이 a인 데이터의 name, id을 보여준다. 

mysql>  select * from uncle; 
=> uncle 테이블에 있는 모든 데이터를 보여준다. 

2. 결과 레코드의 중복 제거 
mysql>  select distinct level from uncle; 
=> uncle 데이블에 level의 종류가 몇개인지 알수가 있다. 

3. 조건검색 
mysql>  select name, id from uncle where age > 20 and level = 'a'; 
=> uncle 데이블에 age가 20보다 크고 level 이 a인 name, id을 보여준다. 
(검색조건을 표시하는 where절에는 비교연산자 > , >=, <, <=, = 와 논리연산자 and, or, not 을 사용할수 있다. 

4. 검색 결과의 정렬 
mysql>  select name, id from uncle where age > 20 order by level desc; 
=> uncle 데이블에 age가 20보다  큰 name, id을 level 내림차순으로 보여준다. 
(asc 는 오름차순, desc는 내림차순 asc나 desc가 없이 order by만 쓴다면 기본값 asc로 설정된다.) 

5. 검색 결과에 대한 산술 계산 및 문자열 처리 
mysql>  select name, '님의 아이디는', id, '입니다.'  from uncle where age > 20 order by level ; 
=> uncle 데이블에 age가 20보다  큰 name, id을 level 오림차순으로 보여준다. 
결과는 ' name 님의 아이디는 id 입니다. ' 이렇게 보인다. 

mysql>  select name, age+5  from uncle where id = 'uncle' ; 
=> uncle 데이블에 id가 uncle 인 레코드의 name, 원래 age보다 +5 해서 결과를 보여준다. 

6. 그룹함수(group function)를 이용한 검색 
mysql>  select count(*)  from uncle where level = 'a' ; 
=> uncle 데이블에 level 이 a을 만족하는 레코드 결과를 보여준다. 
* count(필드명) : 조건을 만족하는 레코드의 개수 
* sum(필드명)  : 해당 필드의 합 
* min(필드명)    : 해당 필드의 최대값 
* max(필드명)  : 해당 필드의 최소값 
* avg(필드명)    : 해당 필드의 평균값 

7. group by를 이용한 검색 
mysql>  select level max(age), min(age), avg(age) from uncle group by level ; 
=> uncle 데이블에 level 과 최대 age값, 최소 age값, 평균 age 값을 level 별로 결과를 보여준다. 

8. having을 이용한 검색 
mysql>  select level max(age), min(age), avg(age) from uncle group by level having level = 'a' ; 
=> uncle 데이블에 level 과 최대 age값, 최소 age값, 평균 age 값을 level a의 결과만 보여준다. 
(having문은 group by에서 지정한 필드에 대한 검색 조건문이다.) 

9. between  연산자를 이용한 검색 
mysql>  select name, id from uncle where level = 'a' and age between 20 and 25 ; 
=> uncle 데이블에 age가 20 ~ 25 이고 level 이 a 인 레코드의 name, id 을 보여준다. 
* mysql>  select name, id from uncle where level = 'a' and age >= 20 and  age <=25 ; 와 같다. 

mysql>  select name, id from uncle where level in ('a', 'b') ; 
=> uncle 데이블에 level이 a, b 인 name, id을 보여준다. 

mysql>  select name, id from uncle where level not in ('a', 'b') ; 
=> uncle 데이블에 level이 a, b 을 제외한 name, id을 보여준다. 

10. like을 이용한 검색 
mysql>  select name, id from uncle where name like '%용%' ; 
=> uncle 데이블에 name에 '용' 포함되어 있는 name, id을 보여준다. 
('%용' 이면 용으로 끝나는 레코드를 '용%'이면 용으로 시작하는 레코드를 보여준다.) 

11. null 값을 이용한 검색 
mysql>  select name, id from uncle where level is null ; 
=> uncle 데이블에 level 값이 null 인 name, id을 보여준다.

블로그 이미지

왕왕왕왕

,

mysql> alter table 테이블명 add 추가할필드명 varchar(10);  -> 열추가
mysql> alter table 테이블명 drop 삭제할필드명 ;      ->열삭제


mysql> alter table 테이블명 change 기존필드명 바꿀필드명  varchar(30);-> 열변경

 

 

 

alter table 테이블명 change column 기존필드명 필드명 int (11);  자료형 변경 

( 필드명은 기존의 필드명을 따라가도 상관없지만 자료형을 바꾸면서 필드명도 같이 변경이 가능함)

 

 

alter table 기존테이블명 rename 바꿀테이블명; 테이블명 변경

 

'데이터베이스 > Mysql' 카테고리의 다른 글

Mysql 함수 - 날짜관련,날짜변환  (0) 2015.07.01
mysql 셀렉터를 이용한 검색  (0) 2015.06.11
Mysql 데이터베이스 생성  (0) 2014.05.18
sql 레코드 변경 및 삭제  (0) 2014.05.15
Mysql INSERT 문  (0) 2014.05.15
블로그 이미지

왕왕왕왕

,

create database 데이터베이스명;

 

이상 끝

'데이터베이스 > Mysql' 카테고리의 다른 글

mysql 셀렉터를 이용한 검색  (0) 2015.06.11
mysql 열 추가 삭제 (기본 쿼리)  (0) 2014.05.20
sql 레코드 변경 및 삭제  (0) 2014.05.15
Mysql INSERT 문  (0) 2014.05.15
sql 테이블 생성 및 제거  (0) 2014.05.15
블로그 이미지

왕왕왕왕

,

1. 변경

 

select * from 테이블명; // 테이블에 어떤 레코드들이 있는지 확인

 

update [테이블명] set [필드명] = '필드값' where [필드명] = '필드값';

 

 

set 필드명 // 이부분이 바뀔부분이고,

where 필드명 // 이부분이 바뀔 레코드 검색

 

2.삭제

 

delete from [테이블명] where [필드명] = '필드값';

 

where 필드명 = '필드값'; 을 가지는 레코드는 삭제된다.

 

'데이터베이스 > Mysql' 카테고리의 다른 글

mysql 열 추가 삭제 (기본 쿼리)  (0) 2014.05.20
Mysql 데이터베이스 생성  (0) 2014.05.18
Mysql INSERT 문  (0) 2014.05.15
sql 테이블 생성 및 제거  (0) 2014.05.15
user 계정생성 및 오류대처  (0) 2014.04.29
블로그 이미지

왕왕왕왕

,

 

1.추가

insert into 테이블명(필드명,필드명1,필드명2,필드명3) values('값','값1','값2','값3');

 

select * from 테이블명; // 레코드 추가한거 확인

 

2.검색

 

select * from 테이블명 where 조건 ='찾을내용';

 

찾을내용에서 문자만 ' ' 을 이용해 하고

숫자는 없이 그냥 해도된다.

 

조건은 필드명으로 한다.

 

블로그 이미지

왕왕왕왕

,