แปลงเวลาวันที่ JS เป็นวันที่และเวลาของ MySQL


124

ไม่มีใครรู้วิธีแปลง JS dateTime เป็น MySQL datetime นอกจากนี้ยังมีวิธีเพิ่มจำนวนนาทีที่เฉพาะเจาะจงลงใน JS datetime แล้วส่งต่อไปยัง MySQL datetime หรือไม่

คำตอบ:


89

แม้ว่า JS จะมีเครื่องมือพื้นฐานเพียงพอที่จะทำสิ่งนี้ แต่มันก็ค่อนข้างแย่

/**
 * You first need to create a formatting function to pad numbers to two digits…
 **/
function twoDigits(d) {
    if(0 <= d && d < 10) return "0" + d.toString();
    if(-10 < d && d < 0) return "-0" + (-1*d).toString();
    return d.toString();
}

/**
 * …and then create the method to output the date string as desired.
 * Some people hate using prototypes this way, but if you are going
 * to apply this to more than one Date object, having it as a prototype
 * makes sense.
 **/
Date.prototype.toMysqlFormat = function() {
    return this.getUTCFullYear() + "-" + twoDigits(1 + this.getUTCMonth()) + "-" + twoDigits(this.getUTCDate()) + " " + twoDigits(this.getUTCHours()) + ":" + twoDigits(this.getUTCMinutes()) + ":" + twoDigits(this.getUTCSeconds());
};

คุณเรียกฟังก์ชันเช่นนี้ด้วยตัวแปรได้อย่างไร?
ปลาดุก

1
@Catfish คุณหมายถึงวันที่ระบุ? คุณใช้Dateวัตถุ new Date().toMysqlFormat()หรือnew Date(2014,12,14).toMysqlFormat()หรืออะไรก็ตาม
kojiro

17
คำตอบนี้มีวันในขณะที่ JavaScript เก่าและไม่เป็นระเบียบ หากคุณกำหนดเป้าหมายเบราว์เซอร์ที่ทันสมัยผมขอแนะนำให้Gajus'toISOStringวิธีการ
kojiro

321
var date;
date = new Date();
date = date.getUTCFullYear() + '-' +
    ('00' + (date.getUTCMonth()+1)).slice(-2) + '-' +
    ('00' + date.getUTCDate()).slice(-2) + ' ' + 
    ('00' + date.getUTCHours()).slice(-2) + ':' + 
    ('00' + date.getUTCMinutes()).slice(-2) + ':' + 
    ('00' + date.getUTCSeconds()).slice(-2);
console.log(date);

หรือสั้นกว่านั้น:

new Date().toISOString().slice(0, 19).replace('T', ' ');

เอาท์พุท:

2012-06-22 05:40:06

สำหรับกรณีการใช้งานขั้นสูงเพิ่มเติมรวมถึงการควบคุมเขตเวลาให้พิจารณาใช้http://momentjs.com/ :

require('moment')().format('YYYY-MM-DD HH:mm:ss');

สำหรับทางเลือกที่มีน้ำหนักเบาสำหรับ ให้พิจารณาhttps://github.com/taylorhakes/fecha

require('fecha').format('YYYY-MM-DD HH:mm:ss')

คุณมีวงเล็บเปิดเพิ่มเติมก่อน date.getUTCDate และใช่นี่ดีกว่า
Adam Lockhart

28
สิ่งนี้จะทำให้เกิดปัญหาเนื่องจากเขตเวลา
Mr Coder

3
มันทำให้การตั้งค่าเขตเวลาหายไปจะเก็บไว้ได้อย่างไร?
shapeare

2
คอมโบกับสิ่งนี้เพื่อดูแลเขตเวลา: stackoverflow.com/questions/11887934/…
ChiliNUT

3
วิธีแก้ปัญหาแบบเต็มด้วย oneliner เขตเวลา !! var d = new Date(); d.toISOString().split('T')[0]+' '+d.toTimeString().split(' ')[0];
Paulo Roberto Rosa

78

ฉันคิดว่าวิธีการแก้ปัญหาอาจไม่ยุ่งยากน้อยลงโดยใช้วิธีการtoISOString()นี้มีความเข้ากันได้กับเบราว์เซอร์ที่กว้าง

ดังนั้นการแสดงออกของคุณจะเป็นแบบซับเดียว:

new Date().toISOString().slice(0, 19).replace('T', ' ');

ผลลัพธ์ที่สร้างขึ้น:

"2017-06-29 17:54:04"


2
ทำงานได้อย่างยอดเยี่ยม! new Date(1091040026000).toISOString().slice(0, 19).replace('T', ' ');
John

6
ดีเพียงหนึ่งปัญหาที่นี่: วิธีการ clunky มากขึ้นจะได้รับชั่วโมง, วันเดือน (แม้ปี) หลังจากที่แอพลิเคชันของ js Date's โซนเวลาชดเชย ในขณะที่คุณส่งคืนเวลา UTC พื้นฐานในรูปแบบ MySQL DATETIME ในกรณีส่วนใหญ่การจัดเก็บ UTC อาจดีกว่าและไม่ว่าในกรณีใดตารางข้อมูลของคุณควรให้ข้อมูลตำแหน่งในช่องเดียว อีกวิธีหนึ่งในการแปลงเป็นเวลาท้องถิ่นนั้นค่อนข้างง่าย: ใช้... - Date.getTimezoneOffset() * 60 * 1000(NB ยังปรับเวลาออมแสงด้วย)
หนูไมค์

14

ค่าเวลา JS สำหรับ MySQL

var datetime = new Date().toLocaleString();

หรือ

const DATE_FORMATER = require( 'dateformat' );
var datetime = DATE_FORMATER( new Date(), "yyyy-mm-dd HH:MM:ss" );

หรือ

const MOMENT= require( 'moment' );
let datetime = MOMENT().format( 'YYYY-MM-DD  HH:mm:ss.000' );

คุณสามารถส่งสิ่งนี้เป็นพารามิเตอร์จะใช้งานได้


11

สำหรับสตริงวันที่โดยพลการ

// Your default date object  
var starttime = new Date();
// Get the iso time (GMT 0 == UTC 0)
var isotime = new Date((new Date(starttime)).toISOString() );
// getTime() is the unix time value, in milliseconds.
// getTimezoneOffset() is UTC time and local time in minutes.
// 60000 = 60*1000 converts getTimezoneOffset() from minutes to milliseconds. 
var fixedtime = new Date(isotime.getTime()-(starttime.getTimezoneOffset()*60000));
// toISOString() is always 24 characters long: YYYY-MM-DDTHH:mm:ss.sssZ.
// .slice(0, 19) removes the last 5 chars, ".sssZ",which is (UTC offset).
// .replace('T', ' ') removes the pad between the date and time.
var formatedMysqlString = fixedtime.toISOString().slice(0, 19).replace('T', ' ');
console.log( formatedMysqlString );

หรือโซลูชันบรรทัดเดียว

var formatedMysqlString = (new Date ((new Date((new Date(new Date())).toISOString() )).getTime() - ((new Date()).getTimezoneOffset()*60000))).toISOString().slice(0, 19).replace('T', ' ');
console.log( formatedMysqlString );

โซลูชันนี้ใช้ได้กับ Node.js เมื่อใช้ Timestamp ใน mysql

คำตอบแรกของ @Gajus Kuizinas ดูเหมือนจะดัดแปลงต้นแบบ toISOString ของ mozilla


4

ไลบรารีDateJS ที่เคารพมีรูทีนการจัดรูปแบบ (จะแทนที่ ".toString ()") คุณสามารถทำด้วยตัวเองได้อย่างง่ายดายเพราะวิธีการ "วันที่" ให้ตัวเลขทั้งหมดที่คุณต้องการ


4

วิธีแก้ปัญหาแบบเต็ม (เพื่อรักษาเขตเวลา) โดยใช้แนวคิดคำตอบ @Gajus:

var d = new Date(),
    finalDate = d.toISOString().split('T')[0]+' '+d.toTimeString().split(' ')[0];
console.log(finalDate); //2018-09-28 16:19:34 --example output


0

ฉันได้ให้ตัวอย่างรูปแบบวันที่ของ JavaScript อย่างง่ายโปรดตรวจสอบรหัสต่อไปนี้

var data = new Date($.now()); // without jquery remove this $.now()
console.log(data)// Thu Jun 23 2016 15:48:24 GMT+0530 (IST)

var d = new Date,
    dformat = [d.getFullYear() ,d.getMonth()+1,
               d.getDate()
               ].join('-')+' '+
              [d.getHours(),
               d.getMinutes(),
               d.getSeconds()].join(':');

console.log(dformat) //2016-6-23 15:54:16

ใช้momentjs

var date = moment().format('YYYY-MM-DD H:mm:ss');

console.log(date) // 2016-06-23 15:59:08

ตัวอย่างโปรดตรวจสอบhttps://jsfiddle.net/sjy3vjwm/2/


ฉันเพิ่งลองใช้รหัสแรกของคุณด้วยวานิลลาจาวาสคริปต์และให้ผลลัพธ์นี้: 2018-4-20 15:11:23 คุณไม่ได้เติมตัวเลขด้วย "0" นำหน้า นอกจากนี้ฉันไม่รู้เกี่ยวกับ momentjs แต่คุณไม่ต้องใส่ "HH" เป็นเวลาหนึ่งชั่วโมงเพื่อให้มันรองหรือไม่? นั่นอาจเป็นเหตุผลว่าทำไมคุณถึงโหวตลง? (itwasntme)
Alex

0

วิธีที่ง่ายที่สุดในการแปลง JS Date เป็นรูปแบบวันที่และเวลาของ SQL ที่เกิดขึ้นกับฉันคือวิธีนี้ จัดการกับการชดเชยเขตเวลาได้อย่างถูกต้อง

const toSqlDatetime = (inputDate) => {
    const date = new Date(inputDate)
    const dateWithOffest = new Date(date.getTime() - (date.getTimezoneOffset() * 60000))
    return dateWithOffest
        .toISOString()
        .slice(0, 19)
        .replace('T', ' ')
}

toSqlDatetime(new Date()) // 2019-08-07 11:58:57
toSqlDatetime(new Date('2016-6-23 1:54:16')) // 2016-06-23 01:54:16

ระวังว่าคำตอบของ @Paulo Robertoจะให้ผลลัพธ์ที่ไม่ถูกต้องเมื่อถึงวันใหม่ (ฉันไม่สามารถแสดงความคิดเห็นได้) ตัวอย่างเช่น :

var d = new Date('2016-6-23 1:54:16'),
    finalDate = d.toISOString().split('T')[0]+' '+d.toTimeString().split(' ')[0];
console.log(finalDate); // 2016-06-22 01:54:16 

เรามี 22 มิถุนายนแทนที่จะเป็น 23!


0
var _t = new Date();

หากคุณต้องการรูปแบบ UTC ง่ายๆ

_t.toLocaleString('indian', { timeZone: 'UTC' }).replace(/(\w+)\/(\w+)\/(\w+), (\w+)/, '$3-$2-$1 $4');

หรือ

_t.toISOString().slice(0, 19).replace('T', ' ');

และหากต้องการในเขตเวลาที่กำหนด

_t.toLocaleString('indian', { timeZone: 'asia/kolkata' }).replace(/(\w+)\/(\w+)\/(\w+), (\w+)/, '$3-$2-$1 $4');

0

ฉันใช้มานานแล้วและเป็นประโยชน์มากสำหรับฉันใช้ตามที่คุณต้องการ

Date.prototype.date=function() {
    return this.getFullYear()+'-'+String(this.getMonth()+1).padStart(2, '0')+'-'+String(this.getDate()).padStart(2, '0')
}

Date.prototype.time=function() {
    return String(this.getHours()).padStart(2, '0')+':'+String(this.getMinutes()).padStart(2, '0')+':'+String(this.getSeconds()).padStart(2, '0')
}

Date.prototype.dateTime=function() {
    return this.getFullYear()+'-'+String(this.getMonth()+1).padStart(2, '0')+'-'+String(this.getDate()).padStart(2, '0')+' '+String(this.getHours()).padStart(2, '0')+':'+String(this.getMinutes()).padStart(2, '0')+':'+String(this.getSeconds()).padStart(2, '0')
}

Date.prototype.addTime=function(time) {
    var time=time.split(":")
    var rd=new Date(this.setHours(this.getHours()+parseInt(time[0])))
    rd=new Date(rd.setMinutes(rd.getMinutes()+parseInt(time[1])))
    return new Date(rd.setSeconds(rd.getSeconds()+parseInt(time[2])))
}

Date.prototype.addDate=function(time) {
    var time=time.split("-")
    var rd=new Date(this.setFullYear(this.getFullYear()+parseInt(time[0])))
    rd=new Date(rd.setMonth(rd.getMonth()+parseInt(time[1])))
    return new Date(rd.setDate(rd.getDate()+parseInt(time[2])))
}

Date.prototype.subDate=function(time) {
    var time=time.split("-")
    var rd=new Date(this.setFullYear(this.getFullYear()-parseInt(time[0])))
    rd=new Date(rd.setMonth(rd.getMonth()-parseInt(time[1])))
    return new Date(rd.setDate(rd.getDate()-parseInt(time[2])))
}

จากนั้นเพียง:

new Date().date()

ซึ่งส่งคืนวันที่ปัจจุบันในรูปแบบ 'MySQL'

สำหรับเวลาเพิ่มคือ

new Date().addTime('0:30:0')

ซึ่งจะเพิ่ม 30 นาที .... และอื่น ๆ

โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.