|
|
|
Как можно указать номер вхождения в строку, позиция которого интересует?
|
|||
|---|---|---|---|
|
#18+
Есть данные вида "0.1", "0.1.3". То есть десятичные числа, разделенные точкой. Мен нужно отобрать значения, где фигурирует не меньше трех чисел (то есть минимум две точки) и вычислить для них родителя (значение без последнего числа). То есть для "0.1.3" родителем будет "0.1", для "0.1" родителя нет, а для "0.4.1.3" родителем будет "0.4.1". INSTR всегда находит только первое вхождение. Можно сконструировать сложное выражение INSTR(SUBSTRING(fld,INSTR(fld,'.')+1),'.')+INSTR(fld,'.')-1, но может быть есть более подходящая функция? ________________________ Мы смотрим с оптимизмом... ...в оптический прицел. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 06.04.2016, 10:46 |
|
||
|
Как можно указать номер вхождения в строку, позиция которого интересует?
|
|||
|---|---|---|---|
|
#18+
SUBSTRING_INDEX() ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 06.04.2016, 12:11 |
|
||
|
|

start [/forum/topic.php?fid=47&gotonew=1&tid=1831956]: |
0ms |
get settings: |
7ms |
get forum list: |
18ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
80ms |
get topic data: |
11ms |
get first new msg: |
12ms |
get forum data: |
3ms |
get page messages: |
60ms |
get tp. blocked users: |
1ms |
| others: | 213ms |
| total: | 411ms |

| 0 / 0 |
