跳到主要内容

datetime

简介

校验参数值是否为日期时间格式

示例

数据字典

hrm.sys_tasks 人力资源系统 - 系统任务表

列名数据类型非空自增描述
idint(11)主键-
titlevarchar(255)--任务标题
completedtinyint(1)---任务是否完成
start_timedatetime---任务开始时间
end_timedatetime---任务结束时间
  • 创建 hrm.sys_tasks 任务表

    DROP TABLE IF EXISTS hrm.sys_tasks;
    CREATE TABLE hrm.sys_tasks
    (
    id INT PRIMARY KEY AUTO_INCREMENT,
    title VARCHAR(255) NOT NULL,
    completed BOOLEAN COMMENT '0未完成 1完成 data_type=bool',
    start_time DATETIME,
    end_time DATETIME
    );

表中,start_time和end_time 字段是日期时间类型,需要遵守日期时间类型规范。

请求

POST http://127.0.0.1:21000
Content-Type: application/json;charset=utf-8
{
"jsonrpc": "2.0",
"method": "hrm.sysTasks.add",
"params": {
"title": "testing datatime type",
"completed": 1,
"startTime": "2023-11-41 08:00",
"endTime": "2023-11-41 08:00"
},
"id": "client-unique-request-id"
}

响应

从响应结果可见,luwak报错提示上述startTime和endTime字段的值不符合日期类型格式规范,拒绝操作。

HTTP/1.1 400 Bad Request
Content-Type: application/json; charset=utf-8
{
"jsonrpc": "2.0",
"error": {
"code": -32602,
"message": "validating data type: endTime: 2023-11-41 08:00 does not validate as datetime;startTime: 2023-11-41 08:00 does not validate as datetime",
"data": {
"errorCode": "EU.Validator.DataTypeError",
"errorDetails": [
{
"field": "startTime",
"fieldValue": "2023-11-41 08:00",
"location": "hrm.sys_tasks",
"message": "startTime: 2023-11-41 08:00 does not validate as datetime",
"validator": "datetime"
},
{
"field": "endTime",
"fieldValue": "2023-11-41 08:00",
"location": "hrm.sys_tasks",
"message": "endTime: 2023-11-41 08:00 does not validate as datetime",
"validator": "datetime"
}
],
"errorMessage": "endTime: 2023-11-41 08:00 does not validate as datetime;startTime: 2023-11-41 08:00 does not validate as datetime"
}
},
"id": "client-unique-request-id"
}

备注: 以上示例在Luwak 1.12.9测试通过。