CodeGym /జావా కోర్సు /All lectures for TE purposes /బహుళ పట్టికల నుండి డేటాను ఎంచుకోవడం

బహుళ పట్టికల నుండి డేటాను ఎంచుకోవడం

All lectures for TE purposes
స్థాయి , పాఠం
అందుబాటులో ఉంది

ఆధారిత పట్టిక

ఇప్పుడు మన ప్రశ్నలను కొంచెం క్లిష్టతరం చేద్దాం. మా ఉద్యోగుల కోసం టాస్క్‌లతో మా డేటాబేస్‌కు కొత్త టాస్క్ టేబుల్‌ని యాడ్ చేద్దాం. మరి ఇందులో ఎలాంటి ఎంట్రీలు ఉన్నాయో చూద్దాం:

SELECT * FROM task

అటువంటి అభ్యర్థన యొక్క ఫలితం:

id ఉద్యోగి_ఐడి పేరు గడువు
1 1 ఫ్రంటెండ్‌లో బగ్‌ను పరిష్కరించండి 2022-06-01
2 2 బ్యాకెండ్‌లో బగ్‌ను పరిష్కరించండి 2022-06-15
3 5 కాఫీ కొనండి 2022-07-01
4 5 కాఫీ కొనండి 2022-08-01
5 5 కాఫీ కొంటాను 2022-09-01
6 (శూన్య) కార్యాలయాన్ని శుభ్రం చేయండి (శూన్య)
7 4 జీవితం ఆనందించండి (శూన్య)
8 6 జీవితం ఆనందించండి (శూన్య)

ఈ పట్టికలో 4 నిలువు వరుసలు మాత్రమే ఉన్నాయి:

  • id — ప్రత్యేకమైన పని సంఖ్య (మరియు పట్టికలోని వరుసలు);
  • Employee_id — ఉద్యోగి పట్టిక నుండి పనిని కేటాయించిన ఉద్యోగి యొక్క ID;
  • పేరు - పని యొక్క పేరు మరియు వివరణ;
  • గడువు - పనిని పూర్తి చేయవలసిన సమయం.

కొన్ని సూక్ష్మ నైపుణ్యాలకు శ్రద్ధ వహించండి. టాస్క్ N6లో ఉద్యోగి_ఐడి లేదు, మా వద్ద క్లీనర్ లేదు. పని ఉంది, కానీ ప్రదర్శకుడు లేదు. అది జరుగుతుంది.

అలాగే, 6-9 పనులకు నిర్ణీత గడువు లేదు. ఒక పనిని క్రమం తప్పకుండా మరియు నిరంతరంగా చేసినప్పుడు ఇది జరుగుతుంది. ఉదాహరణకు, ఆఫీసుని ప్రతిరోజూ శుభ్రం చేయాలి, కానీ మీరు ప్రతిరోజూ జీవితాన్ని ఆస్వాదించాలి :)

ఒక టేబుల్ మరొక టేబుల్ నుండి IDలను ఉపయోగిస్తే, అటువంటి పట్టికను డిపెండెంట్ అంటారు .

బహుళ పట్టికలకు వ్యతిరేకంగా ప్రశ్న

ఇక్కడ టాస్క్ టేబుల్‌లో “జీవితాన్ని ఆస్వాదించడం” అనే రెండు టాస్క్‌లు ఉన్నాయని మనం చూస్తాము. ఈ అదృష్టవంతులు ఎవరో మనకు ఎలా తెలుస్తుంది?

దీన్ని చేయడానికి, SQLలో, మీరు ఒకేసారి రెండు పట్టికలలో ప్రశ్నను అమలు చేయవచ్చు. సాధారణంగా, SQLలో, మీరు ఒకే సమయంలో ఎన్ని టేబుల్‌లనైనా ప్రశ్నించవచ్చు. అటువంటి అభ్యర్థన యొక్క సాధారణ ఆకృతి:

SELECT columns
FROM Table 1, table 2, tableN

ముఖ్యమైనది! మీరు ఒకే సమయంలో అనేక పట్టికలకు ఒక ప్రశ్నను వ్రాస్తే, ఫలితంగా మీరు పట్టిక వరుసల యొక్క కార్టేసియన్ ఉత్పత్తి అని పిలవబడే దాన్ని పొందుతారు. మొదటి పట్టిక నుండి ప్రతి అడ్డు వరుస రెండవ పట్టిక నుండి ప్రతి అడ్డు వరుసకు అతుక్కొని ఉంటుంది.

అంటే, మీకు మొదటి పట్టికలో 5 వరుసలు మరియు రెండవదానిలో 10 వరుసలు ఉంటే, మీకు మొత్తం 50 వరుసలు ఉంటాయి. జావాలో, ఈ ప్రశ్న ఇలా కనిపిస్తుంది:

for (String row1 : table1)
{
	for (String row2 : table2)
   {
  	System.out.println(row1 + row2);
   }
}

మన ప్రశ్నను ఒకేసారి రెండు పట్టికలకు వ్రాసి ఏమి జరుగుతుందో చూద్దాం:

SELECT * FROM employee, task

మరియు ఈ ప్రశ్న యొక్క ఫలితం:

id పేరు వృత్తి జీతం వయస్సు id ఉద్యోగి _id పేరు గడువు
1 ఇవనోవ్ ఇవాన్ ప్రోగ్రామర్ 100000 25 1 1 ఫ్రంటెండ్‌లో బగ్‌ను పరిష్కరించండి 2022-06-01
2 పెట్రోవ్ పీటర్ ప్రోగ్రామర్ 80000 23 1 1 ఫ్రంటెండ్‌లో బగ్‌ను పరిష్కరించండి 2022-06-01
3 ఇవనోవ్ సెర్గీ టెస్టర్ 40000 ముప్పై 1 1 ఫ్రంటెండ్‌లో బగ్‌ను పరిష్కరించండి 2022-06-01
4 రాబినోవిచ్ మోయిషా దర్శకుడు 200000 35 1 1 ఫ్రంటెండ్‌లో బగ్‌ను పరిష్కరించండి 2022-06-01
5 కిరియెంకో అనస్తాసియా ఆఫీసు మేనేజర్ 40000 25 1 1 ఫ్రంటెండ్‌లో బగ్‌ను పరిష్కరించండి 2022-06-01
6 వాస్కా పిల్లి 1000 3 1 1 ఫ్రంటెండ్‌లో బగ్‌ను పరిష్కరించండి 2022-06-01
1 ఇవనోవ్ ఇవాన్ ప్రోగ్రామర్ 100000 25 2 2 బ్యాకెండ్‌లో బగ్‌ను పరిష్కరించండి 2022-06-15
2 పెట్రోవ్ పీటర్ ప్రోగ్రామర్ 80000 23 2 2 బ్యాకెండ్‌లో బగ్‌ను పరిష్కరించండి 2022-06-15
3 ఇవనోవ్ సెర్గీ టెస్టర్ 40000 ముప్పై 2 2 బ్యాకెండ్‌లో బగ్‌ను పరిష్కరించండి 2022-06-15
4 రాబినోవిచ్ మోయిషా దర్శకుడు 200000 35 2 2 బ్యాకెండ్‌లో బగ్‌ను పరిష్కరించండి 2022-06-15
5 కిరియెంకో అనస్తాసియా ఆఫీసు మేనేజర్ 40000 25 2 2 బ్యాకెండ్‌లో బగ్‌ను పరిష్కరించండి 2022-06-15

మాకు మొత్తం 48 ఫలితాల పంక్తులు ఉన్నాయి, కానీ ఇక్కడ నేను 11 మాత్రమే ఇచ్చాను. లేకపోతే, తగినంత స్థలం ఉండదు.

మూడు విషయాలపై శ్రద్ధ వహించండి:

  • అదే పేర్లతో నిలువు వరుసలు: id . ఇది ఉద్యోగి టేబుల్ నుండి ఐడి మరియు టాస్క్ టేబుల్ నుండి ఐడి .
  • ప్రతి పట్టిక యొక్క వరుసలు పునరావృతమవుతాయి. ఎడమ కాలమ్‌లో, ID 6 తర్వాత ID = 1 మళ్లీ వస్తుంది.
  • మేము అర్ధంలేని వరుసలను కలిగి ఉన్నాము, ఉదాహరణకు, id (ఉద్యోగి పట్టిక నుండి) 6 మరియు అదే వరుసలో ఉద్యోగి_id 1.

అర్థం లేని పంక్తులను తొలగించడం

మా ఫలిత పట్టికలో చాలా వరుసలు ఉన్నాయి , ఇది రెండు టేబుల్‌ల ఉద్యోగి మరియు టాస్క్‌లోని అన్ని వరుసల కార్టెసియన్ ఉత్పత్తి .

తార్కికంగా, ఉద్యోగి_id అడ్డు వరుస 3 అయితే, అది id 3 ఉన్న ఉద్యోగి పట్టికలోని అడ్డు వరుసకు మాత్రమే కట్టుబడి ఉండాలి. WHEREతో ఈ అపార్థాన్ని పరిష్కరించడానికి ప్రయత్నిద్దాం.

ఇలా ఒక ప్రశ్న రాద్దాం:

SELECT * FROM employee, task 
WHERE emploee.id = task.emploee_id 

మరియు ఈ ప్రశ్న యొక్క ఫలితం:

id పేరు వృత్తి జీతం వయస్సు id ఉద్యోగి_ఐడి పేరు గడువు
1 ఇవనోవ్ ఇవాన్ ప్రోగ్రామర్ 100000 25 1 1 ఫ్రంటెండ్‌లో బగ్‌ను పరిష్కరించండి 2022-06-01
2 పెట్రోవ్ పీటర్ ప్రోగ్రామర్ 80000 23 2 2 బ్యాకెండ్‌లో బగ్‌ను పరిష్కరించండి 2022-06-15
4 రాబినోవిచ్ మోయిషా దర్శకుడు 200000 35 7 4 జీవితం ఆనందించండి (శూన్య)
5 కిరియెంకో అనస్తాసియా ఆఫీసు మేనేజర్ 40000 25 3 5 కాఫీ కొనండి 2022-07-01
5 కిరియెంకో అనస్తాసియా ఆఫీసు మేనేజర్ 40000 25 4 5 కాఫీ కొనండి 2022-08-01
5 కిరియెంకో అనస్తాసియా ఆఫీసు మేనేజర్ 40000 25 5 5 కాఫీ కొంటాను 2022-09-01
6 వాస్కా పిల్లి 1000 3 8 6 జీవితం ఆనందించండి (శూన్య)

శుభవార్త ఏమిటంటే అర్థరహిత పంక్తులు అదృశ్యమయ్యాయి: మొదటి నిలువు వరుసలోని id ఎల్లప్పుడూ ఉద్యోగి_idకి సమానంగా ఉంటుంది.

చేదువార్త ఏమిటంటే, ఎవరికీ అప్పగించని పనులు, కార్యాలయాన్ని శుభ్రం చేయడం వంటివి పోయాయి. వారి ఉద్యోగి_ఐడి NULL, కాబట్టి వారు ఎక్కడ పూర్తి చేసిన తర్వాత విస్మరించబడ్డారు.

వ్యాఖ్యలు
TO VIEW ALL COMMENTS OR TO MAKE A COMMENT,
GO TO FULL VERSION