با استفاده از تابع BIT_COUNT در MySQL، برای جدول numbers که شامل ستون id و value است، تعداد بیت‌های 1 در هر مقدار value را محاسبه کرده و نتیجه را به‌صورت ستون bits و مرتب‌شده بر اساس bits به ترتیب نزولی نمایش دهید.

16.0 بازدید آخرین ویرایش در 198 روز قبل ساعت 02:55

0.0

برای حل این مسأله کافی است از تابع داخلی BIT_COUNT در MySQL استفاده کنید؛ مثلاً SELECT id, value, BIT_COUNT(value) AS bits FROM numbers ORDER BY bits DESC; اگر ستون value مقادیر منفی دارد، قبل از شمارش می‌توانید آن را به UNSIGNED تبدیل کنید (CAST(value AS UNSIGNED)) تا نتایج مورد انتظار بدست آید. از alias برای نام‌گذاری ستون خروجی و از ORDER BY برای مرتب‌سازی استفاده کنید.

توسط پژوهشگر در 198 روز قبل ساعت 02:55
دسته بندی ها: MySQL MySQL for beginner
sara در 198 روز قبل ساعت 02:56

تابع BIT_COUNT در MySQL برای شمارش بیت‌های 1 مفید و ساده است، اما توجه کنید که روی مقادیر منفی نتیجه مطابق انتظار نخواهد بود و در صورت نیاز بهتر است ابتدا با CAST(value AS UNSIGNED) تبدیل کنید. اگر ستون value ممکن است NULL باشد، قبل از فراخوانی تابع مقداردهی پیش‌فرض یا فیلتری اعمال کنید تا از نتایج غیرمنتظره جلوگیری شود. همچنین این محاسبه در عبارت SELECT به صورت محاسبات زمانی اجرا می‌شود و استفاده مکرر روی جداول بزرگ می‌تواند هزینه‌بر باشد؛ در صورت پرس‌وجوهای پرتکرار می‌توانید مقدار بیت‌ها را به‌صورت ستونی محاسبه‌شده یا ایندکس‌شده نگهداری کنید. همیشه از alias برای خوانایی و از ORDER BY برای مرتب‌سازی نتایج استفاده کنید.

گزارش

1 پاسخ

جدید ترین قدیمی ترین بالاترین امتیاز پاسخ های من

در حال بارگیری...
ورود به حساب کاربری