草庐IT

last_ap_update

全部标签

通过主键进行的 MySQL UPDATE 查询有时非常慢

我们网站上的特定UPDATE查询有时会运行得非常慢,并且会检查比必要的多得多的行。它按主键过滤,所以我希望MySQL总是只需要检查一行。以下是MySQL的慢查询日志中的一些示例:#Time:09070212:59:06#User@Host:XXX[XXX]@XXX[XXX]#Query_time:21Lock_time:0Rows_sent:0Rows_examined:500500SETtimestamp=1246532346;UPDATE`folders`SET`folder_id`='1705641',`updated_at`=now()WHERE`folders`.`id`='

SQL 帮助 : select the last 3 comments for EACH student?

我有两个表来存储小学教室的学生数据:Behavior_Log包含student_id、comments、date列Student_Roster有student_id、firstname、lastname列数据库用于存储对学生行为的每日评论,有时老师会在给定的一天对一个学生发表多条评论。现在假设老师希望能够为每个学生提取最后3条评论的列表,如下所示:Jessica7/1/09talkingJessica7/1/09passingnotesJessica5/3/09absentCiboney7/2/09greatparticipationCiboney4/30/09absentCibone

MySQL UPDATE 语句批处理以避免大量 TRX 大小

我经常编写更新数百万行数据的数据清理。数据驻留在使用InnoDB的24x7x365OLTPMySQL数据库中。更新可能会清理表的每一行(其中DB最终获得表级锁)或者可能只是清理表中10%的行(可能仍为数百万)。为了避免创建大量事务并最大程度地减少争用,我通常最终会尝试将我的一个大型UPDATE语句分解为一系列较小的UPDATE事务。所以我最终写了一个循环结构来限制我的UPDATE的WHERE子句,如下所示:(警告:这只是为了说明问题的伪代码)@batch_size=10000;@max_primary_key_value=selectmax(pk)fromtable1for(inti=

MySQL 性能 : nested insert/duplicate key vs multiple updates

有谁知道什么会更有效并使用更少的资源:方法1--使用单个SELECT语句从一个表中获取数据,然后遍历它以对另一个表执行多个UPDATE。例如。(伪代码,execute()运行查询):Query1_resultset=execute("SELECTitem_id,sum(views)asview_countFROMtableAWHEREcondition=1");while(Query1_resultsetasrow){execute("UPDATEtableBSETview_count=row.view_countWHEREid=row.item_id");}方法2--使用单个INSE

mysql - MySQL 可以在 UPDATE 中进行正则表达式替换吗?

我见过使用REGEXP运算符进行匹配的MySQLSELECT示例。有没有办法在UPDATE中进行正则表达式替换?如果不是,对列中的所有值运行正则表达式替换的最简单方法是什么?请随意建议使用任何编程语言或正则表达式实现。 最佳答案 基本上,没有。您可以使用一些繁琐的REPLACE()调用,在支持正则表达式替换的脚本中创建UPDATE语句,或者使用一些UDF,thisoneforinstance 关于mysql-MySQL可以在UPDATE中进行正则表达式替换吗?,我们在StackOverf

mysql - information_schema 表和 update_time 行为

我想对information_schema及其行为进行一些解释。假设我想知道myisam表何时被修改。我写这个查询selectupdate_timefrominformation_schema.tableswheretable_schema='my_db'andtable_name='my_table'即使我对我的表应用了一些更改,但在我运行flushtables之前,它什么也没有发生。不幸的是,在我看来update_time存储了我运行刷新表的那一刻的日期和时间,而不是真正发生表更改的那一刻。是真的吗?提前致谢。 最佳答案 我个人

mysql - 如何在 MySQL 中使用 LAST_INSERT_ID 关键字传递表名?

如何以表名作为参数在MySQL中查找最后一个标识插入值?当我使用LAST_INSERT_ID()关键字时,我无法获取表名。 最佳答案 确实,你不能那样做。我建议您在应用程序级别使用它-在PHP/Python/Ruby/Perl等中 关于mysql-如何在MySQL中使用LAST_INSERT_ID关键字传递表名?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/6172207/

由于 "Cannot add or update a child row: foreign key constraint fails",MySQL .cs​​v 加载失败

我正在尝试将包含棒球时间表的.csv文件加载到游戏表中。csv文件内容如下所示:5/17/2011,8:10PM,14,13,KansasCity,MO5/18/2011,8:10PM,14,16,Chicago,IL5/19/2011,8:10PM,14,16,Chicago,IL5/20/2011,7:05PM,26,14,Columbus,OH我尝试插入它们的sql语句是:LOADDATALOCALINFILE'c:/ftpsite/comp.csv'INTOTABLEgameFIELDSTERMINATEDBY','ENCLOSEDBY'"'LINESTERMINATEDBY'

php - 组合 SELECT 和 UPDATE 以避免重复选择

我想结合SELECT和UPDATE查询,以避免重复选择行。这是我的示例代码:privatefunctiongetNewRCode(){$getrcodesql="SELECT*FROM`{$this->mysqlprefix}codes`WHERE`used`=0LIMIT1;";$getrcodequery=$this->mysqlconn->query($getrcodesql);if(@$getrcodequery->num_rows>0){$rcode=$getrcodequery->fetch_array();$updatercodesql="UPDATE`{$this->m

php - mysql 'FOR UPDATE' 命令无法正常工作

我有两个php页面,page1.php和page2.phppage1.phpexecute_query('STARTTRANSACTION');$res=execute_query('SELECT*FROMtableWHEREid=1FORUPDATE');sleep(20);print$res->first_name;execute_query('COMMIT');print"\nOK";page2.php$res=execute_query('SELECT*FROMtableWHEREid=1');print$res->first_name;我几乎同时执行两个页面所以根据mysql