با استفاده از تابع LN در MySQL مقدار لگاریتم طبیعی ستون amount را برای رکوردهایی که مقدار amount بزرگتر از صفر هستند محاسبه و بهصورت ستون new_ln نمایش دهید.
1.0 بازدید آخرین ویرایش در 202 روز قبل ساعت 02:28 0.0
برای حل این مسئله از MySQL و تابع توکار LN() استفاده کنید؛ مثلاً: SELECT id, amount, LN(amount) AS new_ln FROM your_table WHERE amount > 0; توجه کنید که LN برای مقادیر صفر یا منفی تعریفنشده است، بنابراین از شرط WHERE amount > 0 یا ساختار CASE WHEN amount > 0 THEN LN(amount) ELSE NULL END استفاده کنید. برای دقیقتر شدن نتایج میتوانید مقدار را به DECIMAL یا FLOAT تبدیل کنید و نام جدول/ستونها را مطابق دیتابیس خود جایگزین نمایید.
1 پاسخ
جدید ترین قدیمی ترین بالاترین امتیاز پاسخ های من
در حال بارگیری...
برای ارسال پاسخ باید با حساب کاربری وارد شوید.
ورود به حساب کاربری
توجه داشته باشید LN مقدارهای مثبت را محاسبه میکند و برای مقدارهای صفر یا منفی تعریف نشده است، پس داشتن شرط amount > 0 یا استفاده از CASE ضروری است. اگر مقدار amount مقدار NULL هم میتواند داشته باشد، LN(NULL) برابر NULL است و خروجی شما را مختل میکند، بنابراین یا فیلتر NULL را کنار بگذارید یا با CASE/COALESCE مدیریت کنید. برای دقت بیشتر میتوانید مقدار amount را قبل از محاسبه به DECIMAL یا FLOAT تبدیل کنید (مثلاً CAST(amount AS DECIMAL(10,2)) یا مشابه) تا اندازه اعشار مشخصی داشته باشید. و برای کارایی بهتر، در صورت امکان روی amount ایندکس ایجاد کنید تا شرط WHERE مقدارهای مثبت سریعتر فیلتر شوند.
گزارش