4.1 పరిమితి
మీ SQL ప్రశ్న చాలా ఎక్కువ డేటాను అందించాలని మీరు ఆశించినట్లయితే, మీరు గరిష్ట సంఖ్యను ముందుగానే పరిమితం చేయవచ్చు. అన్నింటికంటే, పట్టికలు వేల లేదా మిలియన్ల వరుసలను కలిగి ఉండవచ్చు.
SQL ఉపయోగించి ప్రశ్న ఫలితంలో అడ్డు వరుసల సంఖ్యను పరిమితం చేయడం చాలా సులభం చేస్తుంది LIMIT
. ఈ కీవర్డ్ SQL ప్రశ్న చివరిలో ఉపయోగించబడుతుంది మరియు ఇలా కనిపిస్తుంది:
LIMIT quantity
మా స్టోర్ ఉత్పత్తుల జాబితాను కలిగి ఉన్న ఉత్పత్తి పట్టికకు వ్యతిరేకంగా ఒక ప్రశ్నను వ్రాస్దాం. కానీ మాకు చాలా విజయవంతమైన స్టోర్ ఉంది మరియు మేము చాలా ఉత్పత్తులను విక్రయిస్తున్నందున, మేము సమాధానం యొక్క మొదటి 10 లైన్లను మాత్రమే పొందాలనుకుంటున్నాము. ఆ అభ్యర్థన ఎలా ఉంటుందో ఇక్కడ ఉంది:
SELECT * FROM product
LIMIT 10
మరియు మేము ఈ క్రింది ప్రశ్న ఫలితాన్ని పొందుతాము:
id | పేరు | బ్రాండ్ | ధర | లెక్కించండి |
---|---|---|---|---|
1 | పట్టిక | IKEA | 20.00 | 15 |
2 | కుర్చీ | IKEA | 5.00 | 45 |
3 | సోఫా | IKEA | 80.00 | 10 |
4 | మం చం | IKEA | 75.00 | 10 |
5 | క్లోసెట్ | బాష్ | 125.00 | 15 |
6 | షెల్ఫ్ | షెల్ఫ్ | 25.00 | 114 |
7 | టీవీ | LG | 350.00 | 4 |
8 | దీపం | LG | 15.00 | 100 |
9 | డ్రస్సర్ | IKEA | 99.00 | 10 |
10 | ప్లేట్ | బాష్ | 199.00 | 10 |
ఇప్పుడు మేము మొదటి 5 వరుసలను మాత్రమే అభ్యర్థిస్తాము. ఆ అభ్యర్థన ఎలా ఉంటుందో ఇక్కడ ఉంది:
SELECT * FROM product
LIMIT 5
మేము ఈ క్రింది ప్రశ్న ఫలితాన్ని పొందుతాము:
id | పేరు | బ్రాండ్ | ధర | లెక్కించండి |
---|---|---|---|---|
1 | పట్టిక | IKEA | 20.00 | 15 |
2 | కుర్చీ | IKEA | 5.00 | 45 |
3 | సోఫా | IKEA | 80.00 | 10 |
4 | మం చం | IKEA | 75.00 | 10 |
5 | క్లోసెట్ | బాష్ | 125.00 | 15 |
4.2 ఆఫ్సెట్
చివరిసారి మేము సర్వర్ ప్రతిస్పందనలో లైన్ల సంఖ్యను ఎలా పరిమితం చేయాలో నేర్చుకున్నాము. మరియు ఇప్పుడు, ఉత్పత్తి పట్టిక నుండి వేలాది వరుసలకు బదులుగా, మేము మొదటి 10 వరుసలను పొందవచ్చు మరియు వాటిని వినియోగదారుకు ప్రదర్శిస్తాము. ఇది సంపూర్ణంగా ఉంది. కానీ మనం రెండవ 10 వరుసలను ఎలా ప్రదర్శిస్తాము? మరియు మూడవది?
మనం వ్రాస్తే LIMIT 20
, లేదా LIMIT 30
, సర్వర్ వరుసగా 20 మరియు 30 వరుసలను తిరిగి ఇవ్వలేదా?
ఈ సందర్భంలోనే SQL ప్రత్యేక కీవర్డ్ని కలిగి ఉంది, OFFSET
దానితో మీరు దాని ప్రతిస్పందనలో N లైన్లను దాటవేయమని సర్వర్ని అడగవచ్చు. ఈ కీవర్డ్ SQL ప్రశ్న (తర్వాత) చివరిలో ఉపయోగించబడుతుంది LIMIT
మరియు ఇలా కనిపిస్తుంది:
OFFSET quantity
ఉత్పత్తి పట్టికలో ఒక ప్రశ్నను వ్రాసి , 11 నుండి 15 వరకు రికార్డ్లను పొందడానికి ప్రయత్నిద్దాం. మరో మాటలో చెప్పాలంటే, మేము సర్వర్ని మాకు 5 అడ్డు వరుసలను తిరిగి ఇవ్వమని అడుగుతున్నాము, అయితే ప్రతిస్పందనలో మొదటి 10 వరుసలను దాటవేయండి. ఆ అభ్యర్థన ఎలా ఉంటుందో ఇక్కడ ఉంది:
SELECT * FROM product
LIMIT 5
OFFSET 10
మేము ఈ క్రింది ప్రశ్న ఫలితాన్ని పొందుతాము:
id | పేరు | బ్రాండ్ | ధర | లెక్కించండి |
---|---|---|---|---|
పదకొండు | చేతులకుర్చీ | బాష్ | 44.00 | 8 |
12 | పూల కుండి | స్మార్ట్ఫ్లవర్ | 99.00 | 9 |
13 | నిలబడు | IKEA | 100.00 | 10 |
సర్వర్ కేవలం 3 అడ్డు వరుసలను మాత్రమే అందించింది, అంటే మా పట్టికలో మొత్తం 13 వరుసలు ఉన్నాయి. సర్వర్ మొదటి 10ని దాటవేసి, తదుపరి 5ని అందించింది.
4.3 విభిన్నతను ఎంచుకోండి
మరొక ఉపయోగకరమైన కీవర్డ్ DISTINCT
. పట్టికలో డూప్లికేట్ రికార్డులు ఉన్నప్పుడు మరియు మేము నకిలీలను తీసివేయాలనుకున్నప్పుడు ఇది ఉపయోగించబడుతుంది.
మా పట్టికలో నకిలీలు ఎక్కడ నుండి వస్తాయి? పట్టికలో నకిలీలు ఉండకపోవచ్చు, కానీ ప్రశ్న ఫలితంగా, ఇది సులభం. మేము విక్రయించే అన్ని ఉత్పత్తుల బ్రాండ్లను తిరిగి ఇచ్చే ప్రశ్నను వ్రాస్దాం. ఆ అభ్యర్థన ఎలా ఉంటుందో ఇక్కడ ఉంది:
SELECT brand FROM product
మేము ఈ క్రింది ప్రశ్న ఫలితాన్ని పొందుతాము:
బ్రాండ్ |
---|
IKEA |
IKEA |
IKEA |
IKEA |
బాష్ |
బాష్ |
LG |
LG |
IKEA |
బాష్ |
బాష్ |
స్మార్ట్ఫ్లవర్ |
IKEA |
ఈ పట్టికలో డూప్లికేట్ అడ్డు వరుసలు ఉన్నాయని చూడటం సులభం. నకిలీలు లేవని నిర్ధారించుకోవడానికి మరియు మీరు కీవర్డ్ని ఉపయోగించాల్సి ఉంటుంది DISTINCT
. సరిదిద్దబడిన అభ్యర్థన ఎలా ఉంటుందో ఇక్కడ ఉంది:
SELECT DISTINCT brand
FROM product
మేము ఈ క్రింది ప్రశ్న ఫలితాన్ని పొందుతాము:
బ్రాండ్ |
---|
IKEA |
బాష్ |
LG |
స్మార్ట్ఫ్లవర్ |
చాలా బాగుంది. అది కాదా? ;)
4.4 ద్వారా ఆర్డర్
చివరకు మేము క్రమబద్ధీకరణకు వచ్చాము . ప్రశ్న ఫలితాలను క్రమబద్ధీకరించడానికి, మీరు కీవర్డ్ని ఉపయోగించాలి ORDER BY
. సాంకేతికంగా, ఇవి రెండు పదాలు, కానీ సారాంశం ముఖ్యమైనది కాదు. రెండు పదాలు, ఒక ఆపరేటర్.
ఇది తప్పనిసరిగా కీవర్డ్ తర్వాత వ్రాయబడాలి WHERE
, కానీ ముందు LIMIT
మరియు OFFSET
. ORDER BY
మీరు తర్వాత వ్రాస్తే LIMIT
, SQL సర్వర్ మీకు లోపాన్ని అందిస్తుంది.
సాధారణంగా, ఈ ఆపరేటర్ ఇలా కనిపిస్తుంది:
ORDER BY column order
ఇక్కడ నిలువు వరుస అనేది పట్టికలోని నిలువు వరుస పేరు / క్రమబద్ధీకరణ ఫలితం. మరియు ఆర్డర్ అనేది క్రమబద్ధమైన క్రమం.
క్రమబద్ధీకరణ మూడు రకాలుగా ఉంటుంది:
ASC
(ఆరోహణ నుండి) - ఆరోహణ;DESC
(అవరోహణ నుండి) - అవరోహణ;- పేర్కొనబడలేదు - ఉపయోగించబడుతుంది
ASC
ఆరోహణ క్రమంలో ధర ఆధారంగా క్రమబద్ధీకరించబడిన ఉత్పత్తుల జాబితాను తిరిగి ఇచ్చే ప్రశ్నను వ్రాద్దాం. ఆ అభ్యర్థన ఎలా ఉంటుందో ఇక్కడ ఉంది:
SELECT * FROM product
ORDER BY price ASC
LIMIT 10
మేము ఈ క్రింది ప్రశ్న ఫలితాన్ని పొందుతాము:
id | పేరు | బ్రాండ్ | ధర | లెక్కించండి |
---|---|---|---|---|
2 | కుర్చీ | IKEA | 5.00 | 45 |
8 | దీపం | LG | 15.00 | 100 |
1 | పట్టిక | IKEA | 20.00 | 15 |
6 | షెల్ఫ్ | బాష్ | 25.00 | 114 |
పదకొండు | చేతులకుర్చీ | బాష్ | 44.00 | 8 |
4 | మం చం | IKEA | 75.00 | 10 |
3 | సోఫా | IKEA | 80.00 | 10 |
12 | పూల కుండి | స్మార్ట్ఫ్లవర్ | 99.00 | 9 |
9 | డ్రస్సర్ | IKEA | 99.00 | 10 |
13 | నిలబడు | IKEA | 100.00 | 10 |
మేము క్రమబద్ధీకరణ క్రమాన్ని పేర్కొనకపోతే అదే ఫలితాన్ని పొందుతాము - మేము పదాన్ని దాటవేస్తాము ASC
.
4.5 బహుళ నిలువు వరుసల ద్వారా ఆర్డర్ చేయండి
ORDER BY
అనేక నిలువు వరుసల ద్వారా ఫలితాన్ని క్రమబద్ధీకరించడానికి ఆపరేటర్ మిమ్మల్ని అనుమతిస్తుంది. మొదటి నిలువు వరుసలో చాలా నకిలీ అంశాలు ఉన్నప్పుడు ఇది చాలా ఉపయోగకరంగా ఉంటుంది. ఈ ఆపరేటర్ యొక్క సాధారణ రూపం క్రింది విధంగా ఉంది:
ORDER BY column 1 order 1, column 2 order 2, column 3 order 3
మరో మాటలో చెప్పాలంటే, మొదటి నిలువు వరుస ద్వారా క్రమబద్ధీకరించిన తర్వాత మీకు సమీపంలో అనేక సారూప్య విలువలు ఉంటే, అవి రెండవ నిలువు వరుస ద్వారా క్రమబద్ధీకరించబడతాయి మరియు మొదలైనవి.
మన ఉత్పత్తులను బ్రాండ్ వారీగా మరియు అదే బ్రాండ్తో ఉన్న ఉత్పత్తుల కోసం - వాటి సంఖ్య యొక్క అవరోహణ క్రమంలో క్రమబద్ధీకరించే ప్రశ్నను వ్రాద్దాం. ఆ అభ్యర్థన ఎలా ఉంటుందో ఇక్కడ ఉంది:
SELECT * FROM product
ORDER BY brand ASC, count
DESC
మేము ఈ క్రింది ప్రశ్న ఫలితాన్ని పొందుతాము:
id | పేరు | బ్రాండ్ | ధర | లెక్కించండి |
---|---|---|---|---|
6 | షెల్ఫ్ | బాష్ | 25.00 | 114 |
5 | క్లోసెట్ | బాష్ | 125.00 | 15 |
10 | ప్లేట్ | బాష్ | 199.00 | 10 |
పదకొండు | చేతులకుర్చీ | బాష్ | 44.00 | 8 |
2 | కుర్చీ | IKEA | 5.00 | 45 |
1 | పట్టిక | IKEA | 20.00 | 15 |
9 | డ్రస్సర్ | IKEA | 99.00 | 10 |
13 | నిలబడు | IKEA | 100.00 | 10 |
4 | మం చం | IKEA | 75.00 | 10 |
3 | సోఫా | IKEA | 80.00 | 10 |
8 | దీపం | LG | 15.00 | 100 |
7 | టీవీ | LG | 350.00 | 4 |
12 | పూల కుండి | స్మార్ట్ఫ్లవర్ | 99.00 | 9 |
పట్టికను దగ్గరగా చూడండి - దాని అడ్డు వరుసలు బ్రాండ్ పేరు (అక్షరమాల క్రమం) ద్వారా క్రమబద్ధీకరించబడతాయి మరియు అదే బ్రాండ్ పేరుతో ఉన్న అడ్డు వరుసలు అవరోహణ క్రమంలో (చివరి నిలువు వరుస) ఉత్పత్తి సంఖ్య ద్వారా క్రమబద్ధీకరించబడతాయి.
GO TO FULL VERSION