mysql - 创建预订系统,但我很难将输入日期插入 MySQL 表

标签 mysql reactjs function date datetime

我是编程新手,尝试使用 reactjs、node 和 mysql 创建汽车租赁系统,但我很难将日期插入数据库。我知道我必须以某种方式将它变成一个字符串并使其成为本地时区,但无法弄清楚。

日期.js:

dateOut = "";
dateIn = "";
location = "";
render()
  return(
}
<input type="date" value={this.dateOut} onChange={e => (this.dateOut = e.target.value)} />
<input type="date" value={this.dateIn} onChange={e => (this.dateIn = e.target.value)} />
<input type="text" value={this.location} onChange={e => (this.location = e.target.value)}>
);

add() {
    orderService.addOrder(
      this.dateOut,
      this.dateIn,
      this.location
      id => {
        history.push('/cars/' + id);
      }
    );
  }
} ```

services.js:

  ```addOrder(dateOut, dateIn, location, success) {
    connection.query(
      'insert into Orders (dateOut, dateIn, location, success) values (?, ?, ?)',
      [dateOut, dateIn, location],
      (error, results) => {
        if (error) return console.error(error);

        success(results.insertId);
      }
    );
  } ```

最佳答案

这里是处理这个问题的方法。

  1. 在表中将 dateOutdateIn 列声明为 TIMESTAMP 数据类型。
  2. 当您为 insert 查询提供日期/时间值时,请使用格式如 2019-04-08 16:52 的文本字符串。或者使用 Javascript 日期对象。
  3. 在注册您的用户时,询问他们的时区偏好,特别是要求他们从 mysql.time_zone_name.name 中的值中选择一个。
  4. 将该偏好作为字符串(如 Asia/KolkataAmerica/Halifax)存储在您的用户偏好表中。 VARCHAR(63) 是该列数据类型的不错选择。
  5. 每次您代表用户在您的应用中使用 MySQL 连接时,首先发出命令 SET time_zone = whateverTheyChose 以设置用户的时区首选项。

为什么这么好? TIMESTAMP 数据类型值始终以 UTC 格式存储,并且在检索或存储它们时始终转换为/自当前设置的时区。

如果你想将当前的日期/时间值插入到列中,你可以这样做:

insert into Orders 
       (dateOut, dateIn, location, success) 
values (NOW(),    NOW(),        ?,       ?)

请注意 values() 子句中的值和占位符如何与列列表中的项目一一对应。

您可以阅读有关 MySQL's time zone handling system on the 'toobz 的信息.它基于 IANA's zoneinfo database .该数据库的维护者会处理所有奇怪的时间政治因素,例如土库曼斯坦或美国印第安纳州的夏令时何时开始和结束,因此我们其他人不必这样做。

如果您使用 DATEDATETIME 数据类型而不是 TIMESTAMP,您将无法获得自动时区信息。这些数据类型或多或少类似于时钟的照片。

无论您使用哪种数据类型,都可以使用名为TIMESTAMPDIFF() 的MySQL 函数计算持续时间。例如,

TIMESTAMPDIFF(HOUR, dateOut, dateIn) 

告诉您两个日期/时间值之间的小时数。即使您的两个值跨越夏令时切换天数,它也会正常工作。

花很多时间了解您的数据库管理系统如何处理日期和时间是值得的。他们做得很好,所以你不必重新发明漏气的轮胎。

而且,在您的应用程序生命周期的早期就正确设置所有这些是值得的。更改正在运行的系统以处理这些时区非常非常。 (别问我怎么知道难!)

关于mysql - 创建预订系统,但我很难将输入日期插入 MySQL 表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55581493/

相关文章:

php - $_GET 创建产品页面

reactjs - Facebook React.js::传递数据以进行客户端渲染

reactjs - 将 Ant 设计表导出为 pdf 格式

function - Python 3 的 new.function 替换

MySQL 添加日期字段并在 where 子句中与今天进行比较

MySQL 命令不适用于 Windows CMD

reactjs - i18next 警告或检查缺少语言的键(不是 fallbackLng)

c++ - 为什么类成员函数不能接受多个与其类相同类型的参数

c++ - 如何将数据输入数组并通过函数打印出来?

php - Drupal 8 更新/同步数据库从开发到生产