SELECT
வினவல்களில் தேவையான புலங்களைக் குறிப்பிடவும்
வினவலில் உள்ள அனைத்து புலங்களையும் தேர்ந்தெடுப்பதற்குப் பதிலாக SELECT
, சுமைகளைக் குறைக்கவும் வினவல் வேகத்தை மேம்படுத்தவும் தேவையான புலங்களை மட்டும் தேர்வு செய்யவும்.
எடுத்துக்காட்டாக, நீங்கள் வாடிக்கையாளரின் பெயர் மற்றும் முகவரியைப் பற்றி மட்டுமே அக்கறை கொண்டிருந்தால், வினவலை மாற்றவும்:
உடன்
குறியீடுகளை உருவாக்கவும்
Index
MySQL
விரைவாகத் தேடவும் தரவை மீட்டெடுக்கவும் உதவும். WHERE
, JOIN
அல்லது உட்பிரிவுகளில் அடிக்கடி பயன்படுத்தப்படும் புலங்களைக் கண்டறிந்து ORDER BY
அவற்றுக்கான குறியீடுகளை உருவாக்கவும்.
எடுத்துக்காட்டாக, " orders
" அட்டவணையில், " customer_id
" புலம் அடிக்கடி பயன்படுத்தப்பட்டால் WHERE
அல்லது JOIN
வினவினால், நீங்கள் பின்வருமாறு ஒரு குறியீட்டை உருவாக்கலாம்:
பொருத்தமான வகை குறியீடுகளைப் பயன்படுத்தவும்
MySQL
B-tree
, ஹாஷ் மற்றும் போன்ற பல்வேறு வகையான குறியீடுகளை வழங்குகிறது full-text
. உகந்த செயல்திறனை உறுதிப்படுத்த, உங்கள் வினவல் தேவைகளின் அடிப்படையில் பொருத்தமான வகை குறியீட்டைத் தேர்வு செய்யவும்.
எடுத்துக்காட்டாக, நீங்கள் ஒரு தரவுப் புலத்தில் உரையைத் தேட வேண்டும் என்றால், நீங்கள் full-text
பின்வருமாறு ஒரு குறியீட்டை உருவாக்கலாம்:
வினவல்களை மேம்படுத்தவும்
EXPLAIN
வினவல் செயலாக்கத் திட்டத்தைப் பார்க்கவும், அது எவ்வாறு செயல்படுகிறது என்பதைப் பகுப்பாய்வு செய்யவும் பயன்படுத்தவும் MySQL
. இது செயல்திறன் சிக்கல்களைக் கண்டறியவும் குறியீடுகளைப் பயன்படுத்தி அல்லது வினவல்களை மீண்டும் எழுதுவதன் மூலம் வினவல்களை மேம்படுத்தவும் உதவுகிறது.
எடுத்துக்காட்டாக, வினவலின் வினவல் திட்டத்தைப் பார்க்க SELECT
, பின்வரும் கட்டளையை இயக்கவும்:
திரும்பிய முடிவுகளின் எண்ணிக்கையை வரம்பிடவும்
ஒரு வினவல் அதிக எண்ணிக்கையிலான முடிவுகளை வழங்கும் போது, உட்பிரிவைப் பயன்படுத்தி வழங்கப்பட்ட முடிவுகளின் எண்ணிக்கையை வரம்பிடவும் LIMIT
. இது சுமைகளைக் குறைக்கவும் வினவல் வேகத்தை மேம்படுத்தவும் உதவுகிறது.
எடுத்துக்காட்டாக, "தயாரிப்புகள்" அட்டவணையில் இருந்து 10 முடிவுகளை மட்டுமே வழங்க, நீங்கள் பின்வரும் வினவலைப் பயன்படுத்தலாம்:
INNER JOIN
பதிலாக பயன்படுத்தவும் JOIN
INNER JOIN
வழக்கமானதை விட சிறப்பாக செயல்படுகிறது JOIN
. INNER JOIN
இரண்டு அட்டவணைகளிலும் பொருந்தக்கூடிய பதிவுகளை மட்டுமே நீங்கள் கவனிக்கும்போது பயன்படுத்தவும் .
எடுத்துக்காட்டாக, " " புலத்தின் அடிப்படையில் " orders
" மற்றும் " " அட்டவணையில் சேர, நீங்கள் பின்வரும் வினவலைப் பயன்படுத்தலாம்: customers
customer_id
தற்காலிக அட்டவணைகளை எச்சரிக்கையுடன் பயன்படுத்தவும்
தற்காலிக அட்டவணைகள் சில சந்தர்ப்பங்களில் பயன்படுத்தப்படலாம், ஆனால் அவை வினவல்களை மெதுவாக்கும் என்பதால் அவை கவனமாகப் பயன்படுத்தப்பட வேண்டும். முடிந்தால் தற்காலிக அட்டவணைகளைப் பயன்படுத்துவதைத் தவிர்ப்பதற்கு வினவல்களை மேம்படுத்துவதைக் கவனியுங்கள்.
எடுத்துக்காட்டாக, பின்வரும் வினவலில் தற்காலிக அட்டவணையைப் பயன்படுத்துவதற்குப் பதிலாக:
அசல் அட்டவணையில் இருந்து தரவை நேரடியாக வினவ, வினவலை மேம்படுத்த முயற்சி செய்யலாம்.
ஃபைன்-டியூன் MySQL உள்ளமைவு
கணினி வளங்களைப் பயன்படுத்தவும், உங்கள் பயன்பாட்டின் தேவைகளுக்கு ஏற்பவும் MySQL ஐ மறுகட்டமைப்பதைக் கவனியுங்கள். நினைவகம், இடையக அளவுகள், இணைப்பு வரம்புகள் மற்றும் பிற அளவுருக்களை உள்ளமைப்பது இதில் அடங்கும். MySQL ஆவணங்களைப் பார்க்கவும் மற்றும் உங்கள் குறிப்பிட்ட சூழலுக்கு ஏற்றவாறு உள்ளமைவை எவ்வாறு சரிசெய்வது என்பதை அறியவும்.
தேவையற்ற தரவுகளை நீக்கவும்
தரவுத்தள அளவைக் குறைக்கவும் வினவல் வேகத்தை மேம்படுத்தவும் தேவையற்ற தரவை நீக்கவும் அல்லது பழைய தரவை காப்புப் பிரதி எடுக்கவும்.
எடுத்துக்காட்டாக, உங்களிடம் logs
பழைய பதிவு பதிவுகளை சேமிக்கும் அட்டவணை இருந்தால், பின்வரும் வினவலைப் பயன்படுத்தி ஒரு வருடத்திற்கும் முந்தைய பதிவுகளை நீக்கலாம்:
நினைவகத்தைப் பயன்படுத்தவும் cache
cache
அடிக்கடி செயல்படுத்தப்படும் வினவல்கள் மற்றும் சமீபத்தில் அணுகப்பட்ட தரவைச் சேமிக்க MySQL இன் நினைவகத்தை உள்ளமைக்கவும். இது வட்டு அணுகல் நேரத்தை குறைக்கவும் வினவல் வேகத்தை மேம்படுத்தவும் உதவுகிறது.
எடுத்துக்காட்டாக, 1GB அளவுடன் நினைவகத் தற்காலிக சேமிப்பை உள்ளமைக்க, நீங்கள் MySQL இன் "my.cnf" உள்ளமைவு கோப்பை பின்வருமாறு மாற்றலாம்:
மேலே உள்ள எடுத்துக்காட்டுகள் விளக்கமானவை மற்றும் உங்கள் உண்மையான தரவுத்தளத்தின் கட்டமைப்பு மற்றும் தேவைகளுக்கு ஏற்ப சரிசெய்யப்பட வேண்டும் என்பதை நினைவில் கொள்ளவும். இந்த தேர்வுமுறை நுட்பங்களைப் பயன்படுத்துவதற்கு முன்னும் பின்னும், அவை உங்கள் குறிப்பிட்ட சூழலுக்கு ஏற்றவை என்பதை உறுதிசெய்ய, செயல்திறனை கவனமாகச் சோதித்து மதிப்பீடு செய்யவும்.