📅  最后修改于: 2023-12-03 15:03:05.625000             🧑  作者: Mango
在 MySQL 中,REPEAT()
函数可用于重复一个字符串一定数量的次数。这个函数非常适合用于生成一些特定格式的字符串,比如生成电话号码、邮编等。本文将为你介绍该函数的语法、用法和示例。
REPEAT(str, count)
其中:
str
:表示需要重复的字符串。count
:表示需要重复的次数,必须是一个非负整数。下面是 REPEAT()
函数的例子:
SELECT REPEAT('Hello', 2);
结果为:
HelloHello
这个例子中,REPEAT()
函数将 'Hello'
这个字符串重复两次,因此结果为 'HelloHello'
。
SELECT CONCAT(
SUBSTRING(REPEAT('000', 1 + LENGTH('158')), LENGTH('158') + 1),
'-',
SUBSTRING(REPEAT('0000', 1 + LENGTH('1234')), LENGTH('1234') + 1),
'-',
SUBSTRING(REPEAT('0000', 1 + LENGTH('5678')), LENGTH('5678') + 1)
) AS tel;
结果为:
158-1234-5678
这个例子中,我们用了 CONCAT()
函数将三个字符串连接在一起,用了 SUBSTRING()
函数截取拼接后字符串的一部分,最后用了 REPEAT()
函数生成了格式为 xxx-xxxx-xxxx
的电话号码。
SELECT CONCAT(
SUBSTRING(REPEAT('0000-', 3), 1, LENGTH(REPEAT('0000-', 3))-1),
SUBSTRING(REPEAT('0000-', 3), 1, LENGTH(REPEAT('0000-', 3))-1),
SUBSTRING(REPEAT('0000-', 3), 1, LENGTH(REPEAT('0000-', 3))-1),
SUBSTRING(REPEAT('0000-', 3), 1, LENGTH(REPEAT('0000-', 3))-1)
) AS key;
结果为:
0000-0000-0000-0000
这个例子中,我们用了 SUBSTRING()
函数截取了四个 REPEAT('0000-', 3)
生成的字符串的一部分,最后用了 CONCAT()
函数将它们拼接在一起,生成了格式为 xxxx-xxxx-xxxx-xxxx
的密钥。
REPEAT()
函数是一个很实用的函数,它可以用来生成一些特定格式的字符串。无论你是需要生成电话号码、邮编还是其它一些格式化字符串,都可以使用该函数。在使用该函数时,你需要注意的是,count
参数必须是非负整数,否则会报错。