Mysql은 단순한 개인 애플리케이션부터 대규모 기업 수준의 데이터 웨어하우스 및 상업용 웹사이트에 이르기까지 다양한 유형의 데이터 수집에 적합한 관계형 데이터베이스 관리 시스템입니다. Mysql에서 타임스탬프(Timestamp)는 매우 일반적인 데이터 유형이며 타임스탬프 저장 및 쿼리에 널리 사용됩니다.
그러나 실제 응용 프로그램에서는 때때로 데이터베이스의 타임스탬프를 수정해야 하는 상황에 직면합니다. 예를 들어 특정 레코드의 타임스탬프를 현재 타임스탬프 또는 지정된 타임스탬프로 수정해야 합니다. 그렇다면 MySQL에서 타임스탬프를 수정하는 방법은 무엇입니까? 이 글에서는 다음 사항을 자세히 소개합니다.
1. MySQL에서 타임스탬프는 이벤트가 발생한 특정 시간을 나타내는 데이터 유형입니다. 데이터의 생성 시간과 업데이트 시간은 물론 기타 시간 관련 작업을 기록하는 데 자주 사용됩니다.
Mysql의 타임스탬프는 Unix 타임스탬프와 Mysql 타임스탬프의 두 가지 형식으로 제공됩니다.
Unix 타임스탬프는 1970년 1월 1일 0:00:00부터 현재 시간까지 경과된 초 수를 나타냅니다. 이 타임스탬프 형식을 Mysql에서는 Unix Timestamp라고 합니다. Mysql에 내장된 UNIX_TIMESTAMP() 함수를 사용하여 날짜/시간 유형 시간 데이터를 Unix 타임스탬프로 변환할 수 있습니다. 예:
SELECT UNIX_TIMESTAMP(NOW()) //현재 Unix 타임스탬프 가져오기
Mysql 타임스탬프는 표현된 타임스탬프입니다. YYYY-MM-DD HH:MI:SS 형식입니다. Mysql에 내장된 NOW() 함수를 사용하여 현재 타임스탬프를 가져올 수 있습니다. 예:
SELECT NOW() //현재 Mysql 타임스탬프 가져오기
또한 Mysql은 FROM_UNIXTIME() 함수를 제공하여 Unix 타임스탬프를 Mysql 타임스탬프로 변경합니다. 예:
SELECT FROM_UNIXTIME(1602590500); //Unix 타임스탬프 1602590500을 Mysql 타임스탬프로 변환
2. 타임스탬프를 현재 타임스탬프로 수정합니다
때로는 데이터베이스의 레코드를 변경해야 합니다. 타임스탬프가 현재 타임스탬프로 수정됩니다. Mysql에서는 NOW() 함수를 사용하여 현재 타임스탬프를 가져온 다음 UPDATE 문을 사용하여 해당 레코드의 타임스탬프 필드를 현재 타임스탬프로 업데이트할 수 있습니다. 예:
UPDATE table_name SET timestamp_field = NOW() WHERE id = 1;
그 중 table_name은 테이블 이름, timestamp_field는 타임스탬프 필드 이름, id는 대상 레코드의 기본 키 값입니다.
여러 레코드의 타임스탬프를 현재 타임스탬프로 일괄 업데이트해야 하는 경우 조건문과 결합된 UPDATE 문을 사용할 수 있습니다. 예:
UPDATE table_name SET timestamp_field = NOW() WHERE 조건;
여기서 조건은 다음과 같습니다. 업데이트해야 하는 필터 기록된 조건문. 예를 들어 상태 1인 모든 레코드의 타임스탬프 필드를 업데이트해야 하는 경우 다음 문을 사용할 수 있습니다.
UPDATE table_name SET timestamp_field = NOW() WHERE status = 1
3. 타임스탬프를 지정된 값으로 수정합니다. 타임스탬프
제외 타임스탬프를 현재 타임스탬프로 수정합니다. 때로는 특정 레코드의 타임스탬프를 지정된 타임스탬프로 수정해야 할 수도 있습니다. Mysql에서는 DATE_FORMAT() 함수를 사용하여 지정된 시간 문자열을 MySQL 타임스탬프로 변환할 수 있습니다. 예:
SELECT DATE_FORMAT('2020-10-13 18:03:00', '%Y-%m- % d %H:%i:%s'); //시간 문자열을 Mysql 타임스탬프로 변환
그런 다음 UPDATE 문을 사용하여 해당 레코드의 타임스탬프 필드를 지정된 타임스탬프로 업데이트할 수 있습니다. 예:
UPDATE table_name SET timestamp_field = '2020-10-13 18:03:00' WHERE id = 1;
여기서 '2020-10-13 18:03:00'은 지정된 타임스탬프 문자열이고 table_name은 테이블입니다. name, timestamp_field는 타임스탬프 필드의 이름이고 id는 대상 레코드의 기본 키 값입니다.
여러 레코드의 타임스탬프를 지정된 타임스탬프로 일괄 업데이트해야 하는 경우 조건문과 결합된 UPDATE 문을 사용할 수도 있습니다. 예:
UPDATE table_name SET timestamp_field = '2020-10-13 18:03: 00' WHERE 조건;
where 조건은 업데이트해야 하는 레코드를 필터링하기 위한 조건문입니다. 예를 들어 상태 1인 모든 레코드의 타임스탬프 필드를 2020-10-13 18:03:00으로 업데이트해야 하는 경우 다음 문을 사용할 수 있습니다.
UPDATE table_name SET timestamp_field = '2020-10-13 18 :03:00 ' WHERE status = 1;
IV. 요약
Mysql의 타임스탬프는 일반적인 데이터 유형이며 타임스탬프 저장, 쿼리 및 계산에 널리 사용됩니다. 실제 애플리케이션에서는 타임스탬프를 현재 타임스탬프나 지정된 타임스탬프로 변경하는 등 데이터베이스의 타임스탬프를 수정해야 하는 경우가 있습니다. 현재 타임스탬프를 가져오는 NOW() 함수, 문자열을 Mysql 타임스탬프로 변환하는 DATE_FORMAT() 함수, 타임스탬프 필드를 업데이트하는 UPDATE 문과 같이 해당 Mysql 함수 및 작업을 사용하여 타임스탬프를 수정할 수 있습니다. . 이러한 작업을 마스터하면 MySQL을 사용하여 타임스탬프 데이터를 더 잘 관리할 수 있습니다.
위 내용은 mysql 시간 수정의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!