草庐IT

row_count

全部标签

mysql - 我需要使用 COUNT() 函数将表中不存在的数据选择为零,如何使用 Sql 执行此操作

例如:SELECTCOUNT(num)ASnumber,StatusFROMbaseWHEREStatusin('P','J','K')GROUPBYStatus;注意:J和K不存在于Status列中,但我需要将数字显示为零结果应该是这样的:number|Status---------------1500|P0|J0|K 最佳答案 您可以使用派生表和LEFTJOIN:SELECTcount(base.num)ASnumber,s.StatusFROM(SELECT'P'ASStatusUNIONALLSELECT'J'UNIONAL

php - mysql_num_rows 是否有效和/或标准做法?

前段时间我在研究SQLite,试图移植我的一些站点以使用它而不是MySQL。我因为缺少计算结果的函数而挂断了电话,例如PHP的mysql_num_rows()。稍作搜索后,我发现了thismaillist,它说(据我所知)SQLite没有那个功能,因为它效率低下。它声明编写需要知道返回了多少行的代码是错误的形式。我一般使用mysql_num_rows来检查空返回结果。例如:$query="SELECT*FROMtableWHEREthing='whatever'";$results=mysql_query($query);if(mysql_num_rows($results)){whi

php - PHP 中 mysql_affected_rows() 的奇怪行为

我有一个名为user_ips的表来跟踪用户,以防他们删除cookie或更改浏览器。所以无论如何,下面的代码很简单。它更新user_ips中等于用户ID和IP的条目。如果查询没有更新任何行,则意味着该用户的IP不在表中,因此将其插入。$site->query('UPDATE`user_ips`SET`last_time`=UNIX_TIMESTAMP(),`user_agent`=\''.$this->user_agent.'\'WHERE`ip`='.$this->ip.'AND`userid`='.$this->id);if(mysql_affected_rows()==0){$si

mysql - 获取 COUNT() 的 SUM()

mysql中有没有办法实现SELECTCOUNT(SUM(field2))FROMTABLEWHEREfield1='value'GROUPBYfield2返回一行,其中包含统计字段2的总和。Field1&&Field2都不是唯一的。如果需要更多信息,请告诉我。编辑:我没有想清楚。我需要COUNTofTheCOUNT。所以字段2中的所有计数值。这可以通过获取行数来实现,但我为此选择了:SELECTCOUNT(first_count)total_countFROM(SELECTCOUNT(field2)asfirst_countFROMTABLEWHEREfield1='value'GR

mysql - CakePHP:查找 ('count' ) 和 DISTINCT 字段与查找 ('all' ) 和 GROUP BY 字段

我正在CakePHP中构建查询,但无法在我的find('count')中使用GROUPBY语句,因为它会引发错误。因此,我在字段列表中使用了DISTINCT字段来代替GROUPBY语句。所以,从find('count',array('group'=>'field'))我现在有find('count',array('fields'=>'不同的字段'))在应用程序的另一部分,我使用find('all')来获取与上面相同的记录。在这里,我可以使用GROUPBY语句,所以我有:find('all',array('group'=>'field'))我的问题是:上述两个查询是否返回相同的结果?简而

mysql - 使用 COUNT 显示 MySQL 中出现次数超过 2 次的不同记录

我有一个表格,我试图在其中建立一个不同的列表,其中包含表格中出现两次以上的所有城市。我正在尝试当前查询时被告知“函数计数不存在”?我做错了什么?SELECTCOUNT(city)FROM`table1`GROUPBYcityHAVINGCOUNT(city)>=2 最佳答案 您的查询是正确的,您在COUNT和(City)之间提供了一个空格,它必须是COUNT(City)。那会很好用。您的查询应该是这样的:SELECTCity,COUNT(city)CountsFROM`table1`GROUPBYCityHAVINGCOUNT(ci

mysql - UPDATE vs COUNT vs SELECT 性能

这个说法是对还是错这些查询的性能SELECT*FROMtable;UPDATEtableSETfield=1;SELECTCOUNT(*)FROMtable;相同或者曾经有过一个人的表现与另一个人的表现有很大不同的情况吗?更新如果SELECT和UPDATE之间存在很大差异,我会更感兴趣。如果你愿意,你可以忽略COUNT(*)假设select执行全表扫描。更新还将对表中的所有行执行更新。假设更新只更新一个字段-虽然它会更新所有行(它是一个索引字段)我知道他们会花不同的时间,做不同的事情。我想知道的是差异是否显着。例如。如果更新花费的时间是选择的5倍,那么它很重要。使用此作为阈值。而且没有

php - mysql_num_rows 与 mysql_numrows

如果这个问题已经得到回答,请重定向我。我一直在管理遗留系统,我注意到他们使用调用mysql_numrows而不是mysql_num_rows。我花了很多时间搜索有关这些调用的文档,但一无所获。该系统运行良好,我没有发现任何自定义函数的证据。无论如何都知道这是否是旧版本PHP中已弃用的函数?当我添加到系统时,我使用mysql_num_rows,它工作正常。是的,我知道mysql_*已经过时,应该更新系统,但这超出了我的服务范围。我主要只是好奇为什么这有效?谢谢。 最佳答案 mysql_numrows是mysql_num_rows的弃用

mysql - Drupal 数据库 API 查询 - row.update 如果存在,否则 row.insert

我一直在尝试在drupal中运行查询,如果条目已经存在则更新条目,如果不存在则插入新条目。目前的代码如下所示:db_query("IFEXISTS(SELECT%dFROM{uc_posten_packages.pid})UPDATE{uc_posten_packages}SETtitle='%s',label='%s',cost='%d',length='%d',width='%d',height='%d',weight='%d'WHEREpid=%dELSEINSERTINTO{uc_posten_packages}VALUES('%d','%s','%s','%d','%d','

php - 如何检查 $row ['column_name' ] 是否返回空 php mysql

我有一个包含列的表格id,name,phone,describe从我正在使用的这个表中获取值时$row=mysql_fetch_array($query)现在我想检查是否$row['describe']返回空值。如何checkinphp?? 最佳答案 您可以使用==0,这将检查它是否等于0:if($row['describe']==0){/*codetodo*/}或empty(),这将检查它是否为空:if(empty($row['describe'])){/*codetodo*/}就个人而言,我更喜欢!empty(),因为这将检查变