मैं कम से कम दो विकल्प के बारे में सोच सकते हैं ...
CREATE TABLE constants (
id AS INT,
Illustrated AS VARCHAR(3),
FrontPage AS VARCHAR(3),
BackPage AS VARCHAR(3),
EDLP AS VARCHAR(3),
SpecialPromo AS VARCHAR(3)
)
INSERT INTO constants SELECT 1, 'I', 'FP', 'BP', 'ELP', 'PR'
SELECT
Name,
CASE WHEN CHARINDEX(constants.Illustrated, data.S_Data) > 0 THEN 1 ELSE 0 END AS Illustrated,
etc, etc
FROM
data
INNER JOIN
constants
ON constants.id = 1
या ...
CREATE TABLE constants (
constant_set_id AS INT,
constant_name AS VARCHAR(16),
value AS AS VARCHAR(3)
)
INSERT INTO constants SELECT 1, 'Illustrated', 'I'
INSERT INTO constants SELECT 1, 'FrontPage', 'FP'
INSERT INTO constants SELECT 1, 'BackPage', 'BP'
INSERT INTO constants SELECT 1, 'EDLP', 'ELP'
INSERT INTO constants SELECT 1, 'SpecialPromo', 'PR'
SELECT
Name,
MAX(CASE WHEN constants.constant_name = 'Illustrated' AND CHARINDEX(constants.value, data.S_Data) > 0 THEN 1 ELSE 0 END) AS Illustrated,
etc, etc
FROM
data
INNER JOIN
constants
ON constants.constant_set_id = 1
GROUP BY
data.name
दोनों आप स्थिरांक के कई विभिन्न सेट डालते हैं। एक स्कीमा को बदले बिना विस्तार योग्य है, हालांकि क्वेरी को अभी भी बदलने की आवश्यकता होगी।
किसी भी दृष्टिकोण का मुख्य लाभ यह है कि आप स्थिरांक को फिर से उपयोग कर सकते हैं, लेकिन उन्हें एक बार केंद्रीकृत स्थान में स्टोर कर सकते हैं। जो केवल तभी प्रासंगिक होता है जब स्थिरांक में मानों को अपडेट करने की आवश्यकता होती है। संकेत के माध्यम से पुनः प्रयोग करें।
सुनिश्चित करें कि आप कितना लाभ होगा, के बाद से मैं आप अभी भी हार्डकोडेड स्तंभ नाम चाहते हैं ('Illustrated' संभालने हूँ, 'फ्रंट पेज', आदि) आपके परिणाम सेट में उन मानों से जुड़े हैं। –
इस चयन के लिए एक दृश्य बनाने के बारे में क्या? –
जो मैंने सोचा था - यानी, "क्या यह इसके लायक है?" – Perplexed