|
|
|
Как можно указать номер вхождения в строку, позиция которого интересует?
|
|||
|---|---|---|---|
|
#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&msg=39209111&tid=1831956]: |
0ms |
get settings: |
7ms |
get forum list: |
9ms |
check forum access: |
2ms |
check topic access: |
2ms |
track hit: |
213ms |
get topic data: |
8ms |
get forum data: |
2ms |
get page messages: |
32ms |
get tp. blocked users: |
1ms |
| others: | 245ms |
| total: | 521ms |

| 0 / 0 |
