খেজুরের একটি সিরিজ উত্পন্ন করার জন্য এটি সর্বোত্তম উপায়:
SELECT t.day::date
FROM generate_series(timestamp '2004-03-07'
, timestamp '2004-08-16'
, interval '1 day') AS t(day);
অতিরিক্ত date_trunc()
প্রয়োজন হয় না। date
( day::date
) এ cast ালাই স্পষ্টভাবে তা করে।
তবে date
ইনপুট প্যারামিটার হিসাবে তারিখের আক্ষরিক কাস্টিংয়ের কোনও অর্থ নেই । অ কনটায়ার, timestamp
সেরা পছন্দ । পারফরম্যান্সে সুবিধাটি কম, তবে এটি না নেওয়ার কোনও কারণ নেই। আর তুমি অযথা ডিএসটি (দিবালোক সময় সংরক্ষণ) জড়িত না থেকে রুপান্তরের সঙ্গে মিলিত নিয়ম না date
করতে timestamp with time zone
এবং ফিরে। নিচে দেখ.
সমতুল্য, কম স্বচ্ছ সংক্ষিপ্ত বাক্য গঠন:
SELECT day::date
FROM generate_series(timestamp '2004-03-07', '2004-08-16', '1 day') day;
বা তালিকার সেট-রিটার্নিং ফাংশন সহ SELECT
:
SELECT generate_series(timestamp '2004-03-07', '2004-08-16', '1 day')::date AS day;
AS
শব্দ হয় প্রয়োজনীয় গত বৈকল্পিক এ, Postgres কলাম ওরফে ভুল ব্যাখ্যা হবে day
অন্যথায়। এবং পোস্টগ্রিস 10 এর আগে আমি সেই বৈকল্পিকটিকে পরামর্শ দেব না - কমপক্ষে একই SELECT
তালিকায় একাধিক সেট-রিটার্নিং ফাংশন সহ না :
(একপাশে, শেষ বৈকল্পিক সাধারণত একটি ছোট মার্জিন দ্বারা দ্রুত হয়।)
কেন timestamp [without time zone]
?
এর বেশ কয়েকটি ওভারলোডেড ভেরিয়েন্ট রয়েছে generate_series()
। বর্তমানে (পোস্টগ্রিজ ১১):
SELECT oid::regprocedure AS function_signature
, prorettype::regtype AS return_type
FROM pg_proc
where proname = 'generate_series';
ফাংশন_সাইনচার | রিটার্ন_প্রকার
: --------------------------------------------------------- ------------------------------- | : --------------------------
জেনারেট_সারিজ (পূর্ণসংখ্যা, পূর্ণসংখ্যা, পূর্ণসংখ্যা) | পূর্ণসংখ্যা
জেনারেট_সারিজ (পূর্ণসংখ্যা, পূর্ণসংখ্যা) | পূর্ণসংখ্যা
জেনারেট_সরিজ (বিগিন্ট, বিগিন্ট, বিগিন্ট) | বিগিন্ট
জেনারেট_সরিজ (বিগিন্ট, বিগিন্ট) | বিগিন্ট
জেনারেট_সরিজ (সংখ্যাসূচক, সংখ্যাসূচক, সংখ্যাসূচক) | সংখ্যাযুক্ত
জেনারেট_সারিজ (সংখ্যাসূচক, সংখ্যাসূচক) | সংখ্যাযুক্ত
জেনারেট_সরিজ (সময় অঞ্চল ছাড়া টাইমস্ট্যাম্প, সময় অঞ্চল ছাড়া টাইমস্ট্যাম্প, ব্যবধান) | টাইম জোন ছাড়াই টাইমস্ট্যাম্প
জেনারেট_সারিজ (টাইম জোন সহ টাইমস্ট্যাম্প, টাইম জোন সহ টাইমস্ট্যাম্প, ইন্টারভাল) | সময় অঞ্চল সঙ্গে টাইমস্ট্যাম্প
( numeric
রূপগুলো Postgres 9.5 সঙ্গে যোগ করা হয় নি।) প্রাসঙ্গিক বেশী গত দুটি গাঢ় গ্রহণ এবং ফিরে timestamp
/ timestamptz
।
নেই কোন বৈকল্পিক গ্রহণ বা ফিরেdate
। ফিরে আসার জন্য একটি স্পষ্ট কাস্ট প্রয়োজন date
। timestamp
আর্গুমেন্টগুলির সাথে কলটি ফাংশন ধরণের রেজোলিউশন বিধিগুলিতে না নেমে এবং ইনপুটটির জন্য অতিরিক্ত castালাই ছাড়াই সেরা রূপটিতে সমাধান হয়।
timestamp '2004-03-07'
সম্পূর্ণরূপে বৈধ, বিটিডাব্লু। বাদ দেওয়া সময়ের অংশটি 00:00
আইএসও ফর্ম্যাটের সাথে ডিফল্ট ।
ফাংশন ধরণের রেজোলিউশনের জন্য ধন্যবাদ আমরা এখনও পাস করতে পারি date
। তবে এর জন্য পোস্টগ্র্রেসের আরও কাজ প্রয়োজন। একটা হল অন্তর্নিহিত ঢালাই থেকে date
থেকে timestamp
থেকে এক সেইসাথে date
থেকে timestamptz
। দ্ব্যর্থক হতে পারে, কিন্তু timestamptz
করা হয় "পছন্দের" "তারিখ / সময় ধরনের" মধ্যে। সুতরাং ম্যাচটি 4 য় ধাপে স্থির হয় । :
সমস্ত প্রার্থীর মধ্য দিয়ে চলুন এবং পছন্দের ধরণগুলি (ইনপুট ডেটা টাইপের ধরণের বিভাগ) গ্রহণ করে এমন বেশিরভাগ পজিশনে রাখুন যেখানে টাইপ রূপান্তরকরণের প্রয়োজন হবে। কেউ পছন্দসই ধরণের গ্রহণ না করে সমস্ত প্রার্থী রাখুন। যদি কেবলমাত্র একজন প্রার্থী থাকেন তবে এটি ব্যবহার করুন; অন্যথায় পরবর্তী পদক্ষেপ অবিরত।
ফাংশন ধরণের রেজোলিউশনে অতিরিক্ত কাজ ছাড়াও এটি একটি অতিরিক্ত addsালাই যুক্ত করে timestamptz
- যা কেবলমাত্র আরও বেশি দাম যোগ করে না, এটি ডিএসটি-র সাথে সমস্যাগুলিও চালু করতে পারে যা বিরল ক্ষেত্রে অপ্রত্যাশিত ফলাফলের দিকে পরিচালিত করে। (ডিএসটি একটি মরোনিক ধারণা, বিটিডব্লু, এটি যথেষ্ট চাপ দিতে পারে না)) সম্পর্কিত:
আমি আরও ব্যয়বহুল ক্যোয়ারী প্ল্যান দেখিয়ে ফিডলে ডেমো যুক্ত করেছি:
ডিবি <> ফিডল এখানে
সম্পর্কিত: