SQL സെർവറിൽ SELECT ഉപയോഗിച്ച് ഒരു ടേബിൾ അപ്ഡേറ്റ് ചെയ്യുന്നു
SQL സെർവറിൽ, ഒരു INSERT.. SELECT സ്റ്റേറ്റ്മെൻ്റ് ഉപയോഗിച്ച് ഒരു പട്ടികയിലേക്ക് വരികൾ ചേർക്കുന്നത് സാധാരണമാണ്. ഉദാഹരണത്തിന്, നിങ്ങൾക്ക് ഇനിപ്പറയുന്ന കമാൻഡ് ഉപയോഗിച്ച് ഒരു പട്ടികയിലേക്ക് ഡാറ്റ ചേർക്കാൻ കഴിയും: പട്ടികയിലേക്ക് തിരുകുക(col1, col2, col3) മറ്റ്_ടേബിളിൽ നിന്ന് col1, col2, col3 തിരഞ്ഞെടുക്കുക ഇവിടെ sql='cool'.
എന്നാൽ ഒരു SELECT സ്റ്റേറ്റ്മെൻ്റ് ഉപയോഗിച്ച് ഒരു ടേബിൾ അപ്ഡേറ്റ് ചെയ്യുന്നതിനെക്കുറിച്ച്? നിങ്ങൾക്ക് മൂല്യങ്ങളുള്ള ഒരു താൽക്കാലിക പട്ടിക ഉണ്ടെങ്കിൽ, ഈ മൂല്യങ്ങളുള്ള മറ്റൊരു പട്ടിക അപ്ഡേറ്റ് ചെയ്യണമെങ്കിൽ, അത് സാധ്യമാണോ? ഇത് എങ്ങനെ നേടാമെന്ന് ഈ ലേഖനം പര്യവേക്ഷണം ചെയ്യുന്നു, പ്രക്രിയ മനസ്സിലാക്കാൻ നിങ്ങളെ സഹായിക്കുന്നതിന് വ്യക്തമായ ഉദാഹരണങ്ങളും വിശദീകരണങ്ങളും നൽകുന്നു.
കമാൻഡ് | വിവരണം |
---|---|
UPDATE | ഒരു പട്ടികയിൽ നിലവിലുള്ള റെക്കോർഡുകൾ പരിഷ്കരിക്കാൻ ഉപയോഗിക്കുന്നു. |
SET | അപ്ഡേറ്റിനായി നിരകളും അവയുടെ പുതിയ മൂല്യങ്ങളും വ്യക്തമാക്കുന്നു. |
FROM | അപ്ഡേറ്റിനായി ഉപയോഗിക്കേണ്ട ഉറവിട പട്ടിക വ്യക്തമാക്കുന്നു. |
WHERE | അപ്ഡേറ്റ് ചെയ്യുന്നതിനായി വരികൾ തിരഞ്ഞെടുക്കുന്നതിനുള്ള വ്യവസ്ഥ നിർവചിക്കുന്നു. |
INSERT INTO | ഒരു പട്ടികയിലേക്ക് പുതിയ വരികൾ ചേർക്കാൻ ഉപയോഗിക്കുന്നു. |
SELECT | ഒന്നോ അതിലധികമോ പട്ടികകളിൽ നിന്ന് ഡാറ്റ വീണ്ടെടുക്കുന്നു. |
SQL സെർവറിൽ ഒരു SELECT സ്റ്റേറ്റ്മെൻ്റ് ഉപയോഗിച്ച് എങ്ങനെ അപ്ഡേറ്റ് ചെയ്യാം എന്ന് മനസ്സിലാക്കുന്നു
മുകളിൽ നൽകിയിരിക്കുന്ന സ്ക്രിപ്റ്റുകൾ, SQL സെർവറിലെ മറ്റൊരു ടേബിളിൽ നിന്നുള്ള മൂല്യങ്ങൾ ഉപയോഗിച്ച് ഒരു പട്ടിക എങ്ങനെ അപ്ഡേറ്റ് ചെയ്യാമെന്ന് കാണിക്കുന്നു. ഉപയോഗിച്ച പ്രാഥമിക കമാൻഡ് ആണ് UPDATE, ഒരു പട്ടികയിൽ നിലവിലുള്ള രേഖകൾ പരിഷ്കരിക്കുന്നതിന് അത്യന്താപേക്ഷിതമാണ്. ദി SET ഏത് നിരകളാണ് അപ്ഡേറ്റ് ചെയ്യേണ്ടതെന്നും അവയുടെ പുതിയ മൂല്യങ്ങളും ക്ലോസ് വ്യക്തമാക്കുന്നു. ഇതിനെ തുടർന്നാണ് FROM ക്ലോസ്, ഇത് മറ്റൊരു ടേബിളിനെ പരാമർശിക്കാൻ അപ്ഡേറ്റിനെ അനുവദിക്കുന്നു, ഇത് എ യുടെ ഉപയോഗം ഫലപ്രദമായി പ്രാപ്തമാക്കുന്നു SELECT പുതിയ മൂല്യങ്ങൾ ലഭ്യമാക്കുന്നതിനുള്ള പ്രസ്താവന. ദി WHERE പട്ടികകൾക്കിടയിലുള്ള വരികളുമായി പൊരുത്തപ്പെടുന്ന അവസ്ഥയെ നിർവചിക്കുന്നതിനാൽ ക്ലോസ് നിർണായകമാണ്. ഈ ക്ലോസ് ഇല്ലെങ്കിൽ, അപ്ഡേറ്റ് എല്ലാ വരികൾക്കും ബാധകമാകും, ഇത് സാധാരണയായി ആവശ്യമുള്ള സ്വഭാവമല്ല.
ഉദാഹരണത്തിന്, കമാൻഡ് പരിഗണിക്കുക UPDATE target_table SET target_table.col1 = source_table.col1, target_table.col2 = source_table.col2 FROM source_table WHERE target_table.id = source_table.id. ഈ കമാൻഡ് അപ്ഡേറ്റ് ചെയ്യുന്നു col1 ഒപ്പം col2 ലെ നിരകൾ target_table എന്നതിൽ നിന്നുള്ള മൂല്യങ്ങൾക്കൊപ്പം source_table എവിടെ id മത്സരങ്ങൾ. മെയിൻ ടേബിൾ അപ്ഡേറ്റ് ചെയ്യാൻ നിങ്ങൾ ഉപയോഗിക്കാൻ ആഗ്രഹിക്കുന്ന പുതിയ മൂല്യങ്ങൾ ഉൾക്കൊള്ളുന്ന ഒരു സ്റ്റേജിംഗ് ടേബിളോ താൽക്കാലിക ടേബിളോ ഉള്ളപ്പോൾ ഈ സമീപനം പ്രത്യേകിച്ചും ഉപയോഗപ്രദമാണ്. ഉദ്ദേശിച്ച വരികൾ മാത്രമേ അപ്ഡേറ്റ് ചെയ്യപ്പെടുന്നുള്ളൂ എന്ന് ഈ രീതി ഉറപ്പാക്കുന്നു, കൂടാതെ ഒരു SQL പ്രസ്താവനയ്ക്കുള്ളിൽ സങ്കീർണ്ണമായ പരിവർത്തനങ്ങളും ഡാറ്റാ മൈഗ്രേഷനുകളും കാര്യക്ഷമമായി കൈകാര്യം ചെയ്യാൻ ഇത് അനുവദിക്കുന്നു.
മറ്റൊരു ടേബിളിൽ നിന്നുള്ള മൂല്യങ്ങൾ ഉപയോഗിച്ച് ഒരു SQL സെർവർ ടേബിൾ അപ്ഡേറ്റ് ചെയ്യുന്നു
SQL സെർവർ T-SQL സ്ക്രിപ്റ്റ്
-- Assume you have two tables: target_table and source_table
-- target_table has columns id, col1, col2
-- source_table has columns id, col1, col2
-- Example data in source_table
-- INSERT INTO source_table (id, col1, col2) VALUES (1, 'value1', 'value2')
-- Update target_table using values from source_table
UPDATE target_table
SET target_table.col1 = source_table.col1,
target_table.col2 = source_table.col2
FROM source_table
WHERE target_table.id = source_table.id;
Mise à jour des données dans une table à l'aide d'une നിർദ്ദേശം SELECT
SQL സെർവർ T-SQL സ്ക്രിപ്റ്റ്
-- Suppose you have two tables: main_table and temp_table
-- main_table has columns id, column1, column2
-- temp_table has columns id, column1, column2
-- Example data in temp_table
-- INSERT INTO temp_table (id, column1, column2) VALUES (2, 'data1', 'data2')
-- Perform update on main_table using data from temp_table
UPDATE main_table
SET main_table.column1 = temp_table.column1,
main_table.column2 = temp_table.column2
FROM temp_table
WHERE main_table.id = temp_table.id;
Utiliser une നിർദ്ദേശം SELECT പകരും metre à jour une autre table
SQL സെർവർ T-SQL സ്ക്രിപ്റ്റ്
-- Define the structure of two tables: target_table and staging_table
-- target_table columns: id, field1, field2
-- staging_table columns: id, field1, field2
-- Sample data in staging_table
-- INSERT INTO staging_table (id, field1, field2) VALUES (3, 'info1', 'info2')
-- Execute update on target_table based on staging_table
UPDATE target_table
SET target_table.field1 = staging_table.field1,
target_table.field2 = staging_table.field2
FROM staging_table
WHERE target_table.id = staging_table.id;
SQL സെർവറിൽ SELECT ഉപയോഗിച്ച് അപ്ഡേറ്റ് ചെയ്യുന്നതിനുള്ള വിപുലമായ സാങ്കേതിക വിദ്യകൾ
SQL സെർവറുമായി പ്രവർത്തിക്കുമ്പോൾ ഉപയോഗപ്രദമായ മറ്റൊരു സാങ്കേതികതയാണ് MERGE പ്രസ്താവന. ഒരൊറ്റ പ്രസ്താവനയിൽ പ്രവർത്തനങ്ങൾ തിരുകാനും അപ്ഡേറ്റ് ചെയ്യാനും ഇല്ലാതാക്കാനും ഈ പ്രസ്താവന നിങ്ങളെ അനുവദിക്കുന്നു. ദി MERGE നിങ്ങൾക്ക് രണ്ട് പട്ടികകൾ സമന്വയിപ്പിക്കേണ്ടിവരുമ്പോൾ പ്രസ്താവന പ്രത്യേകിച്ചും സഹായകരമാണ്. ഒരു സോഴ്സ് ടേബിളും ടാർഗെറ്റ് ടേബിളും വ്യക്തമാക്കാൻ ഇത് നിങ്ങളെ അനുവദിക്കുന്നു, തുടർന്ന് ഒരു പൊരുത്തം കണ്ടെത്തിയോ എന്നതിനെ അടിസ്ഥാനമാക്കി സ്വീകരിക്കേണ്ട പ്രവർത്തനങ്ങൾ നിർവ്വചിക്കുന്നു.
ഉദാഹരണത്തിന്, നിങ്ങൾക്ക് ഉപയോഗിക്കാം MERGE ഐഡികൾ പൊരുത്തപ്പെടുന്ന ഒരു സോഴ്സ് ടേബിളിൽ നിന്ന് മൂല്യങ്ങളുള്ള ഒരു ടാർഗെറ്റ് ടേബിൾ അപ്ഡേറ്റ് ചെയ്യുന്നതിന്, പൊരുത്തമൊന്നും കണ്ടെത്തിയില്ലെങ്കിൽ പുതിയ വരികൾ ചേർക്കുക, കൂടാതെ ഉറവിട പട്ടികയിൽ അനുബന്ധ വരികളില്ലാത്ത ടാർഗെറ്റ് ടേബിളിലെ വരികൾ ഇല്ലാതാക്കുക. ഡാറ്റാ സിൻക്രൊണൈസേഷൻ കൈകാര്യം ചെയ്യുന്നതിനുള്ള ശക്തവും വഴക്കമുള്ളതുമായ മാർഗം ഇത് പ്രദാനം ചെയ്യുന്നു, കൂടാതെ പ്രസക്തമായ എല്ലാ മാറ്റങ്ങളും ഒരൊറ്റ, ആറ്റോമിക് പ്രവർത്തനത്തിൽ വരുത്തുന്നുവെന്ന് ഉറപ്പാക്കുന്നു. എങ്ങനെ ഫലപ്രദമായി ഉപയോഗിക്കാമെന്ന് മനസിലാക്കുന്നു MERGE SQL സെർവറിൽ ഡാറ്റ കൈകാര്യം ചെയ്യുന്നതിനും കൈകാര്യം ചെയ്യുന്നതിനുമുള്ള നിങ്ങളുടെ കഴിവ് വളരെയധികം വർദ്ധിപ്പിക്കാൻ കഴിയും.
SQL സെർവറിൽ SELECT ഉപയോഗിച്ച് അപ്ഡേറ്റ് ചെയ്യുന്നതിനെക്കുറിച്ചുള്ള പൊതുവായ ചോദ്യങ്ങളും ഉത്തരങ്ങളും
- ഒരു SELECT സ്റ്റേറ്റ്മെൻ്റ് ഉപയോഗിച്ച് എനിക്ക് എങ്ങനെ ഒന്നിലധികം കോളങ്ങൾ അപ്ഡേറ്റ് ചെയ്യാം?
- എന്നതിലെ ഓരോ നിരയും വ്യക്തമാക്കി നിങ്ങൾക്ക് ഒന്നിലധികം കോളങ്ങൾ അപ്ഡേറ്റ് ചെയ്യാം SET ക്ലോസ്, പോലെ UPDATE target_table SET col1 = source_table.col1, col2 = source_table.col2 FROM source_table WHERE target_table.id = source_table.id.
- JOIN വ്യവസ്ഥയെ അടിസ്ഥാനമാക്കി ഒരു പട്ടിക അപ്ഡേറ്റ് ചെയ്യാൻ കഴിയുമോ?
- അതെ, നിങ്ങൾക്ക് ഇതിൽ ഒരു ജോയിൻ ഉപയോഗിക്കാം FROM മറ്റൊരു ടേബിളിൽ നിന്നുള്ള വ്യവസ്ഥകളെ അടിസ്ഥാനമാക്കി ഒരു പട്ടിക അപ്ഡേറ്റ് ചെയ്യുന്നതിനുള്ള ക്ലോസ്.
- അപ്ഡേറ്റ് പ്രസ്താവനയിൽ എനിക്ക് സബ്ക്വറികൾ ഉപയോഗിക്കാമോ?
- അതെ, എന്നതിൽ സബ്ക്വറികൾ ഉപയോഗിക്കാം SET മറ്റ് പട്ടികകളിൽ നിന്നോ കണക്കുകൂട്ടലുകളിൽ നിന്നോ മൂല്യങ്ങൾ നേടുന്നതിനുള്ള ഉപവാക്യം.
- ഒരു ലളിതമായ അപ്ഡേറ്റിലൂടെ MERGE ഉപയോഗിക്കുന്നതിൻ്റെ പ്രയോജനം എന്താണ്?
- ദി MERGE ഒരു പ്രസ്താവനയിൽ ഒന്നിലധികം പ്രവർത്തനങ്ങൾ (ഇൻസേർട്ട്, അപ്ഡേറ്റ്, ഡിലീറ്റ്) നടത്താൻ സ്റ്റേറ്റ്മെൻ്റ് അനുവദിക്കുന്നു, ഇത് സങ്കീർണ്ണമായ പ്രവർത്തനങ്ങൾക്ക് കൂടുതൽ കാര്യക്ഷമമാക്കുന്നു.
- SELECT ഉപയോഗിച്ച് അപ്ഡേറ്റ് ചെയ്യുമ്പോൾ മൂല്യങ്ങൾ എങ്ങനെ കൈകാര്യം ചെയ്യാം?
- പോലുള്ള പ്രവർത്തനങ്ങൾ നിങ്ങൾക്ക് ഉപയോഗിക്കാം IS അഥവാ COALESCE അപ്ഡേറ്റ് സമയത്ത് മൂല്യങ്ങൾ കൈകാര്യം ചെയ്യാൻ.
- ഒരു താൽക്കാലിക ടേബിളിൽ നിന്നുള്ള ഡാറ്റ ഉപയോഗിച്ച് എനിക്ക് ഒരു പട്ടിക അപ്ഡേറ്റ് ചെയ്യാൻ കഴിയുമോ?
- അതെ, ഒരു സാധാരണ പട്ടിക ഉപയോഗിച്ച് അപ്ഡേറ്റ് ചെയ്യുന്ന അതേ വാക്യഘടന ഉപയോഗിച്ച് നിങ്ങൾക്ക് ഒരു താൽക്കാലിക പട്ടികയിൽ നിന്നുള്ള ഡാറ്റ ഉപയോഗിച്ച് ഒരു പട്ടിക അപ്ഡേറ്റ് ചെയ്യാൻ കഴിയും.
- ഒരു അപ്ഡേറ്റ് പ്രസ്താവനയിലൂടെ വരുത്തിയ മാറ്റങ്ങൾ ട്രാക്ക് ചെയ്യാൻ കഴിയുമോ?
- അപ്ഡേറ്റ് സ്റ്റേറ്റ്മെൻ്റുകൾ വഴി വരുത്തിയ മാറ്റങ്ങൾ ട്രാക്കുചെയ്യുന്നതിന് ട്രിഗറുകൾ, ഡാറ്റ ക്യാപ്ചർ മാറ്റുക തുടങ്ങിയ സവിശേഷതകൾ SQL സെർവർ നൽകുന്നു.
- വലിയ അപ്ഡേറ്റുകൾ നടത്തുമ്പോൾ ഞാൻ എന്ത് മുൻകരുതലുകൾ എടുക്കണം?
- ഇടപാടുകൾ ഉപയോഗിക്കുന്നതും നിങ്ങളുടെ ഡാറ്റ ബാക്കപ്പ് ചെയ്യുന്നതും ആദ്യം ഒരു ചെറിയ ഡാറ്റാസെറ്റിൽ നിങ്ങളുടെ അപ്ഡേറ്റ് സ്റ്റേറ്റ്മെൻ്റ് പരിശോധിക്കുന്നതും പരിഗണിക്കുക.
- ഒരു അപ്ഡേറ്റ് പ്രസ്താവനയ്ക്കൊപ്പം എനിക്ക് OUTPUT ക്ലോസ് ഉപയോഗിക്കാനാകുമോ?
- അതെ, ദി OUTPUT അപ്ഡേറ്റ് ബാധിച്ച ഓരോ വരിയെയും കുറിച്ചുള്ള വിവരങ്ങൾ നൽകാൻ ക്ലോസ് ഉപയോഗിക്കാം.
SQL സെർവറിൽ SELECT ഉപയോഗിച്ച് അപ്ഡേറ്റ് ചെയ്യുന്ന പ്രക്രിയ സംഗ്രഹിക്കുന്നു
SQL സെർവറിൽ, മറ്റൊരു ടേബിളിൽ നിന്ന് മൂല്യങ്ങളുള്ള ഒരു പട്ടിക അപ്ഡേറ്റ് ചെയ്യുന്നത് കാര്യക്ഷമമായി ചെയ്യാൻ കഴിയും UPDATE ഒപ്പം SET a യ്ക്കൊപ്പം കമാൻഡുകൾ FROM ക്ലോസ്. ലെ വ്യവസ്ഥകൾ വ്യക്തമാക്കി ഏത് വരികളാണ് അപ്ഡേറ്റ് ചെയ്യുന്നതെന്ന് കൃത്യമായ നിയന്ത്രണം ഈ രീതി അനുവദിക്കുന്നു WHERE ക്ലോസ്. മറ്റൊരു നൂതന സാങ്കേതികത ഉപയോഗിക്കുന്നു MERGE ഒറ്റ ഓപ്പറേഷനിൽ ഇൻസേർട്ട്, അപ്ഡേറ്റ്, ഡിലീറ്റ് എന്നിങ്ങനെ ഒന്നിലധികം പ്രവർത്തനങ്ങൾ പ്രവർത്തനക്ഷമമാക്കുന്ന പ്രസ്താവന. SQL സെർവറിലെ വിവിധ ടേബിളുകളിലുടനീളം ഡാറ്റാ സമഗ്രതയും സ്ഥിരതയും നിലനിർത്തുന്നതിന് രണ്ട് രീതികളും അത്യന്താപേക്ഷിതമാണ്.
ഈ ടെക്നിക്കുകൾ മനസ്സിലാക്കുന്നത് വലിയ ഡാറ്റാസെറ്റുകൾ കൈകാര്യം ചെയ്യാനുള്ള നിങ്ങളുടെ കഴിവിനെ ഗണ്യമായി വർദ്ധിപ്പിക്കുകയും നിങ്ങളുടെ ഡാറ്റാബേസ് പ്രവർത്തനങ്ങൾ കാര്യക്ഷമവും ഫലപ്രദവുമാണെന്ന് ഉറപ്പാക്കുകയും ചെയ്യും. ഉപയോഗം മാസ്റ്റേഴ്സ് ചെയ്തുകൊണ്ട് UPDATE കൂടെ SELECT കൂടാതെ MERGE പ്രസ്താവന, നിങ്ങൾക്ക് നിങ്ങളുടെ ഡാറ്റാ സിൻക്രൊണൈസേഷൻ ടാസ്ക്കുകൾ കാര്യക്ഷമമാക്കാനും നിങ്ങളുടെ SQL സെർവർ പരിതസ്ഥിതിയിലെ പിശകുകളുടെ സാധ്യത കുറയ്ക്കാനും കഴിയും.
SQL സെർവറിൽ SELECT ഉപയോഗിച്ച് അപ്ഡേറ്റ് ചെയ്യുന്നതിനെക്കുറിച്ചുള്ള അന്തിമ ചിന്തകൾ
SQL സെർവറിൽ ടേബിളുകൾ അപ്ഡേറ്റ് ചെയ്യാൻ SELECT ഉപയോഗിക്കുന്നത് ഡാറ്റാ മാനേജ്മെൻ്റിനുള്ള ശക്തവും കാര്യക്ഷമവുമായ ഒരു രീതിയാണ്. പോലുള്ള കമാൻഡുകൾ പ്രയോജനപ്പെടുത്തുന്നതിലൂടെ UPDATE, SET, ഒപ്പം FROM, നിങ്ങളുടെ ടേബിളുകളിലുടനീളം ഡാറ്റയുടെ സ്ഥിരതയും കൃത്യതയും നിങ്ങൾക്ക് ഉറപ്പാക്കാൻ കഴിയും. കൂടാതെ, ദി MERGE കൂടുതൽ സങ്കീർണ്ണമായ പ്രവർത്തനങ്ങൾക്ക് ഒരു ബഹുമുഖ പരിഹാരം പ്രസ്താവന വാഗ്ദാനം ചെയ്യുന്നു. ഈ സാങ്കേതിക വിദ്യകളിൽ പ്രാവീണ്യം നേടുന്നത്, ഡാറ്റാ സിൻക്രൊണൈസേഷനും മെയിൻ്റനൻസ് ടാസ്ക്കുകളും ആത്മവിശ്വാസത്തോടെയും കൃത്യതയോടെയും കൈകാര്യം ചെയ്യാൻ നിങ്ങളെ പ്രാപ്തരാക്കും.