رفع خطای ORA‑۰۱۵۵۵: Snapshot Too Old در Queryهای طولانی اوراکل
اگر از برنامهنویسان یا DBAهای باتجربهی Oracle باشید، احتمالاً حداقل یک بار با ارور کلاسیک زیر روبهرو شدهاید: ORA-01555: snapshot too old: rollback segment number with name "" too small این خطا نهتنها یکی از پراستفادهترین ارورها در دیتابیسهای بزرگ است، بلکه نشانهای از عدم تعادل میان Undo Tablespace، مدت…
چرا Sequence در Bulk Insert اوراکل مقدار تکراری میدهد؟ | علت و راهکار قطعی
در هر سیستم دیتابیسی، ساخت شناسههای یکتا یکی از پایههای معماری داده است.در Oracle، ابزار این کار معمولاً Sequence است؛ اما زمانی که از دستورهای جمعی مثل Bulk Insert یا Parallel Insert استفاده میکنیم، گاهی مشاهده میشود که Sequence مقادیر تکراری یا نامرتب تولید میکند.این اتفاق به ظاهر عجیب، علتهای…
آموزش عملی پکیج DBMS_SQLTUNE برای بهینهسازی کوئریهای سنگین
سلام به همهی برنامه نویس های عزیز 👋اگه تاحالا با کوئریهایی سروکله زدی که کند و اعصابخردکن هستن و هر کاری میکنی Query Plan مثل لاکپشت جلو میره، باید بدونی وقت استفاده از پکیج جادویی DBMS_SQLTUNE هست!این ابزار رسمی Oracle Database از نسخهی 10g معرفی شد و الان توی نسخههای…
چرا PDB در Oracle 23ai Mount نمیشود؟ بررسی خطاهای معماری Container
اگر با Oracle 23ai کار کرده باشی، احتمالاً با این سناریو مواجه شدی: دیتابیس اصلی (CDB) بهدرستی باز میشود، اما یکی از PDBها در مرحلهی Mount گیر میکند! در ظاهر شاید ساده به نظر برسد، اما پشت این اتفاق مفاهیم عمیقی از معماری چندمستأجر اوراکل (Multitenant Architecture) پنهان است. در…
چرا Query من در Oracle 19c کند اجرا میشود؟
وقتی یه Query در Oracle 19c کند میشه، اولین چیزی که ممکنه به ذهنت برسه اینه که “حتماً دیتام زیاده” یا “سیستم ضعیفه!”.اما واقعیت اینه که کندی همیشه از حجم داده یا سختافزار نیست — معمولاً یه گره نامرئی، یعنی Bottleneck واقعی داره که باید قدمبهقدم پیدا بشه.بیاین با هم…
آموزش کامل پکیج UTL_TCP در Oracle — راهنمای کاربردی برای برقراری ارتباطات TCP از درون PL/SQL
در دنیای امروزی که ارتباطات نرمافزارها از طریق شبکه حرف اول را میزند، اوراکل هم برای توسعهدهندگانی که به ارتباطات سطح پایین نیاز دارند، ابزار قدرتمندی در اختیار گذاشته:پکیجی به نام UTL_TCP.با استفاده از این پکیج میتوانی از درون دیتابیس مستقیماً با هر سرویس TCP ارتباط بگیری؛چه یک سرور داخلی…
برگشت چندین رکورد درجشده با قابلیت Multi‑Row Returning در Oracle 23ai
اگر تا حالا با اوراکل کار کرده باشی، احتمالاً با دستور INSERT و قابلیت RETURNING INTO آشنا هستی. این امکان همیشه به ما اجازه میداد بعد از درج رکورد، مقادیر موردنظر (مثل ID یا هر ستون دیگر) را همان لحظه به دست بیاوریم، اما فقط برای یک رکورد! مشکل اینجا…
مقایسه CTE (WITH Clause) و Subqueryها از منظر Performance در Oracle
اگر با Oracle SQL کار کرده باشی، حتماً با دو روش اصلی برای شکستن کوئریهای پیچیده آشنا هستی:استفاده از CTE یا همان WITH Clauseاستفاده از Subqueryهای معمولیهر دو روش ظاهراً همان هدف را دنبال میکنند، اما از نگاه Performance (کارایی و سرعت اجرا) تفاوتهای مهمی دارند که در تصمیمگیریهای روزمره…
معماری Multi‑Tenant در Oracle: مزایا، چالشها و کاربردها
با رشد سریع دادهها و نیاز شرکتها به بهینهسازی زیرساختهای پایگاه داده، معماری Multi‑Tenant در Oracle بهعنوان یک تحول جدی وارد میدان شد.این معماری ابتدا با معرفی Oracle Database 12c پا به عرصه گذاشت و با فراهم کردن امکان مدیریت چند پایگاه داده مستقل (PDB) در بستر یک پایگاه داده…
درج چند رکورد با یک دستور در Oracle 23ai — آموزش کامل Multi‑Row Insert
در بانکهای اطلاعاتی Oracle Database، دستور INSERT معمولاً برای اضافه کردن یک رکورد استفاده میشود.اما در خیلی از پروژهها نیاز داریم چند ردیف را با یک دستور واحد وارد کنیم تا هم کد کوتاهتر و خواناتر شود، هم سرعت اجرای عملیات بالاتر برود.در نسخه جدید Oracle 23ai این امکان به…
