十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
1、只能用 SELECT.就像下面这个 Hello World 一样,mysql DELIMITER //,mysql CREATE PROCEDURE HelloWorld, BEGIN,SELECT 'Hello World',END/,Query OK, 0 rows affected (0.00 sec),mysql call HelloWorld,Hello World ,row in set 0.00 sec,Query OK, 0 rows affected只有SELECT了。
我们提供的服务有:成都做网站、网站制作、成都外贸网站建设、微信公众号开发、网站优化、网站认证、渝北ssl等。为超过千家企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的渝北网站制作公司
2、mysql没有sqlserver里面控制台的概念,因为mysql全部都是控制台
如果需要在查询语句返回的列中包含一列表示该条记录在整个结果集中的行号 ISO SQL: 标准提出的方法是提供 ROW_NUMBER() / RANK() 函数 Oracle 中可以使用标准方法( i版本以上) 也可以使用非标准的 ROWNUM MS SQL Server 则在 版本中提供了 预定义用户变量来实现
set @mycnt = ;select (@mycnt := @mycnt + ) as ROWNUM othercol from tblname order by othercol;
这样查询出来的结果集中 ROWNUM 就保存了行编号信息 这个行编号信息的某种用途在于当你需要根据需要对数据按照某种规则排序并取出排序之后的某一行数据 并且希望知道这行数据在之前排序中的位置时就用得着了 比如
set @mycnt = ;select * from ( select (@mycnt := @mycnt + ) as ROWNUM othercol from tblname order by othercol) as A where othercol=OneKeyID;
lishixinzhi/Article/program/MySQL/201405/30871
Oracle 中可以使用标准方法(8i版本以上),也可以使用非标准的 ROWNUM ; MS SQL Server 则在 2005 版本中提供了 ROW_NUMBER() 函数;但在 MySQL 中似乎还没有这样的系统自带功能。 解决方法是通过预定义用户变量来实现: mysql set @mycnt = 0; mysql select (@mycnt := @mycnt + 1) as ROWNUM ,NAME fromCHARBASE LIMIT 100; 这样查询出来的结果集中 ROWNUM 就保存了行编号信息。这个行编号信息的某种用途在于当你需要根据需要对数据按照某种规则排序并取出排序之后的某一行数据,并且希望知道这行数据在之前排序中的位置时就用得着了。 为了方便,我们通常将两句合起来执行,以避免变量全局自增:
sqlserver中输出行号:row_number over()
而在mysql中没有排序函数,应该使用:
SET @rownum = 0;
SELECT (@rownum := @rownum + 1) AS ROWNUM , 表名.* FROM 表名;
验证
看你的意思行号就是显示顺序号,你的查询结果可以按id升序排序(order by id),这样查询结果的顺序就是显示的顺序,这个行号可以在程序里加上,不用在数据库操作。另外最好是加上一个排序值得字段,这样可以随时调整显示顺序。