'Mysql'에 해당되는 글 16건

  1. 2014.02.15 [Mysql] - 랜덤 데이터 뽑기
  2. 2013.08.31 [Mysql] - Mysql 문자열 + 숫자 +1 예제
  3. 2012.12.27 [Mysql] - DB Create 구문
  4. 2012.11.05 [Mysql] - AES_ENCRYPT, AES_DECRYPT 암호화, 복호화
  5. 2012.04.23 [Mysql] - ERROR 1418 (HY000): This function has none of DETERMINISTIC 해답
  6. 2011.11.23 [Mysql] - mysql SUBSTRING_INDEX 함수사용법
  7. 2011.11.16 [Mysql] - 날짜 함수 사용법, 예제
  8. 2011.09.07 [Mysql] - CONCAT 쿼리문 Values 에 문자열 추가하기
  9. 2011.08.17 [Mysql] - #HY000Table '' is marked as crashed 오류 해결방법
  10. 2011.08.12 [Mysql] - Can't find file: (errno: 13) 에러 복구방법

[Mysql] - 랜덤 데이터 뽑기

Mysql 2014. 2. 15. 15:02
반응형

SELECT * 

   FROM RANDOM_TABLE

  LIMIT rand(), 1


랜덤으로 1라인의 데이터를 뽑아 옵니다 rand() 함수

반응형
:

[Mysql] - Mysql 문자열 + 숫자 +1 예제

Mysql 2013. 8. 31. 16:11
반응형

SELECT IFNULL(CONCAT('A', LPAD(ABS( MAX( REPLACE(COMPANY_CODE, 'A', '') ) + 1), 7, 0)), 'A0000001')

반응형
:

[Mysql] - DB Create 구문

Mysql 2012. 12. 27. 13:53
반응형

CREATE DATABASE PAINBLOG DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;

반응형
:

[Mysql] - AES_ENCRYPT, AES_DECRYPT 암호화, 복호화

Mysql 2012. 11. 5. 16:22
반응형

SELECT HEX(AES_ENCRYPT('비밀번호', '변환할 코드명')) -- 암호 암호화


SELECT AES_DECRYPT(UNHEX('필드명'), '변환할 코드명') -- 암호 복호화


반응형
:

[Mysql] - ERROR 1418 (HY000): This function has none of DETERMINISTIC 해답

Mysql 2012. 4. 23. 11:48
반응형

ERROR 1418 (HY000): This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its declaration and binary logging is enabled (you *might* want to use the less safe log_bin_trust_function_creators variable)




1. mysql 서버를 시작할 때 다음 옵션을 추가 한다.

    --log-bin-trust-function-creators=1

2. 계정에 접속해서 다음을 실행한다. 
   mysql>SET GLOBAL log_bin_trust_function_creators = 1;


반응형
:

[Mysql] - mysql SUBSTRING_INDEX 함수사용법

Mysql 2011. 11. 23. 09:11
반응형
EMAIL = asdf@tistory.com

SELECT SUBSTRING_INDEX(EMAIL, "@", 1) EMAIL1,
            SUBSTRING_INDEX(EMAIL, "@", -1) EMAIL2 
  FROM ABC 

EMAIL1 = asdf 
EMAIL2 = tistory.com 
반응형
:

[Mysql] - 날짜 함수 사용법, 예제

Mysql 2011. 11. 16. 14:24
반응형
출처 : http://radiocom.kunsan.ac.kr/lecture/mysql/day_time_function.html



DATEOFWEEK(date) : 날짜에 대한 요일을 정수로 반환한다, 
                   1=일요일, 2=월요일, 7=토요일을 의미한다. 
【예제】 
mysql> SELECT DAYOFWEEK(CURDATE()), DAYOFWEEK('2007-11-12'); 
+----------------------+-------------------------+
| DAYOFWEEK(CURDATE()) | DAYOFWEEK('2007-11-12') |
+----------------------+-------------------------+
|                    2 |                       2 |
+----------------------+-------------------------+

 
WEEKDAY(date) : date에 대한 요일을 반환한다.
                0=월요일,....,6=일요일을 의미한다. 
【예제】
mysql> SELECT WEEKDAY(CURDATE()), WEEKDAY('2007-11-12');
+--------------------+-----------------------+
| WEEKDAY(CURDATE()) | WEEKDAY('2007-11-12') |
+--------------------+-----------------------+
|                  0 |                     0 |
+--------------------+-----------------------+
 

DAYOFMONTH(date) : 날짜 date에 대한 월중 값을 1∼31범위에서 반환한다. 

【예제】 
mysql> SELECT DAYOFMONTH(CURDATE()),DAYOFMONTH('2007-11-12'); 
+-----------------------+--------------------------+
| DAYOFMONTH(CURDATE()) | DAYOFMONTH('2007-11-12') |
+-----------------------+--------------------------+
|                    12 |                       12 |
+-----------------------+--------------------------+

 
DAYOFYEAR(date) : 날짜 date에 대한 년중 값을 1∼366범위에서 반환한다. 

【예제】 
mysql> SELECT DAYOFYEAR(CURDATE()), DAYOFYEAR('2007-11-12'); 
+----------------------+-------------------------+
| DAYOFYEAR(CURDATE()) | DAYOFYEAR('2007-11-12') |
+----------------------+-------------------------+
|                  316 |                     316 |
+----------------------+-------------------------+

 
MONTH(date) : date값을 1∼12월로 반환한다. 

【예제】 
mysql> SELECT MONTH(CURDATE()), MONTH('2007-11-12'); 
+------------------+---------------------+
| MONTH(CURDATE()) | MONTH('2007-11-12') |
+------------------+---------------------+
|               11 |                  11 |
+------------------+---------------------+

 
DAYNAME(date) : 날짜 date의 요일을 반환한다. 

【예제】 
mysql> SELECT DAYNAME(CURDATE()),DAYNAME('2007-11-12'); 
+--------------------+-----------------------+
| DAYNAME(CURDATE()) | DAYNAME('2007-11-12') |
+--------------------+-----------------------+
| Monday             | Monday                |
+--------------------+-----------------------+

 
MONTHNAME(date) : 날짜 date의 달(월)을 반환한다. 

【예제】 
mysql> SELECT MONTHNAME(CURDATE()),MONTHNAME('2007-11-12'); 
+----------------------+-------------------------+
| MONTHNAME(CURDATE()) | MONTHNAME('2007-11-12') |
+----------------------+-------------------------+
| November             | November                |
+----------------------+-------------------------+

 
QUARTER(date) : 날짜 date의 분기 값을 1∼4로 반환한다. 

【예제】 
mysql> SELECT QUARTER(CURDATE()),QUARTER('2007-11-12'); 
+--------------------+-----------------------+
| QUARTER(CURDATE()) | QUARTER('2007-11-12') |
+--------------------+-----------------------+
|                  4 |                     4 |
+--------------------+-----------------------+
 
WEEK(date) 
WEEK(date,first) : 날짜 date의 1년 중  주값으로 1∼53범위 내에서 반환하며,
              week(date)는 일요일부터 시작하지만, 
              week(date,first)는 일요일부터 시작(first=0)하는 경우나 
                                 월요일부터 시작하는 경우(first=1)처럼 지정할 수 있다. 

【예제】 
mysql> SELECT WEEK(CURDATE()),WEEK('2007-11-12'); 
+-----------------+--------------------+
| WEEK(CURDATE()) | WEEK('2007-11-12') |
+-----------------+--------------------+
|              45 |                 45 |
+-----------------+--------------------+

mysql> SELECT WEEK(CURDATE(),0), WEEK(CURDATE(),1); 
+-------------------+-------------------+
| WEEK(CURDATE(),0) | WEEK(CURDATE(),1) |
+-------------------+-------------------+
|                45 |                46 |
+-------------------+-------------------+

 
YEAR(date) : 날짜 date를 년으로 1000∼9999범위에서 반환한다. 

【예제】 
mysql> SELECT YEAR(CURDATE()),YEAR('2007-11-12'); 
+-----------------+--------------------+
| YEAR(CURDATE()) | YEAR('2007-11-12') |
+-----------------+--------------------+
|            2007 |               2007 |
+-----------------+--------------------+

 
YEARWEEK(date) 
YEARWEEK(date,first)   :  날짜 date에 대한 년과 달을 반환하며,  
                          first의 경우는 week(date,first)의 사용법이 같다. 

【예제】 
mysql> SELECT YEARWEEK(CURDATE()),YEARWEEK('2007-11-12'); 
+---------------------+------------------------+
| YEARWEEK(CURDATE()) | YEARWEEK('2007-11-12') |
+---------------------+------------------------+
|              200745 |                 200745 |
+---------------------+------------------------+

mysql> SELECT YEARWEEK(CURDATE()), YEARWEEK(CURDATE(),1); 
+---------------------+-----------------------+
| YEARWEEK(CURDATE()) | YEARWEEK(CURDATE(),1) |
+---------------------+-----------------------+
|              200745 |                200746 |
+---------------------+-----------------------+

 
HOUR(time) 
MINUTE(time) 
SECOND(time) : 입력값 time을 시, 분, 초로 반환한다. 

【예제】 
mysql> SELECT HOUR(CURDATE()),MINUTE(CURDATE()),SECOND(CURDATE()); 
+-----------------+-------------------+-------------------+
| HOUR(CURDATE()) | MINUTE(CURDATE()) | SECOND(CURDATE()) |
+-----------------+-------------------+-------------------+
|               0 |                20 |                 7 |
+-----------------+-------------------+-------------------+

 
PERIOD_ADD(p,n) : YYMM이나 YYYYMM으로 표시되는 기간 p에 n 개월을 더한다. 

【예제】 
mysql> SELECT  PERIOD_ADD(200745,3); 
+----------------------+
| PERIOD_ADD(200745,3) |
+----------------------+
|               201012 |
+----------------------+

 
PERIOD_DIFF(p1,p2) : YYMM이나 YYYYMM으로 표기되는 p1과 p2의 차이 개월을 반환 한다. 

【예제】 
mysql> SELECT PERIOD_DIFF(200207,0107); 
+--------------------------+ 
| PERIOD_DIFF(200207,0107) | 
+--------------------------+ 
|                       12 | 
+--------------------------+ 

 
DATE_ADD(date,INTERVAL expr type) 
DATE_SUB(date,INTERVAL expr type) 
ADDDATE(date,INTERVAL expr type) 
SUBDATE(date,INTERVAL expr type) : 
           날짜 date에 type 형식으로 지정한 expr값을 더하거나 뺀다. 
           DATE_ADD()와 ADDDATE()는 같은 동작이고,
           DATE_SUB()와 SUBDATE()는 같은 의미이다.
            여기서 표현되는 type, expr 형식은 다음과 같다. 
SECOND	SECONDS
MINUTE	MINUTES
HOUR	HOURS
DAY	DAYS
MONTH	MONTHS
YEAR	YEARS
MINUTE_SECOND	"MINUTES:SECONDS"
HOUR_MINUTE	"HOURS:MINUTES"
DAY_HOUR	"DAYS HOURS"
YEAR_MONYH	"YEARS-MONTHS"
HOUR_SECOND	"HOURS:MINUTES:SECONDS"
DAY_MINUTE	"DAYS HOURS:MINUTES"
DAY_SECOND	"DAYS HOURS:MINUTES:SECONDS"






【예제】     
mysql> SELECT DATE_ADD('2007-12-31 23:59:59', INTERVAL 1 SECOND); 
+----------------------------------------------------+
| DATE_ADD('2007-12-31 23:59:59', INTERVAL 1 SECOND) |
+----------------------------------------------------+
| 2008-01-01 00:00:00                                |
+----------------------------------------------------+

 
EXTRACT(type FROM date) : 이 함수는 DATE_ADD(), DATE_SUB()와 같이 원하는 부분을 추출한다. 

【예제】 
mysql> SELECT EXTRACT(YEAR FROM '2007-11-12'); 
+---------------------------------+
| EXTRACT(YEAR FROM '2007-11-12') |
+---------------------------------+
|                            2007 |
+---------------------------------+

mysql> SELECT EXTRACT(YEAR_MONTH FROM '2007-11-12 01:22:33'); 
+------------------------------------------------+
| EXTRACT(YEAR_MONTH FROM '2007-11-12 01:22:33') |
+------------------------------------------------+
|                                         200711 |
+------------------------------------------------+

mysql> SELECT EXTRACT(DAY_MINUTE FROM '2007-11-12 01:22:33'); 
+------------------------------------------------+
| EXTRACT(DAY_MINUTE FROM '2007-11-12 01:22:33') |
+------------------------------------------------+
|                                         120122 |
+------------------------------------------------+

 
TO_DAYS(date) : 입력된 date값에 대한 0년을 기준으로 한 날짜 수를 반환한다. 

【예제】 
mysql> SELECT TO_DAYS(NOW()); 
+----------------+
| TO_DAYS(NOW()) |
+----------------+
|         733357 |
+----------------+

 
FROM_DAYS(n) : 입력된 날짜 수 n에 대한 연월일을 반환한다. 

【예제】 
mysql> select from_days('733357'); 
+---------------------+
| from_days('733357') |
+---------------------+
| 2007-11-12          |
+---------------------+

mysql> select from_days(to_days(now())); 
+---------------------------+
| from_days(to_days(now())) |
+---------------------------+
| 2007-11-12                |
+---------------------------+
 

DATE_FORMAT(date,format) : 입력된 date를 format 형식으로 반환한다. 
사용되는 format 형식은 다음과 같다. 
%M	영문 달 이름(January...December)
%W	요일명(Sunday...Saterday)
%D	날짜의 서수표기(1st,2nd,3rd....)
%Y	4자리 년표기
%y	2자리 년표기
%X	일요일부터 시작하는 주수를 4자리로 표기
%x	월요일부터 시작하는 주수를 4자리로 표기
%a	단축된 요일명 표기(Sun...Sat)
%d	월중 날짜를 숫자로 표기(00...31)
%e	월중 날짜를 숫자로 표기(0...31)
%m	숫자로 표기된 월(01...12)
%c	숫자로 표기된 월(1...12)
%b	단축된 달 이름 표기(Jan...Dec)
%j	년중 일수 표기(001...366)
%H	24시간 표기(00...23)
%k	24시간 표기(0...23)
%h	12시간 표기(01...12)
%I	12시간 표기(01...12)
%l	12시간 표기(1...12)
%i	분의 숫자 표기(00...59)
%r	12시간 표기(hh:mm:ss [AP]M)
%T	24시간 표기(hh:mm:ss)
%S	초 표기(00...59)
%s	초 표기(00...59)
%p	AM 또는 PM
%w	요일을 숫자로 표기(0=일요일...6=토요일)
%U	일요일부터 시작하는 수준 표기(0...53)
%u	월요일부터 시작하는 수준 표기(0...53)
%V	일요일부터 시작하는 수준 표기(1...53)
%v	월요일부터 시작하는 수준 표기(1...53)
%%	% 문자 표기






【예제】 
mysql> SELECT DATE_FORMAT(CURDATE(),'%W %M %Y'); 
+-----------------------------------+
| DATE_FORMAT(CURDATE(),'%W %M %Y') |
+-----------------------------------+
| Monday November 2007              |
+-----------------------------------+

mysql> SELECT DATE_FORMAT(CURDATE(),'%Y.%m.%d'); 
+-----------------------------------+
| DATE_FORMAT(CURDATE(),'%Y.%m.%d') |
+-----------------------------------+
| 2007.11.12                        |
+-----------------------------------+

 
TIME_FORMAT(time,format) : 이 함수는 DATE_FORMAT() 함수처럼 쓰이지만, 
                                 format은 시분초만 지정한다. 

【예제】 
mysql> select time_format(curtime(), '%r');
+------------------------------+
| time_format(curtime(), '%r') |
+------------------------------+
| 09:29:40 AM                  |
+------------------------------+
 

 
CURDATE() 
CURRENT_DATE : 오늘 날짜를 YYYY-MM-DD나 YYYYMMDD 형식으로 반환한다. 

【예제】 
mysql> SELECT CURDATE(),CURRENT_DATE; 
+------------+--------------+
| CURDATE()  | CURRENT_DATE |
+------------+--------------+
| 2007-11-12 | 2007-11-12   |
+------------+--------------+

 
CURTIME() 
CURRENT_TIME : 현재 시각을 HH:MM:SS나 HHMMSS 형식으로 반환한다. 

【예제】 
mysql> SELECT CURTIME(),CURRENT_TIME; 
+-----------+--------------+ 
| CURTIME() | CURRENT_TIME | 
+-----------+--------------+ 
| 14:31:51  | 14:31:51     | 
+-----------+--------------+ 
 

NOW() 
SYSDATE() 
CURRENT_TIMESTAMP : 오늘 현시각을 YYYY-MM-DD HH:MM:SS나 YYYYMMDDHHMMSS 형식으로  반환한다. 

【예제】 
mysql> SELECT NOW(),SYSDATE(),CURRENT_TIMESTAMP; 
+---------------------+---------------------+---------------------+
| NOW()               | SYSDATE()           | CURRENT_TIMESTAMP   |
+---------------------+---------------------+---------------------+
| 2007-11-12 09:33:38 | 2007-11-12 09:33:38 | 2007-11-12 09:33:38 |
+---------------------+---------------------+---------------------+
 

UNIX_TIMESTAMP() 
UNIX_TIMESTAMP(date) : 입력으로 주어진 날짜를 1970-01-01 00:00:00부터 계산한 시간값을 반환한다. 

【예제】 
mysql> SELECT UNIX_TIMESTAMP(),UNIX_TIMESTAMP(CURDATE()); 
+------------------+---------------------------+
| UNIX_TIMESTAMP() | UNIX_TIMESTAMP(CURDATE()) |
+------------------+---------------------------+
|       1194827645 |                1194793200 |
+------------------+---------------------------+
 

FROM_UNIXTIME(unix_timestamp[,format]) : unix_timestamp 값을 DATE_FORMAT()과 같은 형태로 반환한다. 
 unix_timestamp 값을 YYYY-MM-DD HH:MM:SS나 YYYYMMDDHHMMSS 형태로 반환한다. 

【예제】 
mysql> SELECT FROM_UNIXTIME(UNIX_TIMESTAMP(),'%Y.%d.%m'); 
+--------------------------------------------+
| FROM_UNIXTIME(UNIX_TIMESTAMP(),'%Y.%d.%m') |
+--------------------------------------------+
| 2007.12.11                                 |
+--------------------------------------------+

mysql> SELECT FROM_UNIXTIME(UNIX_TIMESTAMP()); 
+---------------------------------+
| FROM_UNIXTIME(UNIX_TIMESTAMP()) |
+---------------------------------+
| 2007-11-12 09:35:02             |
+---------------------------------+
 

SEC_TO_TIME(seconds) 
TIME_TO_SEC(time) : 입력한 time을 초단위 변환한다. 

【예제】 
mysql> SELECT TIME_TO_SEC(CURTIME()), SEC_TO_TIME(CURTIME()); 
+------------------------+------------------------+
| TIME_TO_SEC(CURTIME()) | SEC_TO_TIME(CURTIME()) |
+------------------------+------------------------+
|                  34530 | 25:58:50               |
+------------------------+------------------------+
반응형
:

[Mysql] - CONCAT 쿼리문 Values 에 문자열 추가하기

Mysql 2011. 9. 7. 10:12
반응형
$values1 = "1234";
INSERT INTO TABLE_NAME (A,B,C) VALUES (CONCAT('BBS_', $values1), '$b', '$c')

결과물

A 라는 컬럼에는 'BBS_1234' 라는 값이 추가됩니다.
반응형
:

[Mysql] - #HY000Table '' is marked as crashed 오류 해결방법

Mysql 2011. 8. 17. 10:30
반응형

사용법

mysql -u root -p 1234 로 mysql 접속후
use databasesname; 데이터베이스 선택후

check table 테이블명; 으로 테이블 체크후
repair table 테이블명; 으로 테이블 복구 하시면됩니다.


반응형
:

[Mysql] - Can't find file: (errno: 13) 에러 복구방법

Mysql 2011. 8. 12. 16:40
반응형
Can't find file: (errno: 13)

에러가 뜨면 현재 페이지가 db에 접근을 할수가 없어서 생기는 오류입니다.

그럴때 mysql db폴더로 가서 db의 소유자와 그룹을 변경해주면

원상 복구 됩니다. 

궁금하신점은 댓글 달아주세요 
반응형
: