কেউ আমাকে একটি SQL কোয়েরি প্রেরিত যেখানে GROUP BY
দফা বিবৃতি গঠিত: GROUP BY 1
।
এটি ঠিক টাইপো হতে হবে? কোনও কলামে উপনাম 1 দেওয়া হয় না এর অর্থ কী হতে পারে? আমি কি ঠিক ধরে নিচ্ছি যে এটি অবশ্যই টাইপো হবে?
কেউ আমাকে একটি SQL কোয়েরি প্রেরিত যেখানে GROUP BY
দফা বিবৃতি গঠিত: GROUP BY 1
।
এটি ঠিক টাইপো হতে হবে? কোনও কলামে উপনাম 1 দেওয়া হয় না এর অর্থ কী হতে পারে? আমি কি ঠিক ধরে নিচ্ছি যে এটি অবশ্যই টাইপো হবে?
উত্তর:
SELECT account_id, open_emp_id
^^^^ ^^^^
1 2
FROM account
GROUP BY 1;
উপরের প্রশ্নের GROUP BY 1
মধ্যে first column in select statement
যা
বোঝায় account_id
।
আপনি নির্দিষ্ট করতে পারেন ORDER BY
।
দ্রষ্টব্য: অর্ডার বা গ্রুপ দ্বারা সংখ্যা সর্বদা 0 দিয়ে নয় 1 দিয়ে শুরু হয়।
ক্ষেত্রের নাম অনুসারে দলবদ্ধকরণের পাশাপাশি, আপনি সারণীর মধ্যে ক্ষেত্রের অর্ডিনাল বা অবস্থানের দ্বারাও গ্রুপ করতে পারেন group 1 প্রথম ক্ষেত্রের সাথে মিল রাখে (নাম নির্বিশেষে), 2 দ্বিতীয় হয়, এবং আরও অনেক কিছু।
সারণী / দর্শন কাঠামোর পরিবর্তন হতে পারে বলে আপনি নির্দিষ্ট কিছুতে গ্রুপিং করা থাকলে এটি সাধারণত অসুস্থ পরামর্শ দেওয়া হয়। অতিরিক্তভাবে, আপনি যদি টেবিলের ক্ষেত্রগুলি মুখস্ত না করে থাকেন তবে আপনার এসকিউএল কোয়েরিটি কী করছে তা দ্রুত বুঝতে অসুবিধা হতে পারে।
আপনি যদি কোনও অনন্য সেট ফিরে আসছেন বা দ্রুত কোনও অস্থায়ী অনুসন্ধান করছেন, তবে টাইপিং হ্রাস করার জন্য এটি দুর্দান্ত শর্টহ্যান্ড সিনট্যাক্স। আপনি যদি আবার কোয়েরিটি চালানোর পরিকল্পনা করেন তবে ভবিষ্যতের বিভ্রান্তি এবং অপ্রত্যাশিত জটিলতা (স্কিম পরিবর্তনের কারণে) এড়াতে তাদের প্রতিস্থাপনের পরামর্শ দেব
এটি নির্বাচন ক্ষেত্রের প্রথম ক্ষেত্র অনুসারে গ্রুপ করবে
এর অর্থ আপনার নির্বাচিত ধারাটিতে 1 ম কলাম অনুসারে বর্গক্ষেত্র গোষ্ঠী, আমরা সর্বদা এটির GROUP BY 1
সাথে একসাথে ব্যবহার ORDER BY 1
করি GROUP BY 1,2,3..
, এটির পাশাপাশি আপনি এটি ব্যবহার করতে পারেন অবশ্যই এটি আমাদের পক্ষে সুবিধাজনক তবে আপনাকে সেই অবস্থার দিকে মনোযোগ দেওয়া দরকার ফলাফলটি আপনি তা নাও করতে পারেন যদি কেউ আপনার নির্বাচিত কলামগুলি সংশোধন করে থাকে এবং এটি ভিজ্যুয়ালাইজড না হয় তা চাই
এটি ধারা অনুসারে গ্রুপটির পরে আপনি যে কলামের অবস্থানটি রেখেছেন তা গোষ্ঠীভুক্ত করবে।
উদাহরণস্বরূপ আপনি চালাতে 'যদি SELECT SALESMAN_NAME, SUM(SALES) FROM SALES GROUP BY 1
' এটি দ্বারা গ্রুপ হবে SALESMAN_NAME
।
এটি করার ক্ষেত্রে একটি ঝুঁকি হ'ল যদি আপনি চালিত হন ' Select *
' এবং কোনও কারণে আপনি কলামগুলি দিয়ে একটি আলাদা ক্রমে টেবিলটি পুনরায় তৈরি করেন, এটি আপনাকে প্রত্যাশার চেয়ে আলাদা ফলাফল দেয়।