草庐IT

update_order_review

全部标签

mysql - 根据行在 MySQL 中是否存在执行 UPDATE 或 INSERT

在MySQL中,我试图找到一种有效的方法来在表中已存在行时执行更新,或者在行不存在时执行插入。到目前为止,我发现了两种可能的方法:最明显的一个:打开一个事务,SELECT查找该行是否存在,如果不存在则INSERT,如果存在则UPDATE,提交事务首先将INSERTIGNORE插入表中(因此如果该行已存在则不会引发错误),然后是UPDATE第二种方法避免了交易。您认为哪个更有效,有没有更好的方法(例如使用触发器)? 最佳答案 INSERT...ONDUPLICATEKEYUPDATE 关于

php - 如何在 Laravel 4 中使用 UPDATE 或 INSERT?

我正在Laravel4中构建一个应用程序,我需要运行多个查询作为UPDATE或INSERT查询,以避免在重复插入时违反PK。我一直无法找到任何方法来使用Laravel中的查询构建器来执行此操作。我可以修改数据库类或类似的东西吗?还是我只需要编写纯SQL语句? 最佳答案 现在我们可以使用User::updateOrCreate() 关于php-如何在Laravel4中使用UPDATE或INSERT?,我们在StackOverflow上找到一个类似的问题: htt

SQL:ORDER BY 两列混合,不基于优先级

我正在使用mySQL。我必须按姓氏对联系人姓名进行排序,但在没有姓氏的情况下,我按名字排序。这看起来像:ORDERBYlastname="",lastname,firstname但是,这会使姓氏出现在顶部。我想要的行为是混合名字和姓氏,就像它们来自同一领域一样。示例(假装这些是名字):A,TZ,GABC对比:AA,TBCZ,G谢谢 最佳答案 使用COALESCE和NULLIF:ORDERBYCOALESCE(NULLIF(LastName,''),FirstName),FirstName

mysql - GROUP BY 查询忽略 ORDER BY 子句

SELECTdeal_woot.*,site.woot_off,site.nameASsite_nameFROMdeal_wootINNERJOINsiteONsite.id=site_idWHEREsite_idIN(2,3,4,5,6)GROUPBYsite_idORDERBYdeal_woot.idDESCLIMIT5我想在分组前使用ORDERBY,我该如何实现? 最佳答案 使用如下子查询:SELECT*,COUNT(*)FROM(SELECT*fromactionsorderbydateDESC)ASactionsGROUP

python - mycursor.executemany UPDATE 未按预期工作

问题:我有一个用于抓取和网站的python脚本,它获取2个变量并将它们存储在2个列表中。然后我使用executemany来更新MySQL数据库,使用一个变量来匹配预先存在的行以将另一个变量插入。代码:Python脚本importmysql.connectorfrombs4importBeautifulSoupassoupfromseleniumimportwebdriverimporttime,remydb=mysql.connector.connect(host="host",user="user",passwd="passwd",database="database")mycurs

mysql - mysql order by 内部是如何实现的?

Mysql内部是如何实现orderby的?按多列排序是否涉及对按约束排序中指定的每一列多次扫描数据集一次? 最佳答案 这是描述:http://dev.mysql.com/doc/refman/5.0/en/order-by-optimization.html除非您有行外列(BLOB或TEXT)或您的SELECT列表太大,使用这个算法:ReadtherowsthatmatchtheWHEREclause.Foreachrow,recordatupleofvaluesconsistingofthesortkeyvalueandrowpo

mysql - 连接表性能的 ORDER BY 列

我有2个1:1关系的表(但将来可能会变成1:N关系)如下:CREATETABLEarticle(article_idINT,insertedDATETIME)ENGINEInnoDB;CREATETABLEarticle_top(article_top_idINT,article_idINT,untilDATETIME)ENGINEInnoDB;我需要做的是选择首先按article_top.untilDESC排序然后按article.insertedDESC排序的文章(因此“顶部”文章位于顶部其余的从新到旧排序。我执行以下查询,速度很慢(当我跳过ORDERBY子句中的article_t

mysql - 如何优化这个简单的 JOIN+ORDER BY 查询?

我有两个mysql表:/*Tableusers*/CREATETABLEIFNOTEXISTS`users`(`Id`int(10)unsignedNOTNULLAUTO_INCREMENT,`DateRegistered`datetimeNOTNULL,PRIMARYKEY(`Id`))ENGINE=InnoDBDEFAULTCHARSET=utf8;/*Tablestatistics_user*/CREATETABLEIFNOTEXISTS`statistics_user`(`UserId`int(10)unsignedNOTNULLAUTO_INCREMENT,`Sent_Vie

如果我使用 'after update' 但不使用 'after insert',MYSQL 触发器是否有效?

我编写了一个触发器,在对表a执行操作后向表b中插入一行。出于某种原因,如果我在“插入后”添加此触发器然后插入一行,它没有任何效果。但是,如果我将触发器添加为“更新后”并更新行,它确实有效。这是触发代码。当我将“AFTERUPDATE”替换为“AFTERINSERT”并进行插入时,插入新行时没有任何反应。创建触发器时我没有收到任何错误,并且我没有尝试更新设置触发器的同一个表。任何帮助表示赞赏!谢谢,仁droptriggerifexistsinsertUndecided;DELIMITER//CREATETRIGGERinsertUndecidedAFTERUPDATEONjiraissu

MySQL/InnoDB偶尔有些更新运行很慢,处于 'Updating'状态

我们的数据库更新性能偶尔会大幅下降。例如,表FooTable我们有大约40列与varcharPK此外还有10个索引。以下查询用时44秒,而在其他时候它几乎立即运行。在减速期间,服务器上的平均负载非常低(5分钟平均负载为1.5),并且根据vmstat的IO也相当合理。这里有一个例子:mysql>updateFooTablesetBarColumn=1349981286086wherevarcharPK='e4348411-0fbb-460a-80f7-f1de304a9f7c'QueryOK,1rowaffected(44.94sec)Rowsmatched:1Changed:1Warn