草庐IT

update_query

全部标签

sql - 我可以始终使用 INSERT ....ON DUPLICATE UPDATE 进行简单的更新/插入吗?

(MYSQL)是否存在任何显着的性能差异,或其他不使用INSERT...ONDUPLICATEUPDATEsql更新PK/插入新内容的原因? 最佳答案 没有,没有。INSERTONDUPLICATEKEYUPDATE将定位记录并更新它就像一个简单的UPDATE会做。事实上这只是一个UPDATE,其次是INSERT应该UPDATE失败。INSERTONDUPLICATEKEYUPDATE可以是分组更新的更快替代方案(当您有一个每个键有多个记录的源表并且希望每个记录递增一次目标表时)。如果每个键的值很少,则此查询:INSERTINTOt

php - Mysql Join Query 多次给出相同的结果

我有两张table。一种是items,一种是tags。查询的here.想法是创建一个搜索框来搜索项目,然后通过选择标签来缩小搜索范围。(某种分面搜索)。在摆弄mysql教程之后,我想到了这个:SELECT`items`.`id`,`items`.`name`,`items`.`pay`,`items`.`desc`FROM`items`LEFTJOIN(`tags`)ON(`tags`.`item_id`=`items`.`id`)WHERE((`tags`.`type`='food'AND`tags`.`name`='pizza')OR(`tags`.`type`='drinks'A

php - 尝试构建一个动态的 PHP mysql_query 字符串来更新一行并取回更新的行

我有一个jQuery跟踪onChage.change()事件的表单,因此当某些内容发生更改时,它会运行一个ajax请求,我传入列、id和url中的值。这里我有应该更新数据的PHP代码。我现在的问题是如何动态构建mySQl字符串。以及我如何回显数据库上刚刚更改的更改/更新。这是我尝试使用的PHP代码。这个例子可以吗?$sqlUpdate='UPDATE`plProducts`.`allPens`SET"{$collumn}"="{$val}"WHERE`allPens`.`prodId`="{$id}"LIMIT1;'; 最佳答案 使

php - MySQL优化: Perform Maths operation inside or outside of a query?

我有一种强烈的感觉,所有对查询本身不必要的数学运算都应该在查询之外执行。例如:$result=mysql_query(SELECTa,a*b/casscoreFROMtable)while($row=mysql_fetch_assoc($result)){echo$row['a'].'score:'.$row['score'].;}对比:$result=mysql_query(SELECTa,b,cFROMtable)while($row=mysql_fetch_assoc($result)){echo$row['a'].'score:'.$row['a']*$row['b']/$ro

MySQL:INSERT IGNORE 或 ON DUPLICATE KEY UPDATE 检查多个列而不是唯一列

如果存在包含特定值的行,我想插入行,如果不存在,则更新它。具体来说:user_id=5,user_zip=12345,distance=600列存在于数据库中。如果我尝试插入user_id=5,user_zip=12345,distance=700它应该只更新distance但我尝试插入user_id=5,user_zip=67890,distance=800它应该插入一个新行。我无法定义列user_zip和distance唯一,因此我可以使用重复键更新。 最佳答案 我认为您误解了ONDUPLICATEKEYUPDATE的工作原理。

php - mysql_query 成功返回 false

我在使用Windows7、WAMP2.2、MySQL5.5.16、Apache2.2.21和PHP5.3.8的开发环境中查询表单时遇到问题。每次我执行查询时,它都会返回一个错误:".YouhaveanerrorinyourSQLsyntax;checkthemanualthatcorrespondstoyourMySQLserverversionfortherightsyntaxtousenear'INERTIGNOREINTOusers(username,hashed_password,email)VALUES('username',''atline1"我决定将我的问题放在顶部,以便

mysql - INSERT SELECT ON DUPLICATE UPDATE 的 SQL 语法

我想对一个表中的行进行分组和聚合,然后插入到另一个表中,然后更新聚合值。它的SQL命令是什么?INSERTINTOtbdetail(detail,views)(SELECTdetail,SUM(views)ASviewsallFROMtbGROUPBYdetail)//ONDUPLICATEKEYUPDATEviews=views+viewsall 最佳答案 在MySQL中,当使用INSERT...SELECT语句时,您可以使用VALUES()引用SELECT语句的值之一功能:INSERTINTOtbdetail(detail,vi

php - PDO 事务是否涵盖 PDO::query()?

位于PHP.net的PDO交易示例表明PDO::exec()是事务处理的,但是没有这样的例子使用PDO::query()。事务是否涵盖PDO::query()?此外,据我所知,PDO::query()返回一个结果集。如果是事务处理的,怎么会有结果集,因为语句在提交之前不应该执行?(这是否意味着PDO::query()确实是not交易?)我似乎找不到官方引用资料来说明它是否是. 最佳答案 您误解了交易。事务只是保证操作是原子的:要么所有操作都成功,要么都不成功。一旦你开始一个事务,每个查询都会被执行,并且它会被记录在事务日志中。如果操

php - INSERT 语句之谜——mysql_query 返回 true,但数据库中没有新行出现

我一定是在做傻事。我已经对此问题进行了3天的故障排除,但没有成功。这是发送到mysql_query()的PHP字符串:insertintopost_replies(postID,fromID,toID,status)values($id,$userID,$toID,".g_unread.")在你说“啊哈,SQL一定有错误”之前,请注意以下两点:mysql_query()返回真(1)在发送到mysql_query()之前,我将字符串导出到一个文本文件(见下文)-如果我将导出的文本粘贴到同一个mysql_query()语句中,它工作正常(出现新行)-如果粘贴导出的文本进入phpMyAdmi

php - mysqli multi_query 后跟查询

这个问题在这里已经有了答案:"Commandsoutofsync;youcan'trunthiscommandnow"-Causedbymysqli::multi_query(3个答案)关闭5个月前。我目前正在做以下事情:$mysqli=newmysqli($server,$username,$password,$database);$mysqli->multi_query($multiUpdates);while($mysqli->next_result()){;}//Flushingresultsofmulti_queries$mysqli->query($sqlInserts);