如何用sqlserver 改变一个列按一定的顺序排列,

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何用sqlserver 改变一个列按一定的顺序排列,相关的知识,希望对你有一定的参考价值。

让JBBH 101,102,103,104。。。。。。

试试这个,能解决你的问题:
假设表名为tablename
--加自增列tempCol ,101为起始值,1为自增值,更新之后删掉这列
alter table tablename add tempCol int identity(101,1)。
参考技术A 试试这个,能解决你的问题:
假设表名为tablename
--加自增列tempCol ,101为起始值,1为自增值,更新之后删掉这列
alter table tablename add tempCol int identity(101,1)
update tablename set JBBH = tempCol
alter table tablename drop column tempCol本回答被提问者和网友采纳
参考技术B 添加order by JBBH追问

我的表里已经有了数据

追答

哦,我知道你的意思了,原来这个列没有值
oracle中可以用sequence实现
sqlserver只能写存储过程了

如何用一个循环顺序循环多个列表? [复制]

【中文标题】如何用一个循环顺序循环多个列表? [复制]【英文标题】:How to loop through multiple lists sequentially with one loop? [duplicate] 【发布时间】:2018-05-10 00:56:15 【问题描述】:

Python 3.6.3 中,有没有办法在一个接一个的列表中循环?

例如:

deck = [(value, suit) for value in range(2, 11) +
            ["J", "Q", "K", "A"] for suit in ["H", "C", "D", "S"]]

(在这种情况下,我想在非面卡之后循环遍历面卡。)

为了澄清: 上面的行抛出一个:

TypeError: unsupported operand type(s) for +: 'range' and 'list'

这是我的问题。

【问题讨论】:

你的例子不清楚。预期的结果/输出是什么? @timgeb 在示例中,我尝试制作一副标准的 52 张卡片。问题是我想在编号卡片之后立即迭代 "J", "Q", "K", "A" 而不需要第二次循环。 @schwobaseggl 此行引发类型错误:“TypeError: unsupported operand type(s) for +: 'range' and 'list'” @Josh range() 不会在 Python 3 中创建列表。它曾经在 Python 2 中创建列表。range() 在 Python 3 中确实创建了不可变序列类型,不是列表。 【参考方案1】:

range 在 Python3 中不返回 list,因此 range(2, 10) + ["J", "Q", "K", "A"] 不起作用,但 list(range(2, 10)) + ["J", "Q", "K", "A"] 可以。您还可以使用itertools.chain 连接可迭代对象:

from itertools import chain 

chain(range(2, 10), ["J", "Q", "K", "A"])
# or even shorter:
chain(range(2, 10), "JQKA")  # as strings themselves are iterables

# so this comprehension will work
deck = [
   (value, suit) 
   for value in chain(range(2, 10), "JQKA") 
   for suit in "HCDS"
]

当然,嵌套推导确实构成了一个笛卡尔积,您也可以使用 util:

from itertools import product
deck = list(product(chain(range(2, 10), "JQKA"), "HCDS"))

【讨论】:

【参考方案2】:

您当前代码的问题在这里:

range(2, 10) + ["J", "Q", "K", "A"]

首先应该是range(2, 11),否则会省略编号为10的卡片。其次,为了加入范围和列表,您必须这样做:

list(range(2, 11)) + ["J", "Q", "K", "A"]

所以最终的结果是:

deck = [(value, suit) for value in list(range(2, 11)) + ["J", "Q", "K", "A"] for suit in ["H", "C", "D", "S"]]

我认为这将为您提供所需的输出(首先是所有非人脸卡,然后是所有人脸卡)。

【讨论】:

这可行,但@schwobaseggl 使用 itertools 有更好的解决方案,因为它不需要不必要地构造列表,然后进行列表连接。【参考方案3】:

请参阅@schwobaseggl 的解决方案,但我通常更喜欢将卡片表示为 2 个字符的字符串:

deck = [r+s for r in '23456789TJQKA' for s in 'hcds']

在我看来,这更具可读性,并且仍然很像等级元组,西装。

【讨论】:

不需要*【参考方案4】:

在Python3中,可以使用解包:

deck = [(value, suit) for value in [*range(2, 10), "J", "Q", "K", "A"] for suit in ["H", "C", "D", "S"]]

【讨论】:

那里不需要list 呼叫:[*range(2, 10), "J", "Q", "K", "A"] 就足够了。 (甚至[*range(2, 11), *"JQKA"]。) @MarkDickinson 很高兴知道。请查看我最近的编辑。【参考方案5】:

只关注你得到的错误:

TypeError:+ 的不支持的操作数类型:“范围”和“列表”

我会给你一个解释。

您当前的代码在 Python 2 中工作:

deck = [(value, suit) for value in range(2, 11) + ["J", "Q", "K", "A"] for suit in ["H", "C", "D", "S"]]
print deck

将打印:

[(2, 'H'), (2, 'C'), (2, 'D'), (2, 'S'), (3, 'H'), (3, 'C'), (3, 'D'), (3, 'S'), (4, 'H'), (4, 'C'), (4, 'D'), (4, 'S'), (5, 'H'), (5, 'C'), (5, 'D'), (5, 'S'), (6, 'H'), (6, 'C'), (6, 'D'), (6, 'S'), (7, 'H'), (7, 'C'), (7, 'D'), (7, 'S'), (8, 'H'), (8, 'C'), (8, 'D'), (8, 'S'), (9, 'H'), (9, 'C'), (9, 'D'), (9, 'S'), (10, 'H'), (10, 'C'), (10, 'D'), (10, 'S'), ('J', 'H'), ('J', 'C'), ('J', 'D'), ('J', 'S'), ('Q', 'H'), ('Q', 'C'), ('Q', 'D'), ('Q', 'S'), ('K', 'H'), ('K', 'C'), ('K', 'D'), ('K', 'S'), ('A', 'H'), ('A', 'C'), ('A', 'D'), ('A', 'S')]

Python 3 中,您必须使用 list(range(2, 11))

deck = [(value, suit) for value in list(range(2, 11)) + ["J", "Q", "K", "A"] for suit in ["H", "C", "D", "S"]]
print(deck)

将打印:

[(2, 'H'), (2, 'C'), (2, 'D'), (2, 'S'), (3, 'H'), (3, 'C'), (3, 'D'), (3, 'S'), (4, 'H'), (4, 'C'), (4, 'D'), (4, 'S'), (5, 'H'), (5, 'C'), (5, 'D'), (5, 'S'), (6, 'H'), (6, 'C'), (6, 'D'), (6, 'S'), (7, 'H'), (7, 'C'), (7, 'D'), (7, 'S'), (8, 'H'), (8, 'C'), (8, 'D'), (8, 'S'), (9, 'H'), (9, 'C'), (9, 'D'), (9, 'S'), (10, 'H'), (10, 'C'), (10, 'D'), (10, 'S'), ('J', 'H'), ('J', 'C'), ('J', 'D'), ('J', 'S'), ('Q', 'H'), ('Q', 'C'), ('Q', 'D'), ('Q', 'S'), ('K', 'H'), ('K', 'C'), ('K', 'D'), ('K', 'S'), ('A', 'H'), ('A', 'C'), ('A', 'D'), ('A', 'S')]

您必须使用 list(),因为 Python 3 中的 range() 确实创建了不可变序列类型,而不是列表。

【讨论】:

以上是关于如何用sqlserver 改变一个列按一定的顺序排列,的主要内容,如果未能解决你的问题,请参考以下文章

js如何在一个排好数组里插一个数,不改变顺序

sqlserver使用cte实现某列按字符分隔成多行

如何用python按顺序获取一个线条组成的图形的点坐标

是在java中,如何用Poi导出excel,导出的是一个jsp页面的列表,并且,POI.jar包如何下载?

Java SE如何用Java实现直接选择排序

如何用EXCEL随机生成一定位数的字符串