草庐IT

entry_time

全部标签

php - Symfony 2 + Doctrine : How to supress SQLSTATE[23000]: Integrity constraint violation: 1062 Duplicate entry

我查看了几篇文章,但找不到可行的解决方案。我的问题很简单:我有一个包含id、url和title的实体。URL应该是唯一的(在MySQLPDO中)。我成功地创建了实体和模式,没有任何问题。现在,当我遍历一些记录时,我会在每个记录上调用persist(),最后调用flush()。问题是,当我尝试为URL插入重复条目时,它给了我一个异常(exception)。如何抑制?当插入重复条目时,它应该跳过它并插入其余条目。不需要事件、ONUPDATE语句、触发器和所有花​​哨的东西。我已经trycatchpersist或flush()抛出的任何异常,但似乎无法正确地做到这一点。欢迎任何想法,谢谢!编

MySQL 查询 : Long time spent in 'init' state

我正在对MySQL表(myisam引擎)执行更新,根据分析器,该表在“初始”状态下花费了过多的时间:mysql>showprofileforquery2;+----------------------+-----------+|Status|Duration|+----------------------+-----------+|starting|0.000057||checkingpermissions|0.000006||Openingtables|0.000020||Systemlock|0.000007||Tablelock|0.000005||init|21.911657|

php - SQL 语句基于 $curr_time->format ('Y-m-d H:i' )

为什么这段代码...$curr_time=newDateTime();$query_inprocess="UPDATE`MyTable`SETinprocess=1WHEREstartTimeformat('Y-m-dH:i')."'";...导致错误的SQL查询,其中之后的语句被忽略了?UPDATE`MyTable`SETinprocess=1WHEREstartTime 最佳答案 找到下面的:"UPDATE`MyTable`SETinprocess=1WHEREstartTime它可以帮助您获得所需的准确结果。

mysql - Spring Data JPA 和 MySQL : How to avoid "duplicate entry" error in multithreaded environment?

我的Web应用程序的数据库基础架构是这样分层的:Spring数据JPAJPAhibernateC3P0池MySQL有些事务需要相当长的时间,有时一个大事务需要一分钟(目的是将数据缓存到数据库中):从用户到我的网络服务器的HTTP请求可能会开始此事务。然后,我的Web服务器可能会查询另一个远程第三方服务器以查找丢失的数据。收集完所有数据后,事务完成,所有收集到的数据都写入数据库。在这个长时间运行的事务中,用户可能会重新加载我的网站。这会导致在单独的线程中针对相同数据开始另一个事务。由于此事务的目的是缓存,因此此操作本质上是幂等的,我不介意进行相同的计算上两次。但在这些情况下,我的Web应

mysql - (1062, "Duplicate entry ' 0' for key ' 主'")

我收到此错误(1062,“键‘PRIMARY’的重复条目‘0’”)。这发生在我将我的Django应用程序从sqlite3迁移到MySQL之后。这是相关的表格:mysql>describemeddy1_specialization;+-------+-------------+------+-----+---------+----------------+|Field|Type|Null|Key|Default|Extra|+-------+-------------+------+-----+---------+----------------+|id|int(11)|NO|PRI|N

php - PostgreSQL 错误 : date/time field value out of range

您好,我想在我的表格中插入一个日期。但我收到了错误。我也尝试了我发现的两种解决方案:setdatestyletoSQL,DMY;setdatestyle=dmy;但是问题依然存在。请帮助我在哪里做错了。这是错误:ErrorNumber:ERROR:date/timefieldvalueoutofrange:"24-07-2016"LINE1:...isalabad',E'ChiefExecutive',E'1994-10-13',E'24-07-20...^HINT:Perhapsyouneedadifferent"datestyle"setting.INSERTINTO"employ

mysql - JOIN 3 tables and (LIMIT 2 rows ORDER BY time DESC)

我知道这个问题已经被问过很多次了,但我在执行它时遇到了困难。我做了一个简化的例子,所以它很容易重现。我想连接3个表,但在最后一个表上我想限制为2行DESCCREATETABLE`cars`(`car_id`int(11)NOTNULLAUTO_INCREMENT,`plate`varchar(10)NOTNULL,`km`int(11)NOTNULL,`status`tinyint(1)NOTNULL,PRIMARYKEY(`car_id`))ENGINE=MyISAMDEFAULTCHARSET=latin1AUTO_INCREMENT=6;INSERTINTO`cars`(`car

mysql - GREATEST() 和 LEAST() 函数不能在 MySQL 5.7 的存储过程中使用 TIME 变量

我有一个MySQL存储过程来计算员工的工作时间、加类时间等。在某些特殊情况下,我需要计算两个时间段(员工的工作时间和公司的工作时间)之间的重叠,我使用GREATEST()和LEAST()函数作用于TIME类型的变量。存储过程在MySQL5.5中产生了正确的结果,但是当我升级到MySQL5.7时行为发生了变化。实际上,如果我将变量类型更改为VARCHAR(),它可以在MySQL5.7中工作,但它所处理的数据来自TIME类型的表字段。下面是演示该问题的过程的简化形式。DROPprocedureIFEXISTS`timetest`;DELIMITER$$CREATEDEFINER=`root

mysql - MySQL 是否与 Oracle 的 TIMESTAMP WITH TIME ZONE 等效?

MySQL有没有等同于Oracle的TIMESTAMPWITHTIMEZONE的?我需要将一个Oracle表(其中包含一些具有该数据类型的列)映射到一个MySQL表中,但我似乎无法找到一种不求助于某些MySQL函数的简单方法来执行此操作。谢谢并致以最诚挚的问候。 最佳答案 不,您需要将数据分成两列,一列是日期时间,另一列包含时区信息。但是你在后一个字段中输入的内容取决于你在Oracle中存储的内容-TIMESTAMPWITHTIMEZONE数据类型可以包含TZ偏移量和(可选)时区区域。显然后者是日期时间在语义上正确的要求,但IIRC

php - Linux 上 PHP 的真实 max_execution_time

Accordingtothedocumentation:max_execution_timeonlyaffecttheexecutiontimeofthescriptitself.Anytimespentonactivitythathappensoutsidetheexecutionofthescriptsuchassystemcallsusingsystem(),streamoperations,databasequeries,etc.isnotincludedwhendeterminingthemaximumtimethatthescripthasbeenrunning.Thisi