SQLలో డేటా రకాలకు పరిచయం
జావాస్క్రిప్ట్ కాకుండా, SQL బలమైన టైపింగ్ను కలిగి ఉంది. ప్రతి పట్టికలో, ప్రతి నిలువు వరుస దాని స్వంత స్థిర డేటా రకాన్ని కలిగి ఉంటుంది.
చాలా డేటా రకాలు ఉన్నాయి, కానీ జావా లాంగ్వేజ్ వలె కాకుండా, వాటిలో చాలా ఉన్నాయి ఎందుకంటే అన్ని సందర్భాలలో డేటా రకాలు ఉన్నాయి. డేటాబేస్లు డేటా పరిమాణంపై చాలా ఆధారపడి ఉంటాయి, కాబట్టి చాలా డేటా రకాలు ఒకదానికొకటి పొడవులో మాత్రమే విభిన్నంగా ఉంటాయి.
మొత్తంగా, డేటా రకాలను 5 సమూహాలుగా విభజించవచ్చు:
- సంఖ్యా రకాలు
- స్ట్రింగ్ రకాలు
- తేదీలు మరియు సమయాలను నిల్వ చేయడానికి రకాలు
- వస్తువులు: సాధారణంగా బైట్ల సేకరణగా సూచించబడుతుంది
- రవాణా : JSON మరియు XML
సాధారణంగా వివిధ DBMS ఇప్పటికీ వాటి స్వంత డేటా రకాలను కలిగి ఉంటాయి. ప్రతి DBMS దాని స్వంత ప్రత్యేకతను కలిగి ఉంటుంది, కాబట్టి కొత్త డేటా రకాలను జోడించడం చాలా సాధారణ విషయం.
మరొక విషయం ఏమిటంటే, కొత్త డేటా రకాన్ని జోడించడం సరిపోదు, మీరు దానితో పనిచేసే ఫంక్షన్లను జోడించాలి, అలాగే ఈ పనిని సౌకర్యవంతంగా మరియు వేగంగా చేయాలి.
మీరు ఏదైనా పారిశ్రామిక (ఎంటర్ప్రైజ్) DBMSలో పని చేస్తే, మీరు దాని డేటా రకాలు మరియు దాని విధులతో వ్యవహరించాల్సి ఉంటుంది. దాని కోసం 2-5 మంచి పుస్తకాలు చదవడం అవసరం.
SQLతో మా పరిచయంలో భాగంగా, మేము మూడు ప్రధాన డేటా రకాల సమూహాలను పరిశీలిస్తాము:
- సంఖ్యలు
- తీగలు
- తేదీలు
SQLలో సంఖ్యా రకాలు
SQLలో, సంఖ్యా రకాలు మూడు సమూహాలుగా విభజించబడ్డాయి:
- పూర్ణాంకాల రకాలు
- స్థిర బిందువు సంఖ్యలు (దశాంశ స్థానాల స్థిర సంఖ్య)
- ఫ్లోటింగ్ పాయింట్ సంఖ్యలు
పూర్ణాంకాలతో ప్రారంభిద్దాం . వాటిలో 5 మాత్రమే ఉన్నాయి మరియు వాటిని ఒక పట్టికలో వివరించవచ్చు:
# | పేరు టైప్ చేయండి | బైట్లలో పొడవు | జావా నుండి అనలాగ్ | కనీస విలువ | గరిష్ట విలువ |
---|---|---|---|---|---|
1 | TINYINT | 1 | బైట్ | -128 | 127 |
2 | SMALLINT | 2 | చిన్నది | -32.768 | 32.767 |
3 | మీడియం | 3 | -8,388,608 | 8,388,607 | |
4 | INT | 4 | int | -2,147,483,648 | 2,147,483,647 |
5 | పెద్ద | 8 | పొడవు | -2 63 | 2 63-1 |
డేటా రకాలు జావా డేటా రకాలకు చాలా పోలి ఉంటాయి, అయితే మూడు బైట్ల పొడవు ఉండే పూర్ణాంకం రకం కూడా ఉంది. పరిమాణాన్ని ఆదా చేయడానికి ఇది జరుగుతుంది.
జావాలో వలె, ఫ్లోటింగ్ పాయింట్ రకాలు తరువాత వస్తాయి , వాటిలో రెండు మాత్రమే ఉన్నాయి:
# | పేరు టైప్ చేయండి | బైట్లలో పొడవు | జావా నుండి అనలాగ్ | కనీస విలువ | గరిష్ట విలువ |
---|---|---|---|---|---|
1 | ఫ్లోట్ | 4 | తేలుతుంది | -3.40E+38 | +1.18E+38 |
2 | డబుల్ | 8 | రెట్టింపు | -1.79E+308 | +1.79E+308 |
మళ్ళీ, కొత్త ఏమీ లేదు. అన్నీ జావాలో లాగానే ఉంటాయి. అయినప్పటికీ, జావా వలె కాకుండా, SQL మరొక ప్రత్యేక రకాన్ని కలిగి ఉంది, స్థిర-పాయింట్ వాస్తవ సంఖ్య. దీనిని డెసిమల్ అంటారు.
సాధారణంగా ఈ రకం డబ్బును నిల్వ చేయడానికి ఉపయోగించబడుతుంది. ఈ రకం పేరు వ్రాయబడినప్పుడు, దాని తర్వాత సాధారణంగా దశాంశ బిందువుకు ముందు మరియు తరువాత సంఖ్య ఎన్ని దశాంశ స్థానాలు కలిగి ఉందో సూచించబడుతుంది. సాధారణ ఆకృతి ఇలా కనిపిస్తుంది:
DECIMAL(total_characters, after_comma)
మరియు ఒక చిన్న ఉదాహరణ:
salary DECIMAL(5,2)
జీతం కాలమ్లో పూర్ణాంకాలు (గరిష్టంగా 3 దశాంశ స్థానాలు) మరియు పాక్షిక భాగం - 2 దశాంశ స్థానాలు ఉండవచ్చనే వాస్తవాన్ని మేము ఈ విధంగా వివరించాము.
DECIMAL రకం మద్దతిచ్చే అక్షరాల గరిష్ట సంఖ్య 65.
SQLలో స్ట్రింగ్ రకాలు
డేటాబేస్లోని అడ్డు వరుసలు రెండు రూపాల్లో నిల్వ చేయబడతాయి:
- స్థిర పొడవు తీగలు
- వేరియబుల్ పొడవుతో స్ట్రింగ్స్
స్థిర-పొడవు స్ట్రింగ్లు CHAR గా పేర్కొనబడ్డాయి :
CHAR(length)
స్థిర పొడవు అంటే ఈ నిలువు వరుస యొక్క అన్ని విలువలు ఖచ్చితంగా నిర్ణీత సంఖ్యలో అక్షరాలను కలిగి ఉంటాయి.
స్థిర పొడవు స్ట్రింగ్ యొక్క ఉదాహరణ:
country_code CHAR(2)
వేరియబుల్ పొడవు స్ట్రింగ్లు VARCHAR రకం ద్వారా పేర్కొనబడ్డాయి :
VARCHAR(max_length)
వేరియబుల్ పొడవు అంటే ఈ నిలువు వరుస యొక్క అన్ని విలువలు ఏదైనా పొడవు యొక్క వచనాన్ని కలిగి ఉంటాయి, కానీ గరిష్ట పొడవు కంటే ఎక్కువ ఉండవు.
వేరియబుల్ పొడవు స్ట్రింగ్ ఉదాహరణ:
phone VARCHAR(12)
స్థిర పొడవు తీగలు చాలా పెద్ద ప్రయోజనాన్ని కలిగి ఉంటాయి. క్లయింట్ SQL సర్వర్ను టేబుల్ నుండి 1,000,000వ వరుసను తిరిగి ఇవ్వమని అడిగితే, మరియు పట్టికలోని అడ్డు వరుసలు స్థిర పొడవుతో ఉంటే, అప్పుడు, అడ్డు వరుస యొక్క పొడవును తెలుసుకొని, మీరు కోరుకున్న వాటికి సంబంధించిన బైట్లను సులభంగా లెక్కించవచ్చు. వరుస.
పంక్తుల వేరియబుల్ పొడవు విషయంలో, పట్టికలో కావలసిన అడ్డు వరుసను త్వరగా కనుగొనడం సాధ్యం కాదు. అర్రేలిస్ట్ మరియు లింక్డ్లిస్ట్లకు యాక్సెస్ వేగాన్ని గుర్తుంచుకోండి, ఇక్కడ పరిస్థితి దాదాపుగా అదే విధంగా ఉంటుంది.
డేటా రకాన్ని బట్టి వివిధ పొడవులు గల స్ట్రింగ్లను పట్టికలో ఎలా నిల్వ చేస్తారో పోల్చి చూద్దాం.
లైన్ | చార్(4) | నిల్వ చేయడానికి బైట్ | వర్చర్(4) | నిల్వ చేయడానికి బైట్ | |
---|---|---|---|---|---|
'' | '' | 4 | '' | 1 | |
'ab' | 'ab' | 4 | 'ab' | 3 | |
'ఎ బి సి డి' | 'ఎ బి సి డి' | 4 | 'ఎ బి సి డి' | 5 | |
'abcdefgh' | 'ఎ బి సి డి' | 4 | 'ఎ బి సి డి' | 5 |
గమనిక. VARCHAR రకానికి అదే పొడవు కోసం మరో బైట్ అవసరం, ఎందుకంటే ఇది స్ట్రింగ్ పొడవును అదనంగా నిల్వ చేయాలి.
SQLలో తాత్కాలిక రకాలు
SQL తేదీలు మరియు సమయాలను నిల్వ చేయడానికి ప్రత్యేక రకాలను కూడా కలిగి ఉంది. మొత్తం ఐదు రకాలు ఉన్నాయి:
# | పేరు టైప్ చేయండి | Java DateTime API నుండి అనలాగ్ | ఉదాహరణ | కనీస విలువ | గరిష్ట విలువ |
---|---|---|---|---|---|
1 | DATE | స్థానిక తేదీ | '2022-06-30' | '1000-01-01' | '9999-12-31' |
2 | TIME | స్థానిక సమయం | 'hh:mm:ss[.fraction]' | '-838:59:59.000000' | '838:59:59.000000' |
3 | DATETIME | స్థానిక తేదీ సమయం | '1000-01-01 00:00:00.000000' | '9999-12-31 23:59:59.999999' | |
4 | టైమ్స్టాంప్ | తేదీ | '1970-01-01 00:00:01.000000' | '2038-01-19 03:14:07.999999' | |
5 | సంవత్సరం | 1901 | 2155 |
ప్రశ్నలలోని మొత్తం డేటా స్ట్రింగ్గా వ్రాయబడింది - ఒకే కోట్లలో. ఎంట్రీ ఫార్మాట్ పెద్దది నుండి చిన్నదానికి వెళుతుంది:
- సంవత్సరం
- నెల
- రోజు
- గంట
- నిమిషం
- రెండవ
- సెకను యొక్క భిన్నాలు
DATE, TIME మరియు DATETIME రకాలను జావా DateTme API నుండి సాంప్రదాయకంగా రకాల అనలాగ్లుగా పరిగణించవచ్చు: LocalDate, LocalTime, LocalDateTime. లాజిక్ కూడా అదే.
TIMESTAMP రకం 1970 ప్రారంభం నుండి మిల్లీసెకన్లలో డేటాను నిల్వ చేస్తుంది (UNIX ఆపరేటింగ్ సిస్టమ్ ప్రమాణం). ఈ రూపంలోనే అవి జావా భాషలో తేదీ రకం ద్వారా నిల్వ చేయబడతాయి.
చివరగా, YEAR రకం ఉంది, ఇది 1 బైట్ పొడవు మరియు 1 నుండి 255 వరకు విలువలను నిల్వ చేస్తుంది. కాబట్టి, దీనికి అందుబాటులో ఉన్న సంవత్సరాల పరిధి 1901-2155. NULL విలువను ఎన్కోడ్ చేయడానికి 0 విలువ ఉపయోగించబడుతుంది కాబట్టి 1900 సంవత్సరం ఈ రకం ద్వారా నిల్వ చేయబడదు.
SQLలో వస్తువులను నిల్వ చేయడం
గొప్ప పొడవు గల వస్తువులు లేదా గ్రంథాలను నిల్వ చేయడానికి ప్రత్యేక రకాలు ఉన్నాయి. మేము వాటి గురించి వివరంగా చెప్పము, కానీ నేను వాటిని ఏమైనప్పటికీ జాబితా చేస్తాను:
# | పేరు టైప్ చేయండి | వివరణ |
---|---|---|
1 | TEXT | పొడవైన పాఠాలను నిల్వ చేయడానికి ఉపయోగిస్తారు. ఈ ఫీల్డ్లో పోల్చి, క్రమబద్ధీకరించేటప్పుడు, మొదటి 100 అక్షరాలు మాత్రమే ఉపయోగించబడతాయి. |
2 | BLOB | పేరు బైట్ లార్జ్ ఆబ్జెక్ట్. కేవలం బైట్ల సేకరణగా నిల్వ చేయబడింది. ఉదాహరణకు, డేటాబేస్లో చిత్రాలను నిల్వ చేయడానికి ఉపయోగించవచ్చు. |
3 | CLOB | పేరు చార్ లార్జ్ ఆబ్జెక్ట్. పొడవైన పాఠాలను నిల్వ చేయడానికి ఉపయోగిస్తారు. |
4 | ENUM | స్థిరమైన విలువలను సెట్ చేయడానికి మరియు వాటిలో ఒకదాన్ని విలువగా నిల్వ చేయడానికి మిమ్మల్ని అనుమతిస్తుంది. |
5 | సెట్ | స్థిరమైన విలువలను సెట్ చేయడానికి మరియు వాటిలో ఏదైనా ఉపసమితిని విలువగా నిల్వ చేయడానికి మిమ్మల్ని అనుమతిస్తుంది. సాధారణంగా వాటిని బైనరీ మాస్క్గా నిల్వ చేస్తుంది. |
సిద్ధాంతపరంగా, మీరు ఏదైనా జావా ఆబ్జెక్ట్ని బైట్ల సెట్గా సీరియలైజ్ చేయవచ్చు మరియు దానిని డేటాబేస్లో BLOBగా నిల్వ చేయవచ్చు. వస్తువును సేవ్ చేయడం సమస్య కాదు. మరి అతనితో ఎలా పని చేయాలి?
ఒక టేబుల్ మిలియన్ వస్తువులను సీరియల్ రూపంలో నిల్వ చేస్తుందనుకుందాం - మీరు వాటిని ఎలా శోధిస్తారు? DBMS దానితో పని చేయడానికి విస్తృతమైన ఫంక్షన్లను అందించినప్పుడు మాత్రమే నిర్దిష్ట రకం డేటాకు మద్దతు ఇస్తుంది.
GO TO FULL VERSION