ਗੁੰਝਲਦਾਰ ਡਾਟਾ ਪ੍ਰਾਪਤੀ ਲਈ SQL ਨੂੰ ਅਨੁਕੂਲ ਬਣਾਉਣਾ
SQL ਵੱਡੀ ਮਾਤਰਾ ਵਿੱਚ ਡੇਟਾ ਨੂੰ ਸੰਭਾਲਣ ਲਈ ਇੱਕ ਸ਼ਕਤੀਸ਼ਾਲੀ ਸੰਦ ਹੈ, ਪਰ ਕਈ ਵਾਰ ਸਵਾਲ ਉਮੀਦ ਅਨੁਸਾਰ ਵਿਵਹਾਰ ਨਹੀਂ ਕਰਦੇ ਹਨ। ਉਦਾਹਰਨ ਲਈ, ਖਾਸ ਆਈਟਮਾਂ ਨੂੰ ਪ੍ਰਾਪਤ ਕਰਨ ਲਈ ਸ਼ਰਤੀਆ ਸਵਾਲਾਂ ਨਾਲ ਨਜਿੱਠਣ ਵੇਲੇ, ਗੁੰਮ ਹੋਈਆਂ ਐਂਟਰੀਆਂ ਚੁਣੌਤੀਆਂ ਪੈਦਾ ਕਰ ਸਕਦੀਆਂ ਹਨ ਜਿਨ੍ਹਾਂ ਨੂੰ ਧਿਆਨ ਨਾਲ ਸੰਭਾਲਣ ਦੀ ਲੋੜ ਹੁੰਦੀ ਹੈ। 🧑💻
ਕਿਸੇ ਗਾਹਕ ਲਈ ਡੇਟਾ ਖਿੱਚਣ ਲਈ ਇੱਕ ਪੁੱਛਗਿੱਛ ਚਲਾਉਣ ਦੀ ਕਲਪਨਾ ਕਰੋ, ਅਤੇ ਤੁਸੀਂ ਕੁਝ ਆਈਟਮ ਕੋਡਾਂ ਦੀ ਉਮੀਦ ਕਰਦੇ ਹੋ, ਪਰ ਉਹ ਨਤੀਜਿਆਂ ਵਿੱਚ ਦਿਖਾਈ ਨਹੀਂ ਦਿੰਦੇ ਹਨ। ਕੀ ਹੋਵੇਗਾ ਜੇਕਰ ਡੇਟਾ ਕਿਸੇ ਹੋਰ ਸੰਦਰਭ ਵਿੱਚ ਮੌਜੂਦ ਹੈ, ਅਤੇ ਤੁਹਾਨੂੰ ਇਸਨੂੰ ਫਾਲਬੈਕ ਵਜੋਂ ਲਿਆਉਣ ਦੀ ਲੋੜ ਹੈ? ਇਸ ਲਈ SQL ਦੀਆਂ ਮਜਬੂਤ ਸਮਰੱਥਾਵਾਂ ਦਾ ਲਾਭ ਉਠਾਉਂਦੇ ਹੋਏ, ਇੱਕ ਪੱਧਰੀ ਪੁੱਛਗਿੱਛ ਰਣਨੀਤੀ ਦੀ ਲੋੜ ਹੈ।
ਅਜਿਹੀ ਸਥਿਤੀ ਵਿੱਚ ਜਿੱਥੇ 'BR23456' ਵਰਗੇ ਆਈਟਮ ਕੋਡ ਮਿਟਾਏ ਜਾ ਸਕਦੇ ਹਨ ਜਾਂ ਪ੍ਰਾਇਮਰੀ ਗਾਹਕ ਲਈ ਉਪਲਬਧ ਨਹੀਂ ਹਨ, ਤੁਹਾਨੂੰ ਉਹਨਾਂ ਨੂੰ ਵੱਖ-ਵੱਖ ਮਾਪਦੰਡਾਂ ਦੇ ਤਹਿਤ ਮੁੜ ਪ੍ਰਾਪਤ ਕਰਨ ਲਈ ਇੱਕ ਵੱਖਰੀ ਵਿਧੀ ਦੀ ਲੋੜ ਹੈ। ਇਹ ਉਦਾਹਰਨ ਖੋਜਦੀ ਹੈ ਕਿ ਅਜਿਹੇ ਮੁੱਦਿਆਂ ਨੂੰ ਕਿਵੇਂ ਹੱਲ ਕਰਨਾ ਹੈ, ਇੱਕ ਵਿਆਪਕ ਡਾਟਾ ਆਉਟਪੁੱਟ ਨੂੰ ਯਕੀਨੀ ਬਣਾਉਂਦਾ ਹੈ।
ਇੱਕ ਕਦਮ-ਦਰ-ਕਦਮ ਬ੍ਰੇਕਡਾਊਨ ਦੁਆਰਾ, ਅਸੀਂ ਚਰਚਾ ਕਰਾਂਗੇ ਕਿ ਇੱਕ SQL ਪੁੱਛਗਿੱਛ ਕਿਵੇਂ ਬਣਾਈ ਜਾਵੇ ਜੋ ਕੁਸ਼ਲਤਾ ਨੂੰ ਕਾਇਮ ਰੱਖਦੇ ਹੋਏ ਵਿਕਲਪਕ ਗਾਹਕ ਸੰਦਰਭਾਂ ਤੋਂ ਗੁੰਮ ਆਈਟਮਾਂ ਨੂੰ ਖਿੱਚਦੀ ਹੈ। ਉਦਾਹਰਨਾਂ ਅਤੇ ਤਕਨੀਕਾਂ ਤੁਹਾਨੂੰ ਗਤੀਸ਼ੀਲ ਸਥਿਤੀਆਂ ਨੂੰ ਸੰਭਾਲਣ ਵਿੱਚ ਮੁਹਾਰਤ ਹਾਸਲ ਕਰਨ ਵਿੱਚ ਮਦਦ ਕਰਨਗੀਆਂ, ਤੁਹਾਨੂੰ ਅਸਲ-ਸੰਸਾਰ ਦੀਆਂ ਐਪਲੀਕੇਸ਼ਨਾਂ ਲਈ ਵਿਹਾਰਕ ਸਮਝ ਪ੍ਰਦਾਨ ਕਰਨਗੀਆਂ। 🚀
ਹੁਕਮ | ਵਰਤੋਂ ਦੀ ਉਦਾਹਰਨ |
---|---|
WITH | ਇੰਟਰਮੀਡੀਏਟ ਪੁੱਛਗਿੱਛ ਨਤੀਜਿਆਂ ਦੀ ਮੁੜ ਵਰਤੋਂ ਕਰਨ ਦੀ ਇਜਾਜ਼ਤ ਦੇ ਕੇ ਗੁੰਝਲਦਾਰ ਸਵਾਲਾਂ ਨੂੰ ਸਰਲ ਬਣਾਉਣ ਲਈ ਇੱਕ ਕਾਮਨ ਟੇਬਲ ਐਕਸਪ੍ਰੈਸ਼ਨ (CTE) ਨੂੰ ਪਰਿਭਾਸ਼ਿਤ ਕਰਦਾ ਹੈ। ਉਦਾਹਰਨ: MainQuery AS (ਚੁਣੋ ...) ਦੇ ਨਾਲ |
STRING_SPLIT | ਇੱਕ ਸੀਮਤ ਸਟ੍ਰਿੰਗ ਨੂੰ ਮੁੱਲਾਂ ਦੀ ਇੱਕ ਸਾਰਣੀ ਵਿੱਚ ਵੰਡਦਾ ਹੈ, ਜੋ ਅਕਸਰ ਡਾਟਾ ਫਿਲਟਰ ਕਰਨ ਲਈ ਵਰਤਿਆ ਜਾਂਦਾ ਹੈ। ਉਦਾਹਰਨ: STRING_SPLIT (@ItemCodes, ',') ਤੋਂ ਮੁੱਲ ਚੁਣੋ |
IS | ਮੁੱਲਾਂ ਨੂੰ ਇੱਕ ਨਿਸ਼ਚਿਤ ਬਦਲੀ ਮੁੱਲ ਨਾਲ ਬਦਲਦਾ ਹੈ। ਡਿਫੌਲਟ ਮੁੱਲ ਸੈੱਟ ਕਰਨ ਲਈ ਉਪਯੋਗੀ। ਉਦਾਹਰਨ: IS(ਕੀਮਤ, 0) |
TOP 1 | ਸਭ ਤੋਂ ਢੁੱਕਵੇਂ ਰਿਕਾਰਡ ਨੂੰ ਪ੍ਰਾਪਤ ਕਰਨ ਲਈ ਅਕਸਰ ORDER BY ਨਾਲ ਜੋੜ ਕੇ, ਇੱਕ ਸਿੰਗਲ ਕਤਾਰ ਤੱਕ ਸੈੱਟ ਕੀਤੇ ਨਤੀਜੇ ਨੂੰ ਸੀਮਿਤ ਕਰਦਾ ਹੈ। ਉਦਾਹਰਨ: ਕੀਮਤ ਤੋਂ ਚੋਟੀ ਦੀ 1 ਕੀਮਤ ਚੁਣੋ DESC start_date ਦੁਆਰਾ ORDER |
CASE | Implements conditional logic within queries, allowing different outputs based on specific conditions. Example: CASE WHEN alvl >ਸਵਾਲਾਂ ਦੇ ਅੰਦਰ ਸ਼ਰਤੀਆ ਤਰਕ ਨੂੰ ਲਾਗੂ ਕਰਦਾ ਹੈ, ਖਾਸ ਸ਼ਰਤਾਂ ਦੇ ਆਧਾਰ 'ਤੇ ਵੱਖ-ਵੱਖ ਆਉਟਪੁੱਟ ਦੀ ਇਜਾਜ਼ਤ ਦਿੰਦਾ ਹੈ। ਉਦਾਹਰਨ: CASE WHEN alvl > 0 ਫਿਰ 'ਲੈਵਲ 1' |
NOT EXISTS | ਸਬਕਵੇਰੀ ਵਿੱਚ ਕਤਾਰਾਂ ਦੀ ਅਣਹੋਂਦ ਦੀ ਜਾਂਚ ਕਰਦਾ ਹੈ, ਫਾਲਬੈਕ ਤਰਕ ਨੂੰ ਸੰਭਾਲਣ ਲਈ ਉਪਯੋਗੀ। ਉਦਾਹਰਨ: ਜੇਕਰ ਮੌਜੂਦ ਨਹੀਂ ਹੈ (ਕੀਮਤ ਤੋਂ 1 ਚੁਣੋ ਜਿੱਥੇ ਆਈਟਮਕੋਡ = 'BR23456') |
DECLARE | ਅਸਥਾਈ ਡੇਟਾ ਜਾਂ ਪੈਰਾਮੀਟਰਾਂ ਨੂੰ ਸਟੋਰ ਕਰਨ ਲਈ ਵਰਤੀ ਜਾਂਦੀ SQL ਸਕ੍ਰਿਪਟ ਦੇ ਅੰਦਰ ਵੇਰੀਏਬਲਾਂ ਨੂੰ ਪਰਿਭਾਸ਼ਿਤ ਕਰਦਾ ਹੈ। ਉਦਾਹਰਨ: DECLARE @FallbackItem NVARCHAR(50) = 'BR23456' |
SET NOCOUNT ON | ਇੱਕ ਪੁੱਛਗਿੱਛ ਦੁਆਰਾ ਪ੍ਰਭਾਵਿਤ ਕਤਾਰਾਂ ਦੀ ਸੰਖਿਆ ਨੂੰ ਦਰਸਾਉਣ ਵਾਲੇ ਸੰਦੇਸ਼ ਨੂੰ ਅਸਮਰੱਥ ਬਣਾਉਂਦਾ ਹੈ। ਇਹ ਸਟੋਰ ਕੀਤੀਆਂ ਪ੍ਰਕਿਰਿਆਵਾਂ ਵਿੱਚ ਕਾਰਗੁਜ਼ਾਰੀ ਵਿੱਚ ਸੁਧਾਰ ਕਰਦਾ ਹੈ। ਉਦਾਹਰਨ: ਨੰਬਰ ਚਾਲੂ ਕਰੋ |
UNION ALL | ਡੁਪਲੀਕੇਟ ਕਤਾਰਾਂ ਸਮੇਤ, ਇੱਕ ਸਿੰਗਲ ਨਤੀਜਾ ਸੈੱਟ ਵਿੱਚ ਕਈ ਸਵਾਲਾਂ ਦੇ ਨਤੀਜਿਆਂ ਨੂੰ ਜੋੜਦਾ ਹੈ। ਉਦਾਹਰਨ: ਸਿਲੈਕਟ * ਫ੍ਰਾਮ ਕਿਊਰੀ1 ਯੂਨੀਅਨ ਸਾਰੇ ਚੁਣੋ * ਕਿਊਰੀ2 ਤੋਂ |
ORDER BY | ਨਿਰਧਾਰਤ ਕਾਲਮਾਂ ਦੇ ਆਧਾਰ 'ਤੇ ਪੁੱਛਗਿੱਛ ਦੇ ਨਤੀਜਿਆਂ ਨੂੰ ਕ੍ਰਮਬੱਧ ਕਰਦਾ ਹੈ। ਉਦਾਹਰਨ: start_date DESC ਦੁਆਰਾ ਆਰਡਰ ਕਰੋ |
SQL ਸਵਾਲਾਂ ਵਿੱਚ ਗੁੰਮ ਆਈਟਮਾਂ ਨੂੰ ਗਤੀਸ਼ੀਲ ਰੂਪ ਵਿੱਚ ਸੰਭਾਲਣਾ
ਉਪਰੋਕਤ ਸਕ੍ਰਿਪਟਾਂ ਵਿੱਚ, ਮੁੱਖ ਟੀਚਾ ਡੇਟਾ ਪ੍ਰਾਪਤੀ ਵਿੱਚ ਇੱਕ ਆਮ ਸਮੱਸਿਆ ਨੂੰ ਹੱਲ ਕਰਨਾ ਹੈ: ਉਹਨਾਂ ਮਾਮਲਿਆਂ ਨੂੰ ਸੰਭਾਲਣਾ ਜਿੱਥੇ ਕੁਝ ਆਈਟਮਾਂ ਪੁੱਛਗਿੱਛ ਦੇ ਨਤੀਜਿਆਂ ਵਿੱਚੋਂ ਗੁੰਮ ਹੋ ਸਕਦੀਆਂ ਹਨ। ਪ੍ਰਾਇਮਰੀ ਸਕ੍ਰਿਪਟ SQL ਤਕਨੀਕਾਂ ਦੇ ਸੁਮੇਲ ਦੀ ਵਰਤੋਂ ਕਰਦੀ ਹੈ, ਜਿਵੇਂ ਕਿ ਕਾਮਨ ਟੇਬਲ ਐਕਸਪ੍ਰੈਸ਼ਨ (CTEs), CASE ਸਟੇਟਮੈਂਟਾਂ ਦੇ ਨਾਲ ਕੰਡੀਸ਼ਨਲ ਤਰਕ, ਅਤੇ ਫਾਲਬੈਕ ਮਕੈਨਿਜ਼ਮ ਮੌਜੂਦ ਨਹੀਂ ਹੈ. ਇਹਨਾਂ ਵਿਸ਼ੇਸ਼ਤਾਵਾਂ ਨੂੰ ਲੇਅਰਿੰਗ ਕਰਕੇ, ਪੁੱਛਗਿੱਛ ਇਹ ਸੁਨਿਸ਼ਚਿਤ ਕਰਦੀ ਹੈ ਕਿ ਜੇਕਰ ਇੱਕ ਆਈਟਮ ਕੋਡ ਇੱਕ ਗਾਹਕ ਦੀ ਸੂਚੀ ਵਿੱਚੋਂ ਗੁੰਮ ਹੈ, ਤਾਂ ਇਹ ਇੱਕ ਵਿਕਲਪਿਕ ਸੰਦਰਭ ਤੋਂ ਇੱਕ ਫਾਲਬੈਕ ਰਿਕਾਰਡ ਨੂੰ ਗਤੀਸ਼ੀਲ ਰੂਪ ਵਿੱਚ ਪ੍ਰਾਪਤ ਕਰਦਾ ਹੈ।
ਹੱਲ ਦਾ ਇੱਕ ਮਹੱਤਵਪੂਰਨ ਹਿੱਸਾ ਏ ਦੀ ਵਰਤੋਂ ਹੈ ਨਾਲ ਇੱਕ ਮੁੜ ਵਰਤੋਂ ਯੋਗ ਇੰਟਰਮੀਡੀਏਟ ਪੁੱਛਗਿੱਛ ਨੂੰ ਪਰਿਭਾਸ਼ਿਤ ਕਰਨ ਲਈ ਧਾਰਾ, ਜਿਸਨੂੰ ਕਾਮਨ ਟੇਬਲ ਐਕਸਪ੍ਰੈਸ਼ਨ (CTE) ਵੀ ਕਿਹਾ ਜਾਂਦਾ ਹੈ। ਇਹ SQL ਨੂੰ ਪੜ੍ਹਨਾ ਅਤੇ ਸੰਭਾਲਣਾ ਆਸਾਨ ਬਣਾਉਂਦਾ ਹੈ, ਕਿਉਂਕਿ ਇਹ ਮੁੱਖ ਤਰਕ ਨੂੰ ਫਾਲਬੈਕ ਤਰਕ ਤੋਂ ਵੱਖ ਕਰਦਾ ਹੈ। ਉਦਾਹਰਨ ਲਈ, CTE ਵਿੱਚ, ਅਸੀਂ ਗਾਹਕ "ਟੈਸਟ" ਲਈ ਰਿਕਾਰਡ ਪ੍ਰਾਪਤ ਕਰਦੇ ਹਾਂ ਅਤੇ ਨਿਰਧਾਰਤ ਸੂਚੀ ਵਿੱਚ ਆਈਟਮ ਕੋਡਾਂ ਦੀ ਜਾਂਚ ਕਰਦੇ ਹਾਂ। ਜੇਕਰ 'BR23456' ਵਰਗਾ ਕੋਈ ਆਈਟਮ ਕੋਡ ਗੁੰਮ ਹੈ, ਤਾਂ ਫਾਲਬੈਕ ਪੁੱਛਗਿੱਛ 'lvlholder' ਗਾਹਕ ਤੋਂ ਖਾਸ ਸ਼ਰਤਾਂ ਦੇ ਨਾਲ ਲੋੜੀਂਦਾ ਡੇਟਾ ਪ੍ਰਦਾਨ ਕਰਨ ਲਈ ਕਦਮ ਚੁੱਕਦੀ ਹੈ। ਇਹ ਡਾਟਾ ਇਕਸਾਰਤਾ ਅਤੇ ਸੰਪੂਰਨਤਾ ਨੂੰ ਯਕੀਨੀ ਬਣਾਉਂਦਾ ਹੈ। 🛠️
ਇੱਕ ਹੋਰ ਮਹੱਤਵਪੂਰਨ ਪਹਿਲੂ ਹੈ ਫਾਲਬੈਕ ਮਕੈਨਿਜ਼ਮ ਜੋ ਕਿ ਏ ਮੌਜੂਦ ਨਹੀਂ ਹੈ ਹਾਲਤ. ਇਹ ਜਾਂਚ ਕਰਦਾ ਹੈ ਕਿ ਕੀ ਨਿਸ਼ਾਨਾ ਆਈਟਮ ਕੋਡ ਪ੍ਰਾਇਮਰੀ ਪੁੱਛਗਿੱਛ ਦੇ ਨਤੀਜਿਆਂ ਵਿੱਚ ਮੌਜੂਦ ਹੈ। ਜੇਕਰ ਨਹੀਂ, ਤਾਂ ਸਕ੍ਰਿਪਟ ਕਿਸੇ ਹੋਰ ਸਰੋਤ ਤੋਂ ਗੁੰਮ ਆਈਟਮ ਦੇ ਵੇਰਵੇ ਪ੍ਰਾਪਤ ਕਰਦੀ ਹੈ, ਜਿਵੇਂ ਕਿ ਇੱਕ ਵਿਕਲਪਿਕ ਗਾਹਕ ਜਾਂ ਪੱਧਰ (blvl = 8)। ਇਹ ਵਿਧੀ ਉਹਨਾਂ ਪ੍ਰਣਾਲੀਆਂ ਲਈ ਮਹੱਤਵਪੂਰਨ ਹੈ ਜਿੱਥੇ ਡੇਟਾ ਸੰਪੂਰਨਤਾ ਮਹੱਤਵਪੂਰਨ ਹੈ, ਜਿਵੇਂ ਕਿ ਵਸਤੂ ਪ੍ਰਬੰਧਨ ਜਾਂ ਗਤੀਸ਼ੀਲ ਕੀਮਤ ਪ੍ਰਣਾਲੀਆਂ ਵਿੱਚ। ਫਾਲਬੈਕ ਤਰਕ ਦੀ ਵਰਤੋਂ ਕਰਕੇ, ਅਸੀਂ ਇਹ ਸੁਨਿਸ਼ਚਿਤ ਕਰਦੇ ਹਾਂ ਕਿ ਭਾਵੇਂ ਪ੍ਰਾਇਮਰੀ ਡੇਟਾ ਅਧੂਰਾ ਹੈ, ਉਪਭੋਗਤਾ ਫਿਰ ਵੀ ਅਰਥਪੂਰਨ ਨਤੀਜੇ ਪ੍ਰਾਪਤ ਕਰਦਾ ਹੈ।
ਫਾਲਬੈਕ ਪੁੱਛਗਿੱਛ ਤੋਂ ਇਲਾਵਾ, ਸਕ੍ਰਿਪਟ ਦਾ ਸਟੋਰ ਕੀਤਾ ਪ੍ਰਕਿਰਿਆ ਸੰਸਕਰਣ ਮਾਡਯੂਲਰਿਟੀ ਅਤੇ ਮੁੜ ਵਰਤੋਂਯੋਗਤਾ ਨੂੰ ਜੋੜਦਾ ਹੈ। ਗਾਹਕ ਨਾਮ ਅਤੇ ਆਈਟਮ ਕੋਡ ਵਰਗੇ ਮੁੱਖ ਮੁੱਲਾਂ ਨੂੰ ਪੈਰਾਮੀਟਰਾਈਜ਼ ਕਰਕੇ, ਸਟੋਰ ਕੀਤੀ ਪ੍ਰਕਿਰਿਆ ਨੂੰ ਕਈ ਸੰਦਰਭਾਂ ਵਿੱਚ ਦੁਬਾਰਾ ਵਰਤਿਆ ਜਾ ਸਕਦਾ ਹੈ। ਇਹ ਪਹੁੰਚ ਪ੍ਰਦਰਸ਼ਨ ਅਤੇ ਸੁਰੱਖਿਆ ਨੂੰ ਵੀ ਵਧਾਉਂਦੀ ਹੈ, ਕਿਉਂਕਿ ਇਹ ਹਾਰਡਕੋਡਿੰਗ ਨੂੰ ਘੱਟ ਕਰਦਾ ਹੈ ਅਤੇ ਇਨਪੁਟ ਪ੍ਰਮਾਣਿਕਤਾ ਨੂੰ ਸਮਰੱਥ ਬਣਾਉਂਦਾ ਹੈ। ਉਦਾਹਰਨ ਲਈ, ਇੱਕ ਵਿਕਰੀ ਵਿਸ਼ਲੇਸ਼ਕ ਵੱਖ-ਵੱਖ ਫਾਲਬੈਕ ਨਿਯਮਾਂ ਵਾਲੇ ਕਈ ਗਾਹਕਾਂ ਲਈ ਕੀਮਤ ਡੇਟਾ ਨੂੰ ਮੁੜ ਪ੍ਰਾਪਤ ਕਰਨ ਲਈ ਇਸ ਪ੍ਰਕਿਰਿਆ ਦੀ ਵਰਤੋਂ ਕਰ ਸਕਦਾ ਹੈ। 🚀
ਅੰਤ ਵਿੱਚ, ਹੱਲ ਸਵਾਲ ਪ੍ਰਦਰਸ਼ਨ ਨੂੰ ਅਨੁਕੂਲ ਬਣਾਉਣ ਲਈ SQL ਵਧੀਆ ਅਭਿਆਸਾਂ ਨੂੰ ਨਿਯੁਕਤ ਕਰਦਾ ਹੈ, ਜਿਵੇਂ ਕਿ ਵਰਤੋਂ ਸਿਖਰ 1 ਅਤੇ ਦੁਆਰਾ ਆਰਡਰ ਕਰੋ ਨਤੀਜਿਆਂ ਨੂੰ ਸੀਮਤ ਕਰਨ ਅਤੇ ਇਹ ਯਕੀਨੀ ਬਣਾਉਣ ਲਈ ਕਿ ਸਭ ਤੋਂ ਢੁਕਵਾਂ ਡੇਟਾ ਪ੍ਰਾਪਤ ਕੀਤਾ ਗਿਆ ਹੈ। ਇਹ ਵਿਧੀਆਂ ਖਾਸ ਤੌਰ 'ਤੇ ਉਹਨਾਂ ਸਥਿਤੀਆਂ ਵਿੱਚ ਉਪਯੋਗੀ ਹਨ ਜਿੱਥੇ ਵੱਡੇ ਡੇਟਾਸੈਟਾਂ ਨੂੰ ਕੁਸ਼ਲਤਾ ਨਾਲ ਸੰਸਾਧਿਤ ਕੀਤਾ ਜਾਣਾ ਚਾਹੀਦਾ ਹੈ। ਭਾਵੇਂ ਤੁਸੀਂ ਇੱਕ ਡੈਸ਼ਬੋਰਡ ਬਣਾ ਰਹੇ ਹੋ ਜਾਂ ਇੱਕ ਰਿਪੋਰਟ ਤਿਆਰ ਕਰ ਰਹੇ ਹੋ, ਅਜਿਹੇ ਅਨੁਕੂਲਨ ਜਵਾਬ ਦੇ ਸਮੇਂ ਅਤੇ ਉਪਭੋਗਤਾ ਅਨੁਭਵ ਵਿੱਚ ਮਹੱਤਵਪੂਰਨ ਸੁਧਾਰ ਕਰ ਸਕਦੇ ਹਨ।
ਗੁੰਮ ਹੋਏ ਡੇਟਾ ਲਈ ਡਾਇਨਾਮਿਕ SQL ਪੁੱਛਗਿੱਛ ਹੈਂਡਲਿੰਗ
SQL ਡਾਟਾਬੇਸ ਪ੍ਰਬੰਧਨ ਲਈ ਬੈਕ-ਐਂਡ ਸਕ੍ਰਿਪਟ, ਗੁੰਮ ਆਈਟਮਾਂ ਨੂੰ ਗਤੀਸ਼ੀਲ ਤੌਰ 'ਤੇ ਫਾਲਬੈਕ ਤਰਕ ਨਾਲ ਸੰਭਾਲਣਾ।
-- Approach 1: Using a UNION query to handle missing items dynamically
WITH MainQuery AS (
SELECT
p.[itemcode],
p.[uom],
p.[trtype],
p.[alvl],
p.[blvl],
CASE
WHEN p.[alvl] > 0 THEN (
SELECT TOP 1 x.start_date
FROM pricing x
WHERE x.itemcode = p.itemcode
AND x.blvl = p.alvl
AND x.customer = 'lvlholder'
ORDER BY x.start_date DESC
)
WHEN p.[trtype] = '' THEN (
SELECT TOP 1 x.start_date
FROM pricing x
WHERE x.itemcode = p.itemcode
AND x.blvl = 8
AND x.customer = 'lvlholder'
ORDER BY x.start_date DESC
)
ELSE p.[start_date]
END AS start_date,
CASE
WHEN p.[trtype] = 'Quot' THEN p.[price]
WHEN p.[alvl] > 0 THEN (
SELECT TOP 1 x.price
FROM pricing x
WHERE x.itemcode = p.itemcode
AND x.blvl = p.alvl
AND x.customer = 'lvlholder'
ORDER BY x.start_date DESC
)
WHEN p.[trtype] = '' THEN (
SELECT TOP 1 x.price
FROM pricing x
WHERE x.itemcode = p.itemcode
AND x.blvl = 8
AND x.customer = 'lvlholder'
ORDER BY x.start_date DESC
)
ELSE 0
END AS LevelResult,
p.price
FROM pricing p
WHERE p.[Customer] = 'test'
AND p.[itemcode] IN ('ABC1234', 'X123456', 'BR23456', 'CX23456')
)
SELECT * FROM MainQuery
UNION ALL
SELECT
'BR23456' AS [itemcode],
'PC' AS [uom],
'' AS [trtype],
0 AS [alvl],
8 AS [blvl],
'2024-01-01' AS start_date,
15.56 AS LevelResult,
0 AS price
WHERE NOT EXISTS (
SELECT 1
FROM MainQuery mq
WHERE mq.[itemcode] = 'BR23456'
);
ਵਿਕਲਪਕ ਪਹੁੰਚ: ਮੁੜ ਵਰਤੋਂਯੋਗਤਾ ਲਈ ਮਾਡਿਊਲਰਾਈਜ਼ਡ ਸਟੋਰ ਕੀਤੀ ਪ੍ਰਕਿਰਿਆ
ਇਨਪੁਟ ਪੈਰਾਮੀਟਰਾਂ ਅਤੇ ਫਾਲਬੈਕ ਤਰਕ ਨਾਲ ਗੁੰਮ ਆਈਟਮਾਂ ਨੂੰ ਸੰਭਾਲਣ ਲਈ SQL ਸਟੋਰ ਕੀਤੀ ਪ੍ਰਕਿਰਿਆ।
CREATE PROCEDURE FetchItemDetails
@Customer NVARCHAR(50),
@ItemCodes NVARCHAR(MAX)
AS
BEGIN
SET NOCOUNT ON;
DECLARE @FallbackItem NVARCHAR(50) = 'BR23456';
DECLARE @FallbackCustomer NVARCHAR(50) = 'lvlholder';
DECLARE @FallbackBlvl INT = 8;
-- Main Query
SELECT
p.[itemcode],
p.[uom],
p.[trtype],
p.[alvl],
p.[blvl],
IS((
SELECT TOP 1 x.start_date
FROM pricing x
WHERE x.itemcode = p.itemcode
AND x.blvl = p.alvl
AND x.customer = @FallbackCustomer
ORDER BY x.start_date DESC
), p.[start_date]) AS start_date,
IS((
SELECT TOP 1 x.price
FROM pricing x
WHERE x.itemcode = p.itemcode
AND x.blvl = p.alvl
AND x.customer = @FallbackCustomer
ORDER BY x.start_date DESC
), p.price) AS LevelResult
FROM pricing p
WHERE p.[Customer] = @Customer
AND p.[itemcode] IN (SELECT value FROM STRING_SPLIT(@ItemCodes, ','));
-- Fallback
IF NOT EXISTS (SELECT 1 FROM pricing WHERE [itemcode] = @FallbackItem)
BEGIN
INSERT INTO pricing ([itemcode], [uom], [trtype], [blvl], [price], [start_date])
VALUES (@FallbackItem, 'PC', '', @FallbackBlvl, 15.56, '2024-01-01');
END
END
ਡਾਟਾ ਸੰਪੂਰਨਤਾ ਲਈ ਲਚਕੀਲੇ SQL ਸਵਾਲਾਂ ਦਾ ਨਿਰਮਾਣ ਕਰਨਾ
SQL ਪੁੱਛਗਿੱਛ ਡਿਜ਼ਾਈਨ ਦਾ ਇੱਕ ਮਹੱਤਵਪੂਰਨ ਪਹਿਲੂ ਜਿਸ 'ਤੇ ਚਰਚਾ ਨਹੀਂ ਕੀਤੀ ਗਈ ਹੈ ਉਹ ਹੈ *ਬਾਹਰੀ ਜੋੜਾਂ* ਦੀ ਭੂਮਿਕਾ ਅਤੇ ਗੁੰਮ ਹੋਏ ਡੇਟਾ ਨੂੰ ਸੰਭਾਲਣ ਦੀ ਉਹਨਾਂ ਦੀ ਯੋਗਤਾ। ਅੰਦਰੂਨੀ ਜੋੜਾਂ ਦੇ ਉਲਟ, ਬਾਹਰੀ ਜੋੜਾਂ ਤੁਹਾਨੂੰ ਇੱਕ ਸਾਰਣੀ ਤੋਂ ਸਾਰੀਆਂ ਕਤਾਰਾਂ ਨੂੰ ਸ਼ਾਮਲ ਕਰਨ ਦੀ ਇਜਾਜ਼ਤ ਦਿੰਦੀਆਂ ਹਨ, ਭਾਵੇਂ ਸੰਬੰਧਿਤ ਸਾਰਣੀ ਵਿੱਚ ਕੋਈ ਸੰਬੰਧਿਤ ਡੇਟਾ ਨਾ ਹੋਵੇ। ਇਹ ਵਿਸ਼ੇਸ਼ ਤੌਰ 'ਤੇ ਉਪਯੋਗੀ ਹੁੰਦਾ ਹੈ ਜਦੋਂ ਕਿਸੇ ਗਾਹਕ ਦੀ ਸੂਚੀ ਤੋਂ ਡੇਟਾ ਪ੍ਰਾਪਤ ਕਰਨ ਵਰਗੇ ਦ੍ਰਿਸ਼ਾਂ ਨਾਲ ਕੰਮ ਕਰਨਾ, ਜਿੱਥੇ ਕੁਝ ਆਈਟਮਾਂ ਮੌਜੂਦ ਨਹੀਂ ਹੋ ਸਕਦੀਆਂ ਹਨ। ਉਦਾਹਰਨ ਲਈ, ਏ ਖੱਬਾ ਜੁੜੋ, ਤੁਸੀਂ ਇਹ ਯਕੀਨੀ ਬਣਾ ਸਕਦੇ ਹੋ ਕਿ ਮੁੱਖ ਸਾਰਣੀ ਵਿੱਚ ਸਾਰੀਆਂ ਆਈਟਮਾਂ ਬਰਕਰਾਰ ਹਨ, ਅਤੇ ਸੰਬੰਧਿਤ ਸਾਰਣੀ ਵਿੱਚੋਂ ਕੋਈ ਵੀ ਗੁੰਮ ਡੇਟਾ ਨਲ ਜਾਂ ਡਿਫੌਲਟ ਮੁੱਲਾਂ ਨਾਲ ਭਰਿਆ ਹੋਇਆ ਹੈ।
ਇਸ ਤੋਂ ਇਲਾਵਾ, ਸਟੋਰ ਕੀਤੀਆਂ ਪ੍ਰਕਿਰਿਆਵਾਂ ਵਰਗੇ ਸਾਧਨਾਂ ਦੀ ਵਰਤੋਂ ਕਰਦੇ ਹੋਏ ਗਤੀਸ਼ੀਲ ਸਵਾਲਾਂ ਦਾ ਲਾਭ ਲੈਣਾ SQL ਸਕ੍ਰਿਪਟਾਂ ਨੂੰ ਹੋਰ ਅਨੁਕੂਲ ਬਣਾ ਸਕਦਾ ਹੈ। ਡਾਇਨਾਮਿਕ SQL ਰਨਟਾਈਮ ਪੈਰਾਮੀਟਰਾਂ ਦੇ ਆਧਾਰ 'ਤੇ ਸਵਾਲਾਂ ਨੂੰ ਅਨੁਕੂਲ ਬਣਾਉਣ ਦੀ ਇਜਾਜ਼ਤ ਦੇ ਕੇ ਲਚਕਤਾ ਨੂੰ ਸਮਰੱਥ ਬਣਾਉਂਦਾ ਹੈ। ਉਦਾਹਰਨ ਲਈ, ਤੁਸੀਂ ਆਈਟਮ ਕੋਡ ਜਾਂ ਗਾਹਕ ਦੇ ਨਾਮ ਦੀ ਸੂਚੀ ਲਈ ਇਨਪੁਟ ਪੈਰਾਮੀਟਰਾਂ ਦੇ ਨਾਲ ਸਟੋਰ ਕੀਤੀਆਂ ਪ੍ਰਕਿਰਿਆਵਾਂ ਦੀ ਵਰਤੋਂ ਕਰ ਸਕਦੇ ਹੋ, ਗਤੀਸ਼ੀਲ ਤੌਰ 'ਤੇ ਸਵਾਲਾਂ ਨੂੰ ਬਣਾਉਣਾ ਜੋ ਸਥਿਤੀ ਲਈ ਖਾਸ ਹਨ। ਇਹ ਪਹੁੰਚ ਵਿਸ਼ੇਸ਼ ਤੌਰ 'ਤੇ ਬਹੁ-ਕਿਰਾਏਦਾਰ ਪ੍ਰਣਾਲੀਆਂ ਵਿੱਚ ਮਦਦਗਾਰ ਹੈ, ਜਿੱਥੇ ਵੱਖ-ਵੱਖ ਗਾਹਕਾਂ ਦੀਆਂ ਵੱਖੋ-ਵੱਖਰੀਆਂ ਫਾਲਬੈਕ ਸਥਿਤੀਆਂ ਜਾਂ ਲੋੜਾਂ ਹੋ ਸਕਦੀਆਂ ਹਨ। 🧑💻
ਅੰਤ ਵਿੱਚ, ਲਚਕੀਲੇ SQL ਸਵਾਲਾਂ ਦਾ ਨਿਰਮਾਣ ਕਰਦੇ ਸਮੇਂ ਗਲਤੀ ਸੰਭਾਲਣਾ ਇੱਕ ਮਹੱਤਵਪੂਰਨ ਪਹਿਲੂ ਹੈ। ਟਰਾਈ-ਕੈਚ ਬਲੌਕਸ (ਜਾਂ ਉਹਨਾਂ ਦੇ SQL ਬਰਾਬਰ, ਜਿਵੇਂ ਕਿ ਰਿਟਰਨ ਕੋਡਾਂ ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਸਟ੍ਰਕਚਰਡ ਐਰਰ ਹੈਂਡਲਿੰਗ) ਨੂੰ ਸ਼ਾਮਲ ਕਰਨਾ ਇਹ ਯਕੀਨੀ ਬਣਾਉਂਦਾ ਹੈ ਕਿ ਅਣਕਿਆਸੀ ਸਮੱਸਿਆਵਾਂ-ਜਿਵੇਂ ਕਿ ਗੁੰਮ ਟੇਬਲ ਜਾਂ ਅਵੈਧ ਕਾਲਮ ਹਵਾਲੇ-ਐਪਲੀਕੇਸ਼ਨ ਦੇ ਪ੍ਰਵਾਹ ਵਿੱਚ ਵਿਘਨ ਨਾ ਪਵੇ। ਬਾਹਰੀ ਜੋੜਾਂ, ਗਤੀਸ਼ੀਲ SQL, ਅਤੇ ਮਜ਼ਬੂਤ ਐਰਰ ਹੈਂਡਲਿੰਗ ਵਰਗੇ ਤਰੀਕਿਆਂ ਨੂੰ ਜੋੜ ਕੇ, ਤੁਹਾਡੀਆਂ ਪੁੱਛਗਿੱਛਾਂ ਵਧੇਰੇ ਅਨੁਕੂਲ ਅਤੇ ਅਸਫਲ-ਸੁਰੱਖਿਅਤ ਬਣ ਸਕਦੀਆਂ ਹਨ, ਗੁੰਝਲਦਾਰ ਸਥਿਤੀਆਂ ਵਿੱਚ ਨਿਰੰਤਰ ਪ੍ਰਦਰਸ਼ਨ ਅਤੇ ਭਰੋਸੇਯੋਗਤਾ ਨੂੰ ਯਕੀਨੀ ਬਣਾਉਂਦੀਆਂ ਹਨ। 🚀
SQL ਸਵਾਲਾਂ ਬਾਰੇ ਆਮ ਤੌਰ 'ਤੇ ਪੁੱਛੇ ਜਾਂਦੇ ਸਵਾਲ
- ਕੀ ਹੈ ਏ LEFT JOIN ਅਤੇ ਤੁਹਾਨੂੰ ਇਸਨੂੰ ਕਦੋਂ ਵਰਤਣਾ ਚਾਹੀਦਾ ਹੈ?
- ਏ LEFT JOIN ਖੱਬੇ ਸਾਰਣੀ ਤੋਂ ਸਾਰੀਆਂ ਕਤਾਰਾਂ ਨੂੰ ਸ਼ਾਮਲ ਕਰਨ ਲਈ ਵਰਤਿਆ ਜਾਂਦਾ ਹੈ, ਭਾਵੇਂ ਸੱਜੀ ਸਾਰਣੀ ਵਿੱਚ ਕੋਈ ਮੇਲ ਨਾ ਹੋਵੇ। ਇਹ ਰਿਪੋਰਟਾਂ ਜਾਂ ਡੇਟਾ ਵਿਸ਼ਲੇਸ਼ਣ ਵਿੱਚ ਡੇਟਾ ਸੰਪੂਰਨਤਾ ਨੂੰ ਸੁਰੱਖਿਅਤ ਰੱਖਣ ਲਈ ਉਪਯੋਗੀ ਹੈ।
- ਕਿਵੇਂ ਕਰਦਾ ਹੈ IS ਪੁੱਛਗਿੱਛ ਦੇ ਨਤੀਜਿਆਂ ਵਿੱਚ ਸੁਧਾਰ ਕਰਨਾ ਹੈ?
- ਦ IS ਫੰਕਸ਼ਨ ਇੱਕ ਨਿਸ਼ਚਿਤ ਮੁੱਲ ਨਾਲ ਨਲ ਮੁੱਲਾਂ ਨੂੰ ਬਦਲਦਾ ਹੈ, ਡੇਟਾ ਦੀ ਇਕਸਾਰਤਾ ਨੂੰ ਯਕੀਨੀ ਬਣਾਉਂਦਾ ਹੈ ਅਤੇ ਗਣਨਾਵਾਂ ਵਿੱਚ ਨਲ-ਸੰਬੰਧੀ ਤਰੁੱਟੀਆਂ ਨੂੰ ਰੋਕਦਾ ਹੈ।
- ਵਿਚਕਾਰ ਕੀ ਫਰਕ ਹੈ INNER JOIN ਅਤੇ OUTER JOIN?
- INNER JOIN ਟੇਬਲ ਦੇ ਵਿਚਕਾਰ ਸਿਰਫ਼ ਮੇਲ ਖਾਂਦੀਆਂ ਕਤਾਰਾਂ ਨੂੰ ਮੁੜ ਪ੍ਰਾਪਤ ਕਰਦਾ ਹੈ, ਜਦਕਿ OUTER JOIN ਕਿਸਮ (ਖੱਬੇ, ਸੱਜੇ, ਜਾਂ ਪੂਰੀ) 'ਤੇ ਨਿਰਭਰ ਕਰਦੇ ਹੋਏ, ਗੈਰ-ਮੇਲ ਖਾਂਦੀਆਂ ਕਤਾਰਾਂ ਨੂੰ ਸ਼ਾਮਲ ਕਰਦਾ ਹੈ।
- ਕੀ ਤੁਸੀਂ ਡਾਇਨਾਮਿਕ ਸਵਾਲਾਂ ਲਈ ਸਟੋਰ ਕੀਤੀਆਂ ਪ੍ਰਕਿਰਿਆਵਾਂ ਦੀ ਵਰਤੋਂ ਕਰ ਸਕਦੇ ਹੋ?
- ਹਾਂ, ਲਚਕਤਾ ਅਤੇ ਮਾਡਯੂਲਰਿਟੀ ਦੀ ਪੇਸ਼ਕਸ਼ ਕਰਦੇ ਹੋਏ, SQL ਸਵਾਲਾਂ ਨੂੰ ਗਤੀਸ਼ੀਲ ਰੂਪ ਵਿੱਚ ਬਣਾਉਣ ਅਤੇ ਚਲਾਉਣ ਲਈ ਇਨਪੁਟ ਪੈਰਾਮੀਟਰਾਂ ਨਾਲ ਸਟੋਰ ਕੀਤੀਆਂ ਪ੍ਰਕਿਰਿਆਵਾਂ ਨੂੰ ਡਿਜ਼ਾਈਨ ਕੀਤਾ ਜਾ ਸਕਦਾ ਹੈ।
- ਗਲਤੀ ਨਾਲ ਨਜਿੱਠਣ ਨਾਲ ਪੁੱਛਗਿੱਛ ਦੀ ਭਰੋਸੇਯੋਗਤਾ ਵਿੱਚ ਸੁਧਾਰ ਕਿਵੇਂ ਹੋ ਸਕਦਾ ਹੈ?
- SQL ਵਿੱਚ ਸੰਭਾਲਣ ਵਿੱਚ ਗਲਤੀ, ਜਿਵੇਂ ਕਿ ਵਰਤੋਂ TRY-CATCH ਬਲਾਕ, ਇਹ ਸੁਨਿਸ਼ਚਿਤ ਕਰਦਾ ਹੈ ਕਿ ਅਚਾਨਕ ਮੁੱਦੇ ਐਗਜ਼ੀਕਿਊਸ਼ਨ ਪ੍ਰਵਾਹ ਵਿੱਚ ਵਿਘਨ ਨਹੀਂ ਪਾਉਂਦੇ ਹਨ, ਐਪਲੀਕੇਸ਼ਨ ਨੂੰ ਹੋਰ ਮਜ਼ਬੂਤ ਬਣਾਉਂਦੇ ਹਨ।
ਗੁੰਮ ਹੋਏ ਡੇਟਾ ਲਈ ਡਾਇਨਾਮਿਕ SQL ਵਿੱਚ ਮੁਹਾਰਤ ਹਾਸਲ ਕਰਨਾ
ਡਾਇਨਾਮਿਕ SQL ਸਵਾਲ ਉਹਨਾਂ ਦ੍ਰਿਸ਼ਾਂ ਨੂੰ ਸੰਭਾਲਣ ਦਾ ਇੱਕ ਮਜ਼ਬੂਤ ਤਰੀਕਾ ਪ੍ਰਦਾਨ ਕਰਦੇ ਹਨ ਜਿੱਥੇ ਖਾਸ ਡਾਟਾ ਗੈਰਹਾਜ਼ਰ ਹੋ ਸਕਦਾ ਹੈ। ਫਾਲਬੈਕ ਮਕੈਨਿਜ਼ਮ ਵਰਗੀਆਂ ਤਕਨੀਕਾਂ ਇਹ ਯਕੀਨੀ ਬਣਾਉਂਦੀਆਂ ਹਨ ਕਿ ਕੋਈ ਨਾਜ਼ੁਕ ਡਾਟਾ ਪੁਆਇੰਟ ਗੁਆਚ ਨਾ ਜਾਵੇ, ਜਿਸ ਨਾਲ ਉਹ ਡਾਟਾ-ਸੰਵੇਦਨਸ਼ੀਲ ਉਦਯੋਗਾਂ ਜਿਵੇਂ ਕਿ ਰਿਟੇਲ ਜਾਂ ਲੌਜਿਸਟਿਕਸ ਲਈ ਲਾਜ਼ਮੀ ਬਣਾਉਂਦੇ ਹਨ। ਉੱਨਤ SQL ਵਿਸ਼ੇਸ਼ਤਾਵਾਂ ਨੂੰ ਜੋੜ ਕੇ, ਉਪਭੋਗਤਾ ਪ੍ਰਦਰਸ਼ਨ ਅਤੇ ਭਰੋਸੇਯੋਗਤਾ ਨੂੰ ਅਨੁਕੂਲ ਬਣਾ ਸਕਦੇ ਹਨ।
ਜਿਵੇਂ ਕਿ ਵਿਸ਼ੇਸ਼ਤਾਵਾਂ ਨੂੰ ਸਮਝਣਾ ਅਤੇ ਵਰਤਣਾ IS ਅਤੇ ਗਤੀਸ਼ੀਲ ਫਾਲਬੈਕ ਤਰਕ ਡਿਵੈਲਪਰਾਂ ਨੂੰ ਅਜਿਹੇ ਹੱਲ ਬਣਾਉਣ ਲਈ ਸ਼ਕਤੀ ਪ੍ਰਦਾਨ ਕਰਦਾ ਹੈ ਜੋ ਵੱਖ-ਵੱਖ ਚੁਣੌਤੀਆਂ ਦੇ ਅਨੁਕੂਲ ਹੁੰਦੇ ਹਨ। ਕੀਮਤ ਦੇ ਮਾਡਲਾਂ ਤੋਂ ਲੈ ਕੇ ਵਿਆਪਕ ਰਿਪੋਰਟਿੰਗ ਪ੍ਰਣਾਲੀਆਂ ਤੱਕ, ਇਹ ਵਿਧੀਆਂ ਕਾਰਜਾਂ ਨੂੰ ਸੁਚਾਰੂ ਬਣਾਉਣ ਦੌਰਾਨ ਇਕਸਾਰ ਅਤੇ ਸਹੀ ਨਤੀਜੇ ਯਕੀਨੀ ਬਣਾਉਂਦੀਆਂ ਹਨ। 💡
SQL ਕਿਊਰੀ ਓਪਟੀਮਾਈਜੇਸ਼ਨ ਲਈ ਭਰੋਸੇਯੋਗ ਹਵਾਲੇ
- SQL ਕਿਊਰੀ ਬਣਤਰ ਅਤੇ ਸਭ ਤੋਂ ਵਧੀਆ ਅਭਿਆਸ ਇਸ ਤੋਂ ਪ੍ਰਾਪਤ ਕੀਤੇ ਗਏ ਹਨ SQL ਟਿਊਟੋਰਿਅਲ .
- ਡਾਇਨਾਮਿਕ ਪੁੱਛਗਿੱਛ ਤਕਨੀਕਾਂ ਅਤੇ ਫਾਲਬੈਕ ਤਰਕ ਤੋਂ ਹਵਾਲਾ ਦਿੱਤਾ ਗਿਆ ਹੈ ਮਾਈਕਰੋਸਾਫਟ SQL ਸਰਵਰ ਦਸਤਾਵੇਜ਼ .
- ਉੱਨਤ SQL ਕਮਾਂਡਾਂ ਦੀਆਂ ਧਾਰਨਾਵਾਂ ਤੋਂ ਮੁੜ ਪ੍ਰਾਪਤ ਕੀਤਾ ਗਿਆ ਹੈ GeeksforGeeks SQL ਗਾਈਡ .
- ਦੁਆਰਾ ਪ੍ਰੇਰਿਤ ਨਮੂਨਾ ਡੇਟਾ ਅਤੇ ਐਪਲੀਕੇਸ਼ਨ ਦ੍ਰਿਸ਼ DataCamp SQL ਸਰੋਤ .