Mysql
 sql >> база данни >  >> RDS >> Mysql

Намерете позицията на низа и се присъединете към реда на друга таблица

Разделете низ на колони:

select date,
       substring_index(cost, '-', 1) type_a,
       case when cost regexp '.*-' then
                 substring_index(substring_index(cost, '-', 2), '-', -1)
            else ''
       end type_b,
       case when cost regexp '.*-.*-' then
            substring_index(substring_index(cost, '-', 3), '-', -1)
            else ''
       end type_c,
       case when cost regexp '.*-.*-.*-' then
            substring_index(substring_index(cost, '-', 4), '-', -1)
            else ''
       end type_d,
       case when cost regexp '.*-.*-.*-.*-' then
            substring_index(substring_index(cost, '-', 5), '-', -1)
            else ''
       end type_e
from rate_cost;

Ако можете да промените дизайна на таблицата, по-добре е да създадете няколко колони:

create table rate_cost (
    id int,
    rate int,
    hotel int,
    cost_type_a int,
    cost_type_b int,
    cost_type_c int,
    cost_type_d int,
    cost_type_e int,
    date date);



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Spring boot JPA:Използвайте библиотека за групово зареждане на данни за MySQL

  2. Изчислете възрастта с десетични знаци от датата на раждане

  3. MySQL база данни за съхранение на продукти, цвят, размер и наличност

  4. Извикване на PHP променливи от вътре в MySQL база данни

  5. Категоризирайте данните за автоматично попълване