草庐IT

bigger_than_cachesize

全部标签

尽管缺少子查询,但 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 - 如何: Find and update all the entries where the value in one column shows up more than once

我有一个包含以下列的表格:subid-资源的idauthorid-作者的id排序-作者在引用中的顺序对于用户可以提交资源并引用多个作者的应用程序。作者可以在他们的投稿中引用主要和次要作者,而且通常会这样做。有一种情况,用户(称他为用户111)提交的所有条目都将自己列为主要作者,实际作者为次要作者。不幸的是,那个人已经离开了这个项目,所以我来解决这个问题(我必须纯粹用sql来做)。我正在尝试弄清楚如何构建一个查询来执行以下操作:查找所有条目subid值在表中出现多次其中至少一个authorid值是111111的排序大于非111的任何用户的排序并更新它们not(111)作者的排序为“0”并

mysql - SQL order by after more than

我正在尝试使用SQL对结果进行排序id|name(tablename:student)-----1|jhon2|amin3|heli4|mir5|mrs6|amr7|jonnathan8|adhy当我使用这个查询时selectidfromstudenthwhereid>='3'orderbyidDESClimit2出现的结果是id|name(tablename:student)-----8|adhy7|jonnathan虽然我想在id=3之后对结果进行排序,但我想要如下数据id|name(tablename:student)-----4|mir3|heli

MySQL 选择 : where time is greater then and less than time

我有一个接受两个时间参数的函数:$start_time,$end_time每个参数在php中定义为时间$start_time=date("H:i:s",strtotime($start));->like"06:12:44"$end_time=date("H:i:s",strtotime($end));->like"08:22:14"我想构建一个查询来给出这些时间之间的结果这是我的功能functionstatistics_connected_hour($gateway_id,$date_sql,$start_time,$end_time){$statistics_connected=my

MySQL 触发器 : print a warning message when an inserted entry is greater than a value

我创建了一个表格如下:mysql>createtabletesta(aint,bint,creal);QueryOK,0rowsaffected(0.14sec)但是当我想实现这样的触发器时,我遇到了一些语法错误:mysql>createtriggertesta_trigbeforeinsertONtestaFOREACHROWWHEN(NEW.c>100)BEGINPrint"Warning:c>100!"END;ERROR1064(42000):YouhaveanerrorinyourSQLsyntax;checkthemanualthatcorrespondstoyourMySQ

MySQL:是否有可能 "INSERT if number of rows with a specific value is less than X"?

打个简单的比方,我有一个表格如下:编号(主键)|gift_giver_id(FK)|gift_receiver_id(FK)|礼物日期是否可以在单个查询中以这样的方式更新表,即仅当该人到目前为止的礼物少于10件时(即少于10行带有相同的gift_giver_id)?这样做的目的是将table大小限制为每人10份礼物。提前致谢。 最佳答案 尝试:insertintotablename(gift_giver_id,gift_receiver_id,gift_date)selectGIVER_ID,RECEIVER_ID,DATEfrom

MySQL - 为什么 "greater than"的 COUNT 很快但 "less than"需要永远?

SELECTcount(*)cFROMfull_viewWHEREverified>(DATE(NOW())-INTERVAL30DAY)如果我运行该查询,它需要一瞬间,但如果我切换比较运算符,它需要很长时间。现在第一种方式计数=0,第二种方式计数=120000,但如果我只计算整个表也需要微秒。但是有一些奇怪的事情正在发生,因为如果查询确实完成了,它会在之后运行得非常快。MySQL正在缓存查询或其他什么?好吧,我不想依赖缓存来确保网站不会挂起。这看起来很荒谬:如果它可以快速计算大于特定日期的所有内容,为什么要花更长的时间来计算相反的日期?无论哪种方式,它都必须查看整个表格,对吗?它只需

mysql - 如果 "Subquery returns more than 1 row"认为它是 NULL

我正在尝试将新表上的商店ID与此处主表中的ID同步:UPDATEnewtabletSETt.store_id=(SELECTstore_idFROMmaintablesWHEREt.state=s.stateANDs.city=t.cityANDt.name=s.name)每当子查询返回多于一行时,它就会出错并显示“子查询返回多于1行”,但是当它返回零行时,子查询被认为没有返回任何内容,因此newtable上的store_id保持为NULL。这里没有什么新东西,这就是它的工作原理。我想知道是否有可能让子查询在有多个匹配行时输出与没有匹配时相同的输出。这样一来,我将只为主表上的一个匹配行

MySQL 查询 : Query All Entries Older Than 1 Year

我正在LibreOffice中为一家非营利性慈善机构构建一个成员(member)数据库,但我没有mysql查询方面的经验,因此非常感谢您的帮助。我正在尝试创建一个查询,以显示成员(member)注册日期字段(PaymentDate)早于当前日期1年的所有记录AND一个bool值另一个字段(AwaitingRenewal)的值为NO。日期采用05/03/85格式。感谢您能给我的任何帮助! 最佳答案 你可以这样做:select*from`members`where`paymentDate`

mysqli语句执行错误: Result consisted of more than one row

我正在使用选择查询从TUsers获取三个值,其中出现错误Mysqli语句执行错误:结果包含多于一行。我使用DISTINCTROW来避免重复,并且我使用Zend框架来调用该过程。代码如下:程序:CREATEDEFINER=`root`@``PROCEDURE`spfetchloginid`(insecurityansvarchar(50),outemailvarchar(50),outloginidoutvarchar(50),outuseridoutvarchar(50))BEGINSELECTDISTINCTROWEmail,login_id,user_idintoemail,log