AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / dba / Perguntas / 4162
Accepted
VaticNZ
VaticNZ
Asked: 2011-07-28 15:00:54 +0800 CST2011-07-28 15:00:54 +0800 CST 2011-07-28 15:00:54 +0800 CST

Erro 'Falha na conversão' com a expressão ORDER BY CASE

  • 772

Eu tenho o seguinte procedimento armazenado que funciona muito bem, EXCETO quando defino 'OrderBy' como 'OrderNumber'.

Recebo o seguinte erro: A conversão falhou ao converter o valor nvarchar 'SK11270' para o tipo de dados int.

(SK11270 é um valor na coluna OrderNumber que é nvarchar(50))

Se eu executar a consulta idêntica com qualquer outra coluna OrderBy, funcionará bem.

Estou completamente perdido e minha cabeça dói. Alguém pode ver algo óbvio que poderia estar causando esse problema?

Agradeço antecipadamente quaisquer ideias...

Rico

Isso funciona:

sp_jobs '1','20','','JobNumber','ASC','97','True','True','True','True','True','True','True','True','True','False','True','False','True','False','0'

Isso não:
sp_jobs '1','20','','OrderNumber','ASC','97','True','True','True','True','True','True','True','True','True','False','True','False','True','False','0'

PROCEDURE [dbo].[sp_Jobs] 

@PageNumber int,
@PageSize int,
@FilterExpression varchar(500),
@OrderBy varchar(50),
@OrderDirection varchar(50),
@CustomerID int,
@ShowNotSet bit,
@ShowPlaced bit,
@ShowProofed bit,
@ShowReProofed bit,
@ShowApproved bit,
@ShowOnTime bit,
@ShowLate bit,
@ShowProblem bit,
@ShowCompleted bit,
@ShowDispatched bit,
@ShowUnapproved bit,
@ShowClosed bit,
@ShowReturned bit,
@ShowNoStock bit,
@UserID int

WITH RECOMPILE 

AS

BEGIN
WITH    Keys 
AS (SELECT TOP (@PageNumber * @PageSize) ROW_NUMBER() OVER (
        ORDER BY
            CASE WHEN @OrderDirection = 'ASC' THEN
                CASE 
                  WHEN @OrderBy = 'JobNumber' THEN p1.JobNumber
                  WHEN @OrderBy = 'OrderNumber' THEN p1.OrderNumber 
                  WHEN @OrderBy = 'CustID' THEN p1.CustID
                  WHEN @OrderBy = 'Status' THEN p1.MasterJobStatusID  
                  WHEN @OrderBy = 'DateIn' THEN p1.DateIn
                  WHEN @OrderBy = 'DateDue' THEN p1.DateDue
                  WHEN @OrderBy = 'DateOut' THEN p1.DateOut 
                 ELSE NULL 
                END
            END ASC
            , CASE WHEN @OrderDirection = 'DESC' THEN
                CASE 
                  WHEN @OrderBy = 'JobNumber' THEN p1.JobNumber
                  WHEN @OrderBy = 'OrderNumber' THEN p1.OrderNumber 
                  WHEN @OrderBy = 'CustID' THEN p1.CustID
                  WHEN @OrderBy = 'Status' THEN p1.MasterJobStatusID  
                  WHEN @OrderBy = 'DateIn' THEN p1.DateIn
                  WHEN @OrderBy = 'DateDue' THEN p1.DateDue
                  WHEN @OrderBy = 'DateOut' THEN p1.DateOut           
                 ELSE NULL 
                END
            END DESC)  as rn ,P1.jobNumber,P1.CustID,P1.DateIn,P1.DateDue,P1.DateOut,p1.client,p1.MasterJobStatusID,p1.MasterJobStatusTimestamp,p1.OwnerID,p1.StockComplete,p1.OrderNumber
        FROM vw_Jobs_List P1  WITH (NOLOCK) 
        WHERE (@CustomerID = 0 OR CustID = @CustomerID) AND  (@UserID = 0 OR OwnerID = @UserID) AND ((@ShowNotSet = 1 AND MasterJobStatusID=1) OR (@ShowPlaced = 1 AND MasterJobStatusID=2) OR (@ShowProofed = 1 AND MasterJobStatusID=3)  OR (@ShowReProofed = 1 AND MasterJobStatusID=4)  OR
         (@ShowApproved = 1 AND MasterJobStatusID=5)  OR (@ShowOnTime = 1 AND MasterJobStatusID=6)  OR (@ShowLate = 1 AND MasterJobStatusID=7)  OR (@ShowProblem = 1 AND MasterJobStatusID=8)  OR (@ShowCompleted = 1 AND MasterJobStatusID=9)  OR
         (@ShowDispatched = 1 AND MasterJobStatusID=10) OR (@ShowUnapproved = 1 AND MasterJobStatusID=11)  OR (@ShowClosed = 1 AND MasterJobStatusID=12) OR  (@ShowReturned = 1 AND MasterJobStatusID=13) OR (@ShowNoStock=1 AND StockComplete=0))
         AND (Search LIKE '%'+@FilterExpression+'%')),SelectedKeys

AS  (SELECT TOP (@PageSize)SK.rn,SK.JobNumber,SK.CustID,SK.DateIn,SK.DateDue,SK.DateOut,SK.OrderNumber,SK.MasterJobStatusID
        FROM Keys SK 
        WHERE SK.rn > ((@PageNumber-1) * @PageSize))

        SELECT  SK.rn,J.JobNumber,J.OwnerID,J.Description,J.Client,SK.CustID,SK.OrderNumber, CAST(DateAdd(d, -2, CAST(isnull(SK.DateIn,0) AS DateTime)) AS nvarchar) AS DateIn, CAST(DateAdd(d, -2, CAST(isnull(SK.DateDue,0) AS DateTime)) AS nvarchar) AS DateDue,CAST(DateAdd(d, -2, CAST(isnull(SK.DateOut,0) AS DateTime)) AS nvarchar) AS DateOut, Del_Method,Ticket#, InvoiceEmailed, InvoicePrinted, InvoiceExported, InvoiceComplete, JobStatus,j.MasterJobStatusID,j.MasterJobStatusTimestamp,js.MasterJobStatus,StockComplete
        FROM SelectedKeys SK JOIN vw_Jobs_List J  WITH (NOLOCK)  ON j.JobNumber=SK.JobNumber JOIN tbl_SYSTEM_MasterJobStatus js  WITH (NOLOCK)  ON j.MasterJobStatusID=js.MasterJobStatusID

END
sql-server stored-procedures
  • 2 2 respostas
  • 7490 Views

2 respostas

  • Voted
  1. Best Answer
    gbn
    2011-07-28T15:14:35+08:002011-07-28T15:14:35+08:00

    Sua expressão CASE só pode ter um tipo de dados. Mas o seu está misturando tipos de dados e o mais alto está sendo usado (conforme precedência de tipo de dados ). Portanto, nvarchar é alterado para int com base nessas regras.

    Você precisa de um caso por tipo de dados ou por coluna

    Exemplo:

    CASE WHEN @OrderDirection = 'DESC' THEN
                     CASE 
                      WHEN @OrderBy = 'JobNumber' THEN J.JobNumber
                      WHEN @OrderBy = 'CustID' THEN J.CustID
                      WHEN @OrderBy = 'DateIn' THEN J.DateIn
                      WHEN @OrderBy = 'DateDue' THEN J.DateDue
                      WHEN @OrderBy = 'DateOut' THEN J.DateOut
                      WHEN @OrderBy = 'Status' THEN J.MasterJobStatusID 
                      ELSE NULL
                    END
                END DESC,
    CASE WHEN @OrderDirection = 'DESC' THEN
                     CASE 
                      WHEN @OrderBy = 'OrderNumber' THEN J.OrderNumber
                      ELSE NULL
                    END
                END DESC
    
    • 17
  2. Mark Storey-Smith
    2011-07-28T15:39:15+08:002011-07-28T15:39:15+08:00

    Minha culpa, Vatic, devo apontar isso em minha resposta à sua pergunta anterior. Ao usar uma expressão CASE em uma ordem, você deve lidar com cada tipo de dados em uma expressão separada. O seguinte não foi testado, mas deve estar mais próximo do que você precisa.

    ORDER BY
        CASE WHEN @OrderDirection = 'ASC' THEN
            CASE @OrderBy -- int
                WHEN 'JobNumber' THEN p1.JobNumber 
                WHEN 'CustID' THEN p1.CustID
                WHEN 'Status' THEN p1.MasterJobStatusID  
            END
        END ASC,
        CASE WHEN @OrderDirection = 'ASC' THEN
            CASE @OrderBy -- datetime
                 WHEN 'DateIn' THEN p1.DateIn
                 WHEN 'DateDue' THEN p1.DateDue
                 WHEN 'DateOut' THEN p1.DateOut  
            END
        END ASC,
        CASE WHEN @OrderDirection = 'ASC' THEN
            CASE @OrderBy -- nvarchar
                 WHEN 'OrderNumber' THEN p1.OrderNumber  
            END
        END ASC,
        CASE WHEN @OrderDirection = 'DESC' THEN
            CASE @OrderBy -- int
                WHEN 'JobNumber' THEN p1.JobNumber 
                WHEN 'CustID' THEN p1.CustID
                WHEN 'Status' THEN p1.MasterJobStatusID  
            END
        END DESC,
        CASE WHEN @OrderDirection = 'DESC' THEN
            CASE @OrderBy -- datetime
                 WHEN 'DateIn' THEN p1.DateIn
                 WHEN 'DateDue' THEN p1.DateDue
                 WHEN 'DateOut' THEN p1.DateOut  
            END
        END DESC,
        CASE WHEN @OrderDirection = 'ASC' THEN
            CASE @OrderBy -- nvarchar
                 WHEN 'OrderNumber' THEN p1.OrderNumber  
            END
        END DESC
    
    • 5

relate perguntas

  • SQL Server - Como as páginas de dados são armazenadas ao usar um índice clusterizado

  • Preciso de índices separados para cada tipo de consulta ou um índice de várias colunas funcionará?

  • Quando devo usar uma restrição exclusiva em vez de um índice exclusivo?

  • Quais são as principais causas de deadlocks e podem ser evitadas?

  • Como determinar se um Índice é necessário ou necessário

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Como você mysqldump tabela (s) específica (s)?

    • 4 respostas
  • Marko Smith

    Como você mostra o SQL em execução em um banco de dados Oracle?

    • 2 respostas
  • Marko Smith

    Como selecionar a primeira linha de cada grupo?

    • 6 respostas
  • Marko Smith

    Listar os privilégios do banco de dados usando o psql

    • 10 respostas
  • Marko Smith

    Posso ver Consultas Históricas executadas em um banco de dados SQL Server?

    • 6 respostas
  • Marko Smith

    Como uso currval() no PostgreSQL para obter o último id inserido?

    • 10 respostas
  • Marko Smith

    Como executar o psql no Mac OS X?

    • 11 respostas
  • Marko Smith

    Como inserir valores em uma tabela de uma consulta de seleção no PostgreSQL?

    • 4 respostas
  • Marko Smith

    Como faço para listar todos os bancos de dados e tabelas usando o psql?

    • 7 respostas
  • Marko Smith

    Passando parâmetros de array para um procedimento armazenado

    • 12 respostas
  • Martin Hope
    Manuel Leduc Restrição exclusiva de várias colunas do PostgreSQL e valores NULL 2011-12-28 01:10:21 +0800 CST
  • Martin Hope
    markdorison Como você mysqldump tabela (s) específica (s)? 2011-12-17 12:39:37 +0800 CST
  • Martin Hope
    Stuart Blackler Quando uma chave primária deve ser declarada sem cluster? 2011-11-11 13:31:59 +0800 CST
  • Martin Hope
    pedrosanta Listar os privilégios do banco de dados usando o psql 2011-08-04 11:01:21 +0800 CST
  • Martin Hope
    Jonas Como posso cronometrar consultas SQL usando psql? 2011-06-04 02:22:54 +0800 CST
  • Martin Hope
    Jonas Como inserir valores em uma tabela de uma consulta de seleção no PostgreSQL? 2011-05-28 00:33:05 +0800 CST
  • Martin Hope
    Jonas Como faço para listar todos os bancos de dados e tabelas usando o psql? 2011-02-18 00:45:49 +0800 CST
  • Martin Hope
    BrunoLM Guid vs INT - Qual é melhor como chave primária? 2011-01-05 23:46:34 +0800 CST
  • Martin Hope
    bernd_k Quando devo usar uma restrição exclusiva em vez de um índice exclusivo? 2011-01-05 02:32:27 +0800 CST
  • Martin Hope
    Patrick Como posso otimizar um mysqldump de um banco de dados grande? 2011-01-04 13:13:48 +0800 CST

Hot tag

sql-server mysql postgresql sql-server-2014 sql-server-2016 oracle sql-server-2008 database-design query-performance sql-server-2017

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve