Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 8816689
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 14, 20262026-06-14T04:40:36+00:00 2026-06-14T04:40:36+00:00

I need to set a constraint that the user is unable to enter any

  • 0

I need to set a constraint that the user is unable to enter any records after he/she has entered 5 records in a single month. Would it be advisable that I write a trigger or procedure for that? Else is that any other ways that I can setup the constraint?

Instead of writing a trigger i have opt to write a procedure for the constraint but how do i check if the procedure is working?

Below is the procedure:

CREATE OR REPLACE PROCEDURE InsertReadingCheck
        (
         newReadNo          In Int,
         newReadValue       In Int,
         newReaderID        In Int,
         newMeterID         In Int  
        )
AS 
  varRowCount               Int;

BEGIN

Select Count(*) INTO varRowCount
From Reading 
WHERE ReaderID = newReaderID
AND Trunc(ReadDate,'mm') = Trunc(Sysdate,'mm');     

IF (varRowCount >= 5) THEN
    BEGIN
        DBMS_OUTPUT.PUT_LINE('*************************************************');
        DBMS_OUTPUT.PUT_LINE('');
        DBMS_OUTPUT.PUT_LINE(' You attempting to enter more than 5 Records ');
        DBMS_OUTPUT.PUT_LINE('');
        DBMS_OUTPUT.PUT_LINE('*************************************************');
        ROLLBACK;
  RETURN;
    END;

ELSIF (varRowCount < 5) THEN
    BEGIN
        INSERT INTO Reading
            VALUES(seqReadNo.NextVal, sysdate, newReadValue,
            newReaderID, newMeterID);
  COMMIT;
END;
END IF;
END; 

Anyone can help me look through

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-14T04:40:37+00:00Added an answer on June 14, 2026 at 4:40 am

    This is the sort of thing that you should avoid putting in a trigger. Especially the ROLLBACK and the COMMIT. This seems extremely dangerous (and I’m not even sure whether it’s possible). You might have other transactions that you wish to commit that you rollback or vice versa.

    Also, by putting this in a trigger you are going to get the following error:

    ORA-04091: table XXXX is mutating, trigger/function may not see it

    There are ways round this but they’re excessive and involve doing something funky in order to get round Oracle’s insistence that you do the correct thing.

    This is the perfect opportunity to use a stored procedure to insert data into your table. You can check the number of current records prior to doing the insert meaning that there is no need to do a ROLLBACK.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I need to set the default icon that VS uses for the project to
I have a unique set of processes that all need to be automated. We
Need set zoom for camera preview...
I need set a cultureinfo different of others in a currency field. Metadata: [Display(ResourceType
I need Set collection, where its items will be identified by items class. Something
Need to set some attributes of button. For example Checked. I guess it is
I need to set query in my auth script, where in WHERE clause I
I need to set the color of the font every time I add text
I need to set custom alarm tone in my App. Could anyone please just
i need to set an integer to start from 001 instead of only 1

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.