What is STORED PROCEDURE?
A stored procedure is a pre-compiled SQL subroutine used to perform multiple procedural operations.
What will we cover in this article?
How to call MSSQL and MYSQL stored procedure in Hibernate?
What should be taken care while executing stored procedure in Hibernate?
A stored procedure is a pre-compiled SQL subroutine used to perform multiple procedural operations.
"A stored procedure is a subroutine available to applications that access a relational database system" - WikiPedia
"A stored procedure is a group of Transact-SQL statements compiled into a single execution plan" - Microsoft
"A stored procedure is a group of Transact-SQL statements compiled into a single execution plan" - Microsoft
What will we cover in this article?
- Sample MSSQL and MYSQL stored procedure.
- How to call MSSQL and MYSQL stored procedure.
- What should be taken care while executing stored procedure in Hibernate
MSSQL Sample Stored Procedure
IF (OBJECT_ID('SP_MSSQL_HIBERNATE') IS NOT NULL) DROP PROCEDURE SP_MSSQL_HIBERNATE GO CREATE PROCEDURE SP_MSSQL_HIBERNATE @PARAM1 INT, @PARAM2 INT, @PARAM3 VARCHAR(50) AS BEGIN BEGIN TRANSACTION BEGIN TRY /* * Uncomment below code to get custom row in hibernate. * ------------------------------------------------ * DECLARE @X, @Y INT; * DECLARE @RESULT INT; * SET @RESULT = @X + @Y; * SELECT @RESULT AS RESULT, 'javaQuery' AS STRING_RESULT; */ /* Your custom operation */ UPDATE user_master SET Firstname = @PARAM3 WHERE UID = 1; /* Insert record */ INSERT INTO user_master (Firstname, Lastname) VALUES('Jennifer ', 'Lawrence'); /* Returns user object (row) */ SELECT * FROM user_master WHERE UID = 1; COMMIT TRANSACTION; END TRY BEGIN CATCH ROLLBACK TRANSACTION; PRINT @@ERROR END CATCH; END
MYSQL Sample Stored Procedure
DROP PROCEDURE IF EXISTS SP_MYSQL_HIBERNATE; DELIMITER $ CREATE PROCEDURE SP_MYSQL_HIBERNATE(IN PARAM1 INT, IN PARAM2 INT, IN PARAM3 VARCHAR(100)) BEGIN /* * Uncomment below code to get custom row in hibernate. * ------------------------------------------------ * DECLARE X, Y INT DEFAULT 10; * DECLARE RESULT INT; * SET RESULT = X + Y; * SELECT RESULT AS RESULT, 'javaQuery' AS STRING_RESULT; */ /* Your custom operation */ UPDATE user_master SET Firstname = PARAM3 WHERE UID = 1; /* Insert record */ INSERT INTO user_master (Firstname, Lastname) VALUES('Jennifer ', 'Lawrence'); /* Returns user object (row) */ SELECT * FROM user_master WHERE UID = 1; END $ DELIMITER ;
How to call MSSQL and MYSQL stored procedure in Hibernate?
/** * Create hibernate configuration. */ Configuration c = new Configuration(); c.configure("hibernate.cfg.xml"); /** * Open session and begin database transaction for database operation. */ SessionFactory sf = c.buildSessionFactory(); Session session = sf.openSession(); Transaction t = session.beginTransaction(); /** * Create SQL Query for Stored Procedure and pass required parameters. * MSSQL : EXEC Name_Of_Stored_Procedure :param1, :param2 * MYSQL : CALL Name_Of_Stored_Procedure :param1, :param2 * * `.addEntity(User.class)` will map output result as per User bean. */ /**************************************************/ /* Call MSSQL Stored Procedure and MAP it to bean */ /* Un-comment the code */ /**************************************************/ /*Query callStoredProcedure_MSSQL = session.createSQLQuery("EXEC SP_MSSQL_HIBERNATE :param1, :param2, :param3").addEntity(User.class); callStoredProcedure_MSSQL.setInteger("param1", 10); callStoredProcedure_MSSQL.setInteger("param2", 10); callStoredProcedure_MSSQL.setString("param3", "javaQuery");*/ /* callStoredProcedure_MSSQL.list() will execute stored procedure and return the value */ /*ListAbove code contains 3 portion for execution. Un-comment your required code and test it.userList = callStoredProcedure_MSSQL.list(); if (userList != null && !userList.isEmpty()) { for(User user : userList){ System.out.println("Firstname:"+user.getFirstname()); } }*/ /**************************************************/ /* Call MYSQL Stored Procedure and MAP it to bean */ /**************************************************/ Query callStoredProcedure_MYSQL = session.createSQLQuery("CALL SP_MYSQL_HIBERNATE (:param1, :param2, :param3)").addEntity(User.class); callStoredProcedure_MYSQL.setInteger("param1", 10); callStoredProcedure_MYSQL.setInteger("param2", 10); callStoredProcedure_MYSQL.setString("param3", "javaQuery"); /* callStoredProcedure_MSSQL.list() will execute stored procedure and return the value */ List userList = callStoredProcedure_MYSQL.list(); if (userList != null && !userList.isEmpty()) { for(User user : userList){ System.out.println("Firstname:"+user.getFirstname()); } } /******************************************************************/ /* Process custom result of Stored Procedure */ /* Un-comment the code, This will be the same for MSSQL and MYSQL */ /******************************************************************/ /*Query callStoredProcedure_MYSQL = session.createSQLQuery("CALL SP_MYSQL_HIBERNATE (:param1, :param2, :param3)"); callStoredProcedure_MYSQL.setInteger("param1", 10); callStoredProcedure_MYSQL.setInteger("param2", 10); callStoredProcedure_MYSQL.setString("param3", "javaQuery");*/ /* callStoredProcedure_MYSQL.list() will execute stored procedure and return the value */ /*List customResult = callStoredProcedure_MYSQL.list(); if (customResult != null && !customResult.isEmpty()) { Object[] obj = customResult.get(0); System.out.println(obj[0]); System.out.println(obj[1]); }*/ /* Commit the transaction and close session. */ t.commit(); session.close();
- How to Execute MSSQL Stored Procedure in Hibernate (code is commented)
- How to Call MYSQL Stored Procedure in Hibernate
- How to Process custom result of Stored Procedure in Hibernate (code is commented)
What should be taken care while executing stored procedure in Hibernate?
- If you have single Insert, Update or Delete operation in your stored procedure then you have to beginTransactin() and commit() it in order to take effect.
- Hibernate will only select first result of stored procedure. e.g: If you write two select statement then first result will be mapped for hibernate in case of bean and without bean it'll only return first result as list of object.
- If you are calling MSSQL stored procedure then SQL query must be without Parentheses ( and ).
e.g EXEC SP_MSSQL_HIBERNATE :param1, :param2, :param3 - If you are calling MYSQL stored procedure then SQL query must be with Parentheses ( and ).
e.g CALL SP_MYSQL_HIBERNATE (:param1, :param2, :param3)
No comments:
Post a Comment