簡體   English   中英

使用EF6和Mysql數據庫的存儲過程映射

[英]Stored procedure mapping using EF6 and Mysql database

我有使用實體框架6和Mysql Database的 ac#應用程序。 我添加了此存儲過程:

DELIMITER $$
CREATE DEFINER=`root`@`localhost` PROCEDURE `ps_reservation`(IN id_compte varchar(128))
BEGIN
    if id_compte is null then
        SELECT
            `ajtdev`.`ajt_demande`.`id` AS `id_demande`,
            `ajtdev`.`ajt_demande`.`date_intervention` AS `date_intervention`,
            `ajtdev`.`ajt_demande`.`from_time` AS `from_time`,
            `ajtdev`.`ajt_demande`.`to_time` AS `to_time`,
            `ajtdev`.`ajt_demande`.`id_begin_place` AS `id_from_place`,
            `ajtdev`.`ajt_demande`.`id_end_place` AS `id_to_place`,
            `ajtdev`.`ajt_demande`.`bot` AS `bot`,
            `ajtdev`.`ajt_client`.`nom` AS `nom_client`,
            `ajtdev`.`ajt_client`.`prenom` AS `prenom_client`,
            `ajtdev`.`ajt_coordonne`.`tel` AS `tel_client`,
            `ajtdev`.`ajt_statut_demande`.`libelle` AS `statut_demande`,
            `ajtdev`.`ajt_vehicle`.`immarticulation` AS `immarticulation_vehicle`,
            `ajtdev`.`ajt_vehicle`.`marque` AS `marque_vehicle`,
            `ajtdev`.`ajt_collaborator`.`id` AS `id_chauffeur`,
            `ajtdev`.`ajt_collaborator`.`Nom` AS `nom_chauffeur`,
            `ajtdev`.`ajt_collaborator`.`Prenom` AS `prenom_chauffeur`,
            `ajtdev`.`ajt_collaborator`.`id_user_fk` AS `id_user`
        FROM
           `ajtdev`.`ajt_demande` JOIN `ajtdev`.`ajt_statut_demande` ON (`ajtdev`.`ajt_demande`.`id_statut` = `ajtdev`.`ajt_statut_demande`.`id`)
            JOIN `ajtdev`.`ajt_client` ON (`ajtdev`.`ajt_demande`.`id_client` = `ajtdev`.`ajt_client`.`id`)
            JOIN `ajtdev`.`ajt_coordonne` ON (`ajtdev`.`ajt_client`.`id_coordonne` = `ajtdev`.`ajt_coordonne`.`id`)
           JOIN `ajtdev`.`ajt_ass_veh_col` ON (`ajtdev`.`ajt_demande`.`id_ass_veh_col_fk` = `ajtdev`.`ajt_ass_veh_col`.`id`)
           JOIN `ajtdev`.`ajt_vehicle` ON ( `ajtdev`.`ajt_ass_veh_col`.`veh_id_fk`  = `ajtdev`.`ajt_vehicle`.`Id`)
           JOIN `ajtdev`.`ajt_collaborator` ON (`ajtdev`.`ajt_ass_veh_col`.`col_id_fk` = `ajtdev`.`ajt_collaborator`.`Id`)
        WHERE
            ISNULL(`ajtdev`.`ajt_demande`.`deletion_date`)
            and ISNULL(`ajtdev`.`ajt_collaborator`.`deletion_date`)
            and ISNULL(`ajtdev`.`ajt_client`.`deletion_date`)
            and ISNULL(`ajtdev`.`ajt_vehicle`.`deletion_date`);
    else
        SELECT
            `ajtdev`.`ajt_demande`.`id` AS `id_demande`,
            `ajtdev`.`ajt_demande`.`date_intervention` AS `date_intervention`,
            `ajtdev`.`ajt_demande`.`from_time` AS `from_time`,
            `ajtdev`.`ajt_demande`.`to_time` AS `to_time`,
            `ajtdev`.`ajt_demande`.`id_begin_place` AS `id_from_place`,
            `ajtdev`.`ajt_demande`.`id_end_place` AS `id_to_place`,
            `ajtdev`.`ajt_demande`.`bot` AS `bot`,
            `ajtdev`.`ajt_client`.`nom` AS `nom_client`,
            `ajtdev`.`ajt_client`.`prenom` AS `prenom_client`,
            `ajtdev`.`ajt_coordonne`.`tel` AS `tel_client`,
            `ajtdev`.`ajt_statut_demande`.`libelle` AS `statut_demande`,
            `ajtdev`.`ajt_vehicle`.`immarticulation` AS `immarticulation_vehicle`,
            `ajtdev`.`ajt_vehicle`.`marque` AS `marque_vehicle`,
            `ajtdev`.`ajt_collaborator`.`id` AS `id_chauffeur`,
            `ajtdev`.`ajt_collaborator`.`Nom` AS `nom_chauffeur`,
            `ajtdev`.`ajt_collaborator`.`Prenom` AS `prenom_chauffeur`,
            `ajtdev`.`ajt_collaborator`.`id_user_fk` AS `id_user`
        FROM
           `ajtdev`.`ajt_demande` JOIN `ajtdev`.`ajt_statut_demande` ON (`ajtdev`.`ajt_demande`.`id_statut` = `ajtdev`.`ajt_statut_demande`.`id`)
            JOIN `ajtdev`.`ajt_client` ON (`ajtdev`.`ajt_demande`.`id_client` = `ajtdev`.`ajt_client`.`id`)
            JOIN `ajtdev`.`ajt_coordonne` ON (`ajtdev`.`ajt_client`.`id_coordonne` = `ajtdev`.`ajt_coordonne`.`id`)
           JOIN `ajtdev`.`ajt_ass_veh_col` ON (`ajtdev`.`ajt_demande`.`id_ass_veh_col_fk` = `ajtdev`.`ajt_ass_veh_col`.`id`)
           JOIN `ajtdev`.`ajt_vehicle` ON ( `ajtdev`.`ajt_ass_veh_col`.`veh_id_fk`  = `ajtdev`.`ajt_vehicle`.`Id`)
           JOIN `ajtdev`.`ajt_collaborator` ON (`ajtdev`.`ajt_ass_veh_col`.`col_id_fk` = `ajtdev`.`ajt_collaborator`.`Id`)
        WHERE
            ISNULL(`ajtdev`.`ajt_demande`.`deletion_date`)
            and ISNULL(`ajtdev`.`ajt_collaborator`.`deletion_date`)
            and ISNULL(`ajtdev`.`ajt_client`.`deletion_date`)
            and ISNULL(`ajtdev`.`ajt_vehicle`.`deletion_date`)
            and CONVERT(`ajtdev`.`ajt_collaborator`.`id_user_fk` USING UTF8)= id_compte;
    end if;

END$$
DELIMITER ;

當我添加新的EF模型時,在上下文中,我得到此映射頁面:

 public virtual int ps_reservation(string id_compte)
{
    var id_compteParameter = id_compte != null ?
        new ObjectParameter("id_compte", id_compte) :
        new ObjectParameter("id_compte", typeof(string));

    return ((IObjectContextAdapter)this).ObjectContext.ExecuteFunction("ps_reservation", id_compteParameter);
}

我不明白為什么我得到這個方法簽名:

公用虛擬int ps_reservation(字符串id_compte)

我的意思是為什么返回類型是整數! 為什么不是ObjectResult<ps_reservation_Result>

  1. 此錯誤的原因是什么?
  2. 我該如何解決?

經過研究

我在這里找到解決方案

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM