Python-да байланысты кестелерден деректерді алу
Барлық пайдаланушыларды олардың қалаларымен бірге алатын сұраныс жасайық. Ол үшін
LEFT
JOIN командасы қажет болады:
Оның синтаксисі келесідей:
SELECT өрістер FROM кесте_аты
LEFT JOIN байланысты_кесте_аты ON байланыс_шарты
WHERE таңдау_шарты
Осы команда синтаксисінің жеке бөліктерін қарастырайық.
Өрістер
Таңдау бірнеше кестеден жүргендіктен,
барлық өрістерді * арқылы таңдау
жұмыс істемейді. Келесі сұраныс тек негізгі
кестенің өрістерін таңдайды, бірақ байланысты
кестенікін емес:
SELECT *
Барлық кестелерден деректер таңдалуы үшін,
* алдында таңдау үшін кесте атын көрсету керек:
SELECT users.*, cities.*
Немесе бізге қажет өрістерді олардың алдында кесте атын көрсете отырып, тізбелей аламыз:
SELECT users.name, cities.name
Бұл екі әдістің мәселесі бар. Мәселе мынада, егер кестелердегі өрістердің атаулары бірдей болса, онда Python массивінде атаулар қақтығысады және тек бір өріс ғана жеңіп шығады, екіншісі болмай қалады.
Мәселені шешу үшін қақтығысатын атауларды
as командасы арқылы қайта атау керек:
SELECT users.name, cities.name as city_name
Байланыс
ON командасынан кейін біз екі кестенің
байланыс жасалатын өрістерін көрсетуіміз керек.
Біздің жағдайда бұл қалалар кестесінің id
өрісі және пайдаланушылар кестесінің city_id
өрісі болады:
ON cities.id=users.city_id
Сұраныс
Нәтижесінде, пайдаланушыларды олардың қалаларымен бірге алатын сұраныс келесідей болады:
SELECT
users.name, cities.name as city_name
FROM
users
LEFT JOIN cities ON cities.id=users.city_id
Практикалық тапсырмалар
Сізде тауарлар кестесі және олардың санаттарының кестесі бар делік. Тауарлардың атауларын олардың санаттарымен бірге алатын сұраныс жазыңыз.