草庐IT

order_rows

全部标签

MySql Performance : INSERT. ..ON DUPLICATE KEY UPDATE 或 UPDATE & ROW_COUNT

我查询大部分时间都会更新现有记录。但是,我需要检查此记录是否存在,如果不存在,我应该创建它。通常我会使用INSERT...ONDUPLICATEKEYUPDAT,但由于只需要插入几个查询,我正在考虑执行UPDATE并稍后检查如果返回的ROW_COUNT()为零,并且在这种情况下执行INSERT。什么会给我最好的表现? 最佳答案 MySQL有一个REPLACEINTO语法,这可能就是您正在寻找的。如果这对您不起作用,使用UPDATE并检查ROW_COUNT()应该可行,您可能希望将整个事情包装在存储过程中,这样您就可以节省返回服务器的

PHP 或 MYSQL : how to group results by ROW?

我正在使用mysql这些是我的tableD----------id,name----------1,d12,d23,d3t----------id,name----------1,t12,t23,t3c----------id,d_id,t_id----------1,1,11,1,21,1,31,2,11,2,21,2,31,3,11,3,21,3,3我想产生一个查询来得到这样的结果-------------------------------------------d.name,t.name,t.name,t.name--------------------------------

php - MySQL ORDER BY 结果不是按字母顺序排列的

我一直在努力寻找解决这个问题的方法,但一直没有成功。我知道这里有几个类似的问题,但它们都是更复杂的场景,并不真正适用。好的,问题:我有一个非常简单的表格,其中包含交易收款人及其相关类别的列表。结构为id-int,name-varchar,andcat-varchar我正在尝试执行一个简单的查询以按字母顺序显示收款人姓名,并使用while循环将其添加到选择框中。无论我是否使用ASC或DESC,它们都没有明显的顺序显示条目的开头或结尾没有空格。这是查询-SELECTnameFROMpayeesORDERBYname尝试在phpMyAdmin中按字母顺序对它们进行排序时,我得到了相同的结果。

mysql order by 不是唯一的等级?

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:HowdoIHandleTiesWhenRankingResultsinMySQL?我想按Activepoints对表Status进行排序,并将排名插入列rank中。它来了:RANKUSERNAMEACTIVEPOINTS1monkey100922fresnoJump543otherUser954但它应该显示的不是唯一的排名RANKUSERNAMEACTIVEPOINTS1monkey100922fresnoJump542otherUser954

mysql_affected_rows 有时返回 0 而不是 1

我对php脚本有一个奇怪的问题-mysql_affected_rows()有时会无缘无故地返回“0”。有一个类似的问题@stackoverflow,这个问题的答案是:如果更新前后存在明显差异,MySQL只会实际更新一行。但这不是我的情况。例如,如果更新前的值为1320402744并且更新后的值为1320402944mysql_affected_rows()无论如何都会返回“0”。这种差异还不够明显吗?下面是3个文件。如您所见,所有文件都包含调用函数“online()”的文件“functions.inc.php”。文件“login.php”工作正常。它会在“session”表中正确插入一

mysql - 优化 MySQL - WHERE 和 ORDER BY 使用不同的列

我有一个115MByte、1,600,000行的表,用于存储房价和坐标。“SELECT”查询花费的时间太长。我想知道是否有人可以建议加快速度的方法。我的表的稍微简化的版本....CREATETABLE`prices1`(`price`INT(10)NOTNULL,`address`VARCHAR(127)NOTNULL,`lat`FLOAT(6,4)NOTNULLCOMMENT'GPSlatitude',`lng`FLOAT(6,4)NOTNULLCOMMENT'GPSlongitude',INDEX`lat`(`lat`),INDEX`price`(`price`))ENGINE=M

尽管缺少子查询,但 MySQL 更新错误为 "Subquery returns more than 1 row"

我有一个关于mysql5.1.56的查询:select*fromteam_member_accountswherenode=33136...正好返回一行。但是,以下查询错误Subqueryreturnsmorethan1row:updateteam_member_accountssetfee_remaining=0,loan_account_balance=35000,reimbursable_amount=0,reimbursed_amount=0wherenode=33136嗯……什么?什么子查询?怎么超过一排? 最佳答案 该表

mysql - 具有多个 where 和 order by 子句的慢查询

我正在尝试寻找一种方法来加速缓慢的(文件排序)MySQL查询。表格:categories(id,lft,rgt)questions(id,category_id,created_at,votes_up,votes_down)示例查询:SELECT*FROMquestionsqINNERJOINcategoriescON(c.id=q.category_id)WHEREc.lft>1ANDc.rgt如果我删除ORDERBY子句,它会很快。我知道MySQL不喜欢在同一个子句中同时使用DESC和ASC命令,所以我尝试添加一个复合(created_at,votes_up)索引到question

mysql - ORDER BY 中使用的计算值是否在排序期间重新计算过?

假设我们有一个查询,它按未选择的计算值排序,例如:select*fromtableorderbycol1*col2-col3在大多数语言的典型排序操作中,在排序过程中多次使用排序值是很常见的,因为给定的记录可能与许多其他记录进行比较。有可能mysql有这样的实现。如果mysql每行一次计算这样的值并在排序完成时临时存储它们,或者每当进行比较时重新计算这些值,谁能说明确地(这可能是1-n次)?我已经标记了这个mysql,但我欢迎关于/包括其他流行数据库的评论/回答 最佳答案 答案是...mysql每行执行计算一次。由于缺乏可信的答案,

mysql - 在两个不同的组中使用 ORDER BY 的 SQL 查询

假设我有一张包含NBA球员的简单表格:id,player,mp,ppg(mp-参加的比赛,ppg-每场比赛的得分)。我需要一个查询来获取所有人员,但将结果分成两部分:按PPGdesc要求参加了30场以上比赛的球员,按PPGdesc要求打了不到30场比赛的球员理想的输出是(示例):n.playermpppg1.player18232.52.player25632.13.player38229.74.player48027.6...70.player70751.5(lowestinthe30+gamesgroup)71.player712935.7(highestinthelessthan