前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL中用快速为select结果加序号

MySQL中用快速为select结果加序号

原创
作者头像
莫晓东do
发布2018-07-17 19:31:55
5.2K1
发布2018-07-17 19:31:55
举报
文章被收录于专栏:数据存储数据存储

这是一个select的结果集,如何最快的给前面补上连续递增的序号?

这里是个例子:

set @a=0;select @a:=@a+1,user,host from mysql.user;

这里定义了一个变量@a,并在select中动态赋值,实现每行加一。

这个语句也可以用在update中,如:

set @a=0;update table_name set col_name=@a where @a:=@a+1;

这里在mysql5有个潜规则:

如果where后有多个条件,那么变量只会计算一次。如果语句col_name将始终为1。

where @a:=@a+1 and col2_name='xxx';

这时只能通过临时表增加一个递增列,或者联表操作完成。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档