Nikhil Ghuse Nikhil Ghuse - 1 year ago 114
MySQL Question

How to execute mysql stored procedure in Nhibernante

I want to create nhibernate query for my Mysql stored procedure

Answer Source

Hi Nhikhil,

Your question is good.

it's very easy to call stored Procedure through Nhibernate first you create stored procedure name as SelectListEmployeeSP in mysql

as follows:

CREATE PROCEDURE `SelectListEmployeeSP`()
SELECT * FROM Employee e;

And then create .bhm.xml file and write your return values as follows:

<?xml version="1.0" encoding="utf-8"?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2">
    <sql-query name="SelectListEmployeeSP">
        <return-scalar column="ID" type="integer"/>
        <return-scalar column="Name" type="string"/>
        <return-scalar column="Address" type="string"/>
        call SelectListEmployeeSP

And then call this procedure from .cs file as follows:

public void GetListEmployee()
            var employee = NHSession.GetNamedQuery("SelectListEmployeeSP")
                                    .Select(obj => new EmployeeEntity
                                        ID = Convert.ToInt32(obj[0]),
                                        Name = obj[1].ToString(),
                                        Address = obj[2].ToString()

After execute above code you will get the all employee list.

Thanks and Regards - Ankush

Recommended from our users: Dynamic Network Monitoring from WhatsUp Gold from IPSwitch. Free Download