簡體   English   中英

如何在HQL中調用沒有表名的存儲過程?

[英]How can I call a stored procedure without table names in HQL?

我正在嘗試通過HQL中的存儲過程獲取當前時間戳。 這意味着我的代碼如下所示:

var currentTimestamp =
    session.CreateQuery("SELECT CURRENT_TIMESTAMP()")
           .UniqueResult<DateTime>();

這行不通。 具體來說,它將在NHibernate HqlParser.cs文件的內部深處引發System.NullReferenceException 我對此進行了一些嘗試,並改為使用以下內容:

var currentTimestamp =
    session.CreateQuery("SELECT CURRENT_TIMESTAMP() FROM Contact")
           .SetMaxResults(1)
           .UniqueResult<DateTime>();

現在,我有了所需的數據,但沒有HQL查詢。 我希望查詢代表我要問的問題-就像我的原始格式一樣。

這里一個明顯的問題是“為什么要使用HQL?” 我知道我可以輕松地通過session.CreateSQLQuery(...)直接訪問我們的MySQL 5.1數據庫。 這只是我的核心問題的一個示例,其根本原因是我在整個代碼庫中都使用了自定義的無參數HQL函數,並且我希望集成測試能夠盡可能地隔離地運行這些無HQL參數的函數可能。

我的黑客也有一些嚴肅的假設。例如,如果Contact表中沒有記錄,或者Contact表不再存在,它將不會返回結果。

在數據庫表的上下文之外檢索CURRENT_TIMESTAMP()(或任何其他數據庫函數)的方法因數據庫而異-有些允許,有些則不允許。 例如,Oracle不允許沒有表的選擇,因此它們為系統表提供了一個只有一行的表,該行稱為DUAL。

我懷疑NHibernate在HQL中實現的主要功能是所有數據庫實現中共有的功能,因此沒有實現無表選擇。

我可以建議三種方法:

  1. 創建一個隱藏無表選擇的視圖,例如“將view dtm創建為select current_timestamp()作為datetime”

  2. 遵循Oracle的方法並創建一個實用程序表,其中包含一行,您可以將其用作選擇表

  3. 創建一個僅執行“ select current_timestamp()”的簡單存儲過程

暫無
暫無

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

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