Oracle 中可以使用标准方法(8i版本以上),也可以使用非标准的 ROWNUM ; MS SQL Server 则在 2005 版本中提供了 ROW_NUMBER() 函数;但在 MySQL 中似乎还没有这样的系统自带功能。虽然 LIMIT 可以很方便的对返回的结果集数量和位置进行过滤,但过滤出来的记录的行号却没办法被 SELECT 到。据说 MySQL 是早就想增加这个功能了,但我是还没找到。 解决方法是通过预定义用户变量来实现:set @mycnt = 0; select (@mycnt := @mycnt + 1) as ROWNUM , othercol from tblname order by othercol; 这样查询出来的结果集中 ROWNUM 就保存了行编号信息。这个行编号信息的某种用途在于当你需要根据需要对数据按照某种规则排序并取出排序之后的某一行数据,并且希望知道这行数据在之前排序中的位置时就用得着了。比如: set @mycnt = 0; select from ( select (@mycnt := @mycnt + 1) as ROWNUM , othercol from tblname order by othercol ) as A where othercol=OneKeyID; 当然你也可以通过创建临时表的方法把查询结果写到某个拥有 auto_increment 字段的临时表中再做查询,但考虑到临时表在 MySQL master / slave 模式下可能产生的问题,用这样临时用户定义变量的方式来计算查询结果集每一行对应的行号还是更为简洁 -- 除非你愿意在 PHP 或其他语言脚本中对返回的整个结果集再作处理。
1、用JS很容易获得。documentgetElementById("table") rowslength
2、既然是从数据库读出的数据,在表格中显示的话一定会用到循环语句吧,定义个变量每次都自加一,等到表格输出完了,行数也出来了。这个是不区分任何语言的解决办法。
3、通过PHP读取的数据一般放在数组里吧,直接获取数组的长度就行了,count($array)
用count函数就可以查看。
比如表名叫test。
要查询表中一共有多少条记录
1
select count() from test;
如果按条件查询的话,就正常使用where条件即可
1
select count() from test where id=1;
querysetFirstResult(0),querysetMaxResults(4);相当于MySQL中的limit 0, 4;
public void testQuery() {
Session session = null;
try {
session = HibernateUtilsgetSession();
sessionbeginTransaction();
Query query = sessioncreateQuery("from User");
querysetFirstResult(0);//从第一条记录开始
querysetMaxResults(4);//取出四条记录
List userList = querylist();
for (Iterator iter=userListiterator(); iterhasNext();) {
User user = (User)iternext();
Systemoutprintln(usergetId());
Systemoutprintln(usergetName());
}
sessiongetTransaction()commit();
}catch(Exception e) {
eprintStackTrace();
sessiongetTransaction()rollback();
}finally {
HibernateUtilscloseSession(session);
}
}
你前面不是配置方言了吗?hibernate会自动根据方言写那个数据库的分页语句的
好的,楼主,那么我们开始吧:
语句:
select from shop where price in(select max(price) from shop group by article);
结果,请看图------->>
以上就是关于如何在MySQL查询结果集中得到记录行号全部的内容,包括:如何在MySQL查询结果集中得到记录行号、从MYsql中读取的数据,经过了PHP的从新修改,筛选后显示的表格,怎么能获取表格的行数、mysql怎么取得查询出了多少条行记录等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)