- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图在 PHP 中创建 SQL 语句,将字符串转换为时间 (6)。但在过去的 12 个小时里,我已经尝试了一切,但没有取得任何进展。我已经尝试过这些语句,都产生相同的错误。
UPDATE scheduling SET start='03:42PM' WHERE activityid=2;
UPDATE scheduling SET start=CONVERT(TIME(6),'03:42PM');
INSERT INTO scheduling(start) VALUES (start=CONVERT(TIME(6),'03:42PM'));
INSERT INTO scheduling(start) VALUES (start=CONVERT(TIME(6),'03:42PM'));
INSERT INTO scheduling(start) VALUES (start=CONVERT(TIME(6),'15:42'));
错误是
Syntax Error: unexpected '03:42PM'(single quoted text)"
我不知道如何解决这个问题,该表存在,并且我已经使用诸如 SELECT activityid=2 FROM xxxxxx.scheudling
我想我有两个问题,任何一个答案都可以。
在我的 PHP 文档中,我如何将从 Android Studio 截击中获取的字符串转换为日期。 (我使用 $start=$_Post("start")
正确地获取了变量,这样就可以了,但是我不能将它转换成时间。我在网上看了看,并尝试了所有看起来像的东西工作工作。
通过SQL代码转换,我已经尝试了CAST
和CONVERT
,都没有用。我的起始列是类型 TIME(6)
。
最佳答案
我建议使用 SELECT 语句测试表达式。
首先,MySQL CONVERT
函数参数向后翻转。
语法是CONVERT(expr,type)
type
是作为关键字提供的,而不是字符串文字。例如:
SELECT CONVERT('235',SIGNED)
转换为TIME
数据类型
SELECT CONVERT( '15:42' ,TIME(6)) // => 15:42:00.000000
字符串文字的“PM”部分将被忽略。
SELECT CONVERT( '03:42PM' ,TIME(6)) // => 03:42:00.000000
我们可以使用 STR_TO_DATE
函数从包含 AM/PM 指标的字符串中返回一个 TIME 值
SELECT STR_TO_DATE( '03:42PM' ,'%h:%i%p')
而且不需要将其转换为 TIME(6)
,我们可以这样做:
UPDATE scheduling
SET start = STR_TO_DATE( '03:42PM' ,'%h:%i%p')
WHERE activityid = 2
STR_TO_DATE
函数记录在此处:
https://dev.mysql.com/doc/refman/5.7/en/date-and-time-functions.html#function_str-to-date
STR_TO_DATE
的格式模式记录在此处,在 DATE_FORMAT
下:
https://dev.mysql.com/doc/refman/5.7/en/date-and-time-functions.html#function_date-format
跟进
演示:
设置
USE test;
CREATE TABLE scheduling (activityid INT PRIMARY KEY, start TIME(6));
-- 0 row(s) affected
INSERT INTO scheduling (activityid) VALUES (2);
-- 1 row(s) affected
执行上面答案中的update语句
UPDATE scheduling SET start = STR_TO_DATE( '03:42PM' ,'%h:%i%p') WHERE activityid = 2 ;
-- 1 row(s) affected
结果
SELECT * FROM scheduling WHERE activityid = 2;
-- activityid start
-- ---------- ---------------
-- 2 15:42:00.000000
第二次跟进
使用 OP 报告的相同 sql_mode
设置:
SET @@sql_mode = 'ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION' ;
测试:
SELECT STR_TO_DATE( '03:42PM' ,'%h:%i%p')
返回
(NULL)
但是这个更复杂的表达式:
SELECT TIME(STR_TO_DATE(CONCAT(CURRENT_DATE(),' ', '03:42PM' ),'%Y-%m-%d %h:%i%p'))
返回
15:42:00
更复杂的表达式是一种解决方法,可以避免 sql_mode
中的 STRICT_TRANS_TABLES
和 NO_ZERO_DATE
强加的行为。
关于php - mySQL Workbench 错误 : Syntax Error, 意外的单引号,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50650110/
我不知道为什么我得到这些结果。 ++ +add +syntax error 2 ++ +add +syntax error 4 ++是我的输入,并且lex会回显每个字符,并且每当获得+时yacc打印就
这个问题在这里已经有了答案: Syntax error on print with Python 3 [duplicate] (3 个回答) 关闭8年前。 为什么 Python 在第 9 行的简单 p
我有一个非常简单的 SQL 语句 SELECT * FROM Table; 但是,我的查询引擎返回一个语法错误。为什么? 错误详情: An unhandled exception of type 'S
我正在尝试编写一些代码来模拟具有两个三态缓冲器和VHDL中的上拉电阻的电路。下面是我的代码: library ieee; use ieee.std_logic_1164.all; entity Pul
我已经编写了这个mergesort实现,如果将除法功能放在mergesort函数之外,效果很好。但是,当我尝试使除法成为mergesort的内部函数时,遇到语法错误。 我知道,对此必须有一些非常简单的
(我是 Linux 和 Vim 新手,我正在尝试学习 Vim,但我遇到了一些无法解决的问题) 我安装的 Linux (Ubuntu 8.04) 无法使用 Vim 7.1.138 进行更新。 我的 vi
这个错误让我抓狂,我需要帮助。 Syntax Error: Token '{' invalid key at column 2 of the expression [{{ field }}.$erro
原标题是“特定于语言的配色方案防止较简单的配色方案为某些特定于语言的标签着色” 我正在使用 gVim 7.3(在 Ubuntu 12.04 Arch x86/64 上,这很重要)。 更新(2013-0
Closed. This question does not meet Stack Overflow guidelines。它当前不接受答案。 想改善这个问题吗?更新问题,以便将其作为on-topic
我正在编写某种“编译器”:它读取游戏的描述(包括房间,角色,事物等)。将其视为冒险类游戏的视觉版本,但存在很多简单问题。 当我运行“编译器”时,输入中出现语法错误,我不知道为什么。这是我的yacc输入
我正在构建一个示例应用程序(请参阅plunk https://plnkr.co/edit/vDXcSPrOjw5qvBQKcYvw?p=preview)。 var myA
语法错误文件: 我想知道在哪里可以看到确切的错误信息。vivado中没有任何提示。 谢谢! 最佳答案 通常,您可以检查屏幕底部的消息选项卡。无论如何,Vivado并不是特别擅长告诉您代码有什么问题(我
您好,这是我的迷你编程语言的野牛语法文件: %{ #include #include #include #include "projectbison.tab.h" void y
Fmax我的代码中的参数报告为:No Paths to report .因此,我试图使用 set_input_delay 设置与定义时钟的输入信号关系。 .但是,错误报告指出: Verilog HDL
我正在开发一个使用 Twig 的 Symfony2 项目,文件类型为 myfile.html.twig。 Vim 不会自动检测语法突出显示,因此不应用任何语法。打开文件后,我可以使用 :set syn
这是一个相对简单的代码,用于“在半径为2个单位的圆象限上使用中坐标规则评估pi”。 main.alg BEGIN REAL x, y, sumy, pi; INT n := lowerlimit, p
我对我的简单插入所产生的错误感到非常困惑。我已经通过不同的检查器多次检查了语法并搜索了类似的问题,但没有找到解决方案。 错误看起来像这样: 'SQLSTATE[42000]: Syntax error
我尝试了以下代码: with x as 1: y = 1 with z as 1: w = 1 编译器报告了 SyntaxError:语法无效。有什么问题? [已编辑:]我想做的是:
我在 Webstorm 中使用 vue 框架,使用 ES6 语法。 我已经安装了 vue-for-idea 插件,如果我使用纯 ES5 语法,一切都会很顺利。 但是代码的ES6部分似乎还没有被识别,并
我将我认为有用的代码示例作为文本文件保存在我的计算机上。我将它们存储为 txt 文件而不是编写它们的语言,以便它们将在 Notepad++ 中打开而不是在编辑器中打开(即我不希望我的 c++ 示例在
我是一名优秀的程序员,十分优秀!