MySQL: 날짜 문자열을 Unix 타임스탬프로 변환
데이터베이스에서 날짜 문자열을 검색할 때 일관되지 않은 형식 문제가 발생하는 것은 드문 일이 아닙니다. AM 또는 PM 접미사를 포함하는 타임스탬프 등입니다. 이 문서에서는 이러한 날짜 문자열을 Unix 타임스탬프로 효과적으로 변환하는 방법을 보여줍니다.
당면한 특정 문제는 "Apr 15 2012 12:00AM" 형식의 문자열을 Unix 타임스탬프로 변환하는 것입니다. CONVERT(DATETIME, Sales.SalesDate, 103) 및 CONVERT(TIMESTAMP, Sales.SalesDate, 103)을 사용한 초기 시도가 성공하지 못했을 수도 있지만 해결 방법은 다음 단계에 있습니다.
단계 1: 날짜 문자열을 DATETIME으로 변환
시작하려면 날짜를 변환해야 합니다. STR_TO_DATE 함수를 사용하여 문자열을 DATETIME 객체로 변환합니다. 이 함수에는 날짜 문자열과 형식 문자열이라는 두 가지 매개변수가 필요합니다. 이 경우 형식 문자열은 입력 문자열의 형식("%M %d %Y %h:%i%p")과 일치해야 합니다.
STR_TO_DATE('Apr 15 2012 12:00AM', '%M %d %Y %h:%i%p')
2단계: DATETIME을 Unix로 변환 타임스탬프
DATETIME 객체가 있으면 UNIX_TIMESTAMP를 사용하여 이를 Unix 타임스탬프로 변환할 수 있습니다. 기능. 이 함수는 DATETIME 객체를 인수로 사용하고 해당 Unix 타임스탬프를 반환합니다.
UNIX_TIMESTAMP(SELECT STR_TO_DATE('Apr 15 2012 12:00AM', '%M %d %Y %h:%i%p'))
이 단계를 따르면 AM 또는 PM 접미사가 있는 날짜 문자열을 원하는 Unix 타임스탬프 형식으로 성공적으로 변환할 수 있습니다.
추가 서식 고려 사항
원하는 경우 출력 형식이 기본 Unix 타임스탬프와 다르면 FROM_UNIXTIME 함수를 사용하여 형식을 조정하여 추가로 처리할 수 있습니다. 이 함수는 Unix 타임스탬프와 새로운 형식 문자열이라는 두 가지 인수를 사용합니다.
SELECT FROM_UNIXTIME(UNIX_TIMESTAMP(STR_TO_DATE('Apr 15 2012 12:00AM', '%M %d %Y %h:%i%p')),'%m-%d-%Y %h:%i:%p')
이 코드는 Unix 타임스탬프를 "mm-dd-yyyy hh:mm:ss" 형식의 날짜 문자열로 변환합니다.
결론
날짜 변환 방법을 이해함으로써 문자열을 DATETIME 객체로 변환한 다음 Unix 타임스탬프로 변환하면 MySQL에서 날짜 관련 데이터 작업 시 더 큰 유연성을 얻을 수 있습니다. 이 문서에 설명된 기술은 일반적인 형식 문제를 해결하고 날짜 문자열에서 중요한 정보를 추출하는 안정적이고 효율적인 접근 방식을 제공합니다.
위 내용은 AM/PM 접미사가 포함된 MySQL 날짜 문자열을 Unix 타임스탬프로 변환하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!