sql >> データベース >  >> RDS >> Sqlserver

複合型のEntity Framework 5でストアドプロシージャを使用していますか?

    答えを見つけました。
    ストアド プロシージャを次のように変更しました:

    ALTER PROCEDURE [dbo].[FullTextSearchOnContent]
    (
        @SearchText NVARCHAR(200),
        @LanguageId INT ,
        @ContentStatusId INT ,
        @ResultCount INT 
    )
    AS
    
    BEGIN
        SET NOCOUNT ON;
    
        DECLARE @ReturnTable table 
        (
            ContentId int not null,
            LanguageId int null,
            ContentStatusId int null,
            ContentTitle nvarchar(2000) null,
            ContentSummary nvarchar(2000) null,
            ContentImagePath nvarchar(50) null,
            IsSpecial bit null,
            LockCommenting bit null,
            VisitNumber int null,
            AllTagsString nvarchar(max) null,
            ContentRegistrationDate datetime not null,
            ContentStatusFarsiName nvarchar(50) null,
            UserId int null,
            UserInitialReputation int null,
            IsUserAdmin bit null,
            UserFullName nvarchar(71) null,
            UserPhotoPath nvarchar(50) null,
            UserRoleId int null,
            UserStatusId int null,
            SubjectId int not null,
            SubjectName nvarchar(50) null,
            SubjectSymbolPath nvarchar(1000) null
        )
        IF (@SearchText IS NULL) OR (@SearchText = '') OR (@ResultCount IS NULL) OR (@ResultCount = 0) RETURN NULL;
        INSERT @ReturnTable 
            SELECT DISTINCT TOP(@ResultCount) 
                C.Id AS ContentId, 
                C.LanguageId,
                C.StatusId AS ContentStatusId,
                C.Title AS ContentTitle,
                C.Summary AS ContentSummary,
                C.ImagePath AS ContentImagePath, 
                C.IsSpecial,
                C.LockCommenting,
                C.VisitNumber,
                C.AllTagsString,
                C.RegistrationDate AS ContentRegistrationDate,
                CS.FarsiName AS ContentStatusFarsiName,
                U.Id As UserId,
                U.InitialReputation AS UserInitialReputation,
                U.IsAdmin AS IsUserAdmin,
                U.FullName AS UserFullName,
                U.PhotoPath AS UserPhotoPath,
                U.RoleId AS UserRoleId,
                U.UserStatusId AS UserStatusId,
                S.Id AS SubjectId,
                S.Name AS SubjectName, 
                S.SymbolPath AS SubjectSymbolPath
                --,T.Id AS TagId, T.Name AS TagName
                FROM Content AS C
            INNER JOIN [User] AS U ON U.Id = C.WriterId
            INNER JOIN [Subject] AS S ON S.Id = C.SubjectId
            INNER JOIN [ContentStatus] AS CS ON CS.Id = C.StatusId
            --INNER JOIN (SELECT DISTINCT * FROM Tag AS T
            --          INNER JOIN TagContent AS TC ON TC.TagId=T.Id) 
            --          AS T ON T.ContentId = C.Id
            WHERE C.LanguageId = @LanguageId AND [email protected] AND CONTAINS((C.Title,C.AllTagsString),@SearchText) ORDER BY C.RegistrationDate DESC
        select * from @ReturnTable
        --SELECT TOP(@ResultCount) * from Content order by RegistrationDate desc
    END
      

    今では魅力のように機能します:-)




    1. オラクルはDD-MON-YYをDD/MM/YYYYに変換します

    2. ORA-28113:ポリシー述語にエラーがあります

    3. MySQL:エラーコード:1242サブクエリが複数の行を返す

    4. MySQLエラー1(HY000)ファイルErrcode2の作成で問題が発生しました