Jump to content
munkbozz

[Resolvido] Resultado @@ROWCOUNT

Recommended Posts

munkbozz

Estou a utilizar a seguinte query:

SELECT @@ROWCOUNT(SELECT TCURRENTUSER.dwCharID, TGAME_GSP.dbo.TCHARTABLE.bCountry FROM
TCURRENTUSER INNER JOIN TGAME_GSP.dbo.TCHARTABLE ON TCURRENTUSER.dwCharID = TGAME_GSP.dbo.TCHARTABLE.dwCharID
WHERE TGAME_GSP.dbo.TCHARTABLE.bCountry = 2)

A query é executada sem qualquer erro de sintaxe, mas é necessário executar a mesma query duas vezes para que o output corresponda ao valor real.

A query já foi testada com Navicat e SQL Management Studio e o 'erro' é o mesmo.

Não vejo forma de chamar a mesma função duas vezes em PHP. Uma alternativa é colocar a query sem @@ROWCOUNT numa View, mas queria saber porque a necessidade de executar a query duas vezes ou se será algo que falta nesta query.

SQL Management Studio:

gyfu.png

pkt6.png

Navicat:

vuy3.png

lKamZn4.pnglKamZn4.png

Edited by munkbozz

Share this post


Link to post
Share on other sites
AntonioMateus

Creio que tem a ver com a ordem de execução. Como está, primeiro obtém o @@ROWCOUNT, que na primeira execução ainda não está preenchido com o nº de linhas afectadas pelo Select.

Se colocares o Select @@ROWCount depois do select às linhas deves obter o que pretendes, fica é com o nº de linhas no 2ª result e não no 1º.

Espero ter ajudado. :)

Edited by AntonioMateus

Share this post


Link to post
Share on other sites
munkbozz

Não, também não resultou. Bem eu vou countinuar a usar a View e apartir dela seleccionar o número de rows.

Edited by munkbozz

Share this post


Link to post
Share on other sites
AntonioMateus

Se fizeres

SELECT TCURRENTUSER.dwCharID, TGAME_GSP.dbo.TCHARTABLE.bCountry FROM
TCURRENTUSER INNER JOIN TGAME_GSP.dbo.TCHARTABLE ON TCURRENTUSER.dwCharID = TGAME_GSP.dbo.TCHARTABLE.dwCharID
WHERE TGAME_GSP.dbo.TCHARTABLE.bCountry = 2

SELECT @@ROWCOUNT as CountRows

não dá o que retendes?

Edited by AntonioMateus

Share this post


Link to post
Share on other sites
pikax

o que realmente pretendes em usar o @@ROWCOUNT, decerteza que existem melhores alternativas para o que queres.


Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender.

A beleza de um código está em decompor problemas complexos em pequenos blocos simples.

"learn how to do it manually first, then use the wizzy tool to save time."

"Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."

Share this post


Link to post
Share on other sites
munkbozz

Se fizeres

SELECT TCURRENTUSER.dwCharID, TGAME_GSP.dbo.TCHARTABLE.bCountry FROM
TCURRENTUSER INNER JOIN TGAME_GSP.dbo.TCHARTABLE ON TCURRENTUSER.dwCharID = TGAME_GSP.dbo.TCHARTABLE.dwCharID
WHERE TGAME_GSP.dbo.TCHARTABLE.bCountry = 2

SELECT @@ROWCOUNT as CountRows

não dá o que retendes?

Esta sim, obrigado ;)

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

×
×
  • Create New...

Important Information

By using this site you accept our Terms of Use and Privacy Policy. We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.