where a='a' limit 0,20先拿出想要的数据。
2 select found_rows() as num再计算上个结果集个数。
mysql_affected_rows() 返回最近一次与 连接句柄 关联的 INSERT,UPDATE 或 DELETE 查询所影响的记录行数.FOUND_ROWS() : select ROW_COUNT() : update delete insert.
FOUND_ROWS() : select
ROW_COUNT() : update delete insert.
MySQL的函数中,SELECT是另外一个单独的函数 FOUND_ROWS() , UPDATE等是 ROW_COUNT()
如下案例:
mysql>INSERT INTO t VALUES(1),(2),(3) Query OK, 3 rows affected (0.00 sec) Records: 3 Duplicates: 0 Warnings: 0 mysql>SELECT ROW_COUNT() +-------------+ | ROW_COUNT() | +-------------+ | 3 | +-------------+ 1 row in set (0.00 sec)
mysql_affected_rows
(PHP 3, PHP 4 , PHP 5)
mysql_affected_rows -- 取得前一次 MySQL *** 作所影响的记录行数说明
int mysql_affected_rows ( [resource link_identifier])
mysql_affected_rows() 返回最近一次与 连接句柄 关联的 INSERT,UPDATE 或 DELETE 查询所影响的记录行数。如果连接句柄没有指定, 则默认使用最近一次由 mysql_connect() 函数打开的连接句柄。
注: 如果你使用事务处理(transactions),你需要在 INSERT,UPDATE 或 DELETE 查询后调用 mysql_affected_rows() 函数,而不是在 commit 命令之后。
如果最近一次 *** 作是没有任何条件(WHERE)的 DELETE 查询, 在表中所有的记录都会被删除,但该函数返回值为 0。
注: 当使用 UPDATE 查询,MySQL 不会将原值和新值一样的列更新。 这样使得 mysql_affected_rows() 函数返回值不一定就是查询条件所符合的记录数。 只有真正被修改的记录数才会被返回。
mysql_affected_rows() 函数不适用于 SELECT 语句;只适用于能够修改记录的语句中。请使用 mysql_num_rows() 函数来获得 SELECT 所返回的记录行数。
如果最近一次查询失败的话,函数返回 -1。 例子 1. Delete *** 作
<?php /* 连接数据库 */ mysql_pconnect("localhost", "mysql_user", "mysql_password") or die ("Could not connect" . mysql_error()) mysql_select_db("mydb") /* 这会返回有效的被删除记录数。 */ mysql_query("DELETE FROM mytable WHERE id <10") printf ("Records deleted: %d/n", mysql_affected_rows()) /* 没有任何条件(where)的删除语句,返回 0 */ mysql_query("DELETE FROM mytable") printf ("Records deleted: %d/n", mysql_affected_rows()) ?>
以上的例子会得出下面的运行结果:
Records deleted: 10Records deleted: 0
例子 2. Update *** 作
<?php /* 连接数据库 */ mysql_pconnect("localhost", "mysql_user", "mysql_password") or die ("Could not connect" . mysql_error()) mysql_select_db("mydb") /* Update 记录 */ mysql_query("UPDATE mytable SET used=1 WHERE id <10") printf ("Updated records: %d/n", mysql_affected_rows()) mysql_query("COMMIT") ?>
以上的例子会得出下面的运行结果:
Updated Records: 10
参见 mysql_num_rows() 和 mysql_info()。
mysql_affected_rows() 返回的是对行 *** 作的个数
$query=mysql_query("select * from love_mp3_table ")
mysql_affected_rows()//其实对这个也有效,返回44,在这和mysql_num_rows($query)效果一样
$query=mysql_query("INSERT INTO table(id,title,hrefurl) VALUE('','节节胜利','http://')")
mysql_affected_rows()//返回1
$query=mysql_query("DELETE FROM tabel WHERE id=45")
mysql_affected_rows()//返回1
$query=mysql_query("UPDATE table SET title='我是' WHERE id=44")
mysql_affected_rows()//返回1
语法:
第二个SELECT语句返回一个数字,该数字指示如果不使用LIMIT语句写入第一个SELECT将会返回多少行。
如果您使用的是 SELECT SQL_CALC_FOUND_ROWS ,MySQL 必须计算整个结果集中有多少行。但是,这比不使用LIMIT再次运行查询要快,因为不需要将结果集发送到 Client 端。
中文——mysql5.7官方文档
在mysql8.0版本的官方文档中,不推荐使用 SQL_CALC_FOUND_ROWS 选项,并计划在后续版本中废弃。
mysql8.0文档
注意:
mysql会为当前连接保存这个值,各个连接的SQL_CALC_FOUND_ROWS结果互不影响
两条sql语句可以简化成一条sql语句,看似简单了,实则不然。
原因:
来源—— SQL_CALC_FOUND_ROWS的用法
哪个最快?SELECT SQL_CALC_FOUND_ROWS FROM table ,或 SELECT COUNT(*)
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)