473,385 Members | 1,727 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 473,385 software developers and data experts.

Moveprevius problem

I want to have a movenext and move previus option in me site. De next work perfectli, but the move previus return the firstrecordset. Here are the code.

// Next recort work fine
$next_rec = "select * from people where contactid > $rec_id limit 1";

// previus record dont work, return the first record
$next_rec = "select * from people where contactid < $rec_id limit 1";

Any solution ?

Thanks,
Tomás
Jun 12 '07 #1
9 1372
Purple
404 Expert 256MB
Hi,

The get next is working because you are asking for all records starting from a specified point to a limit of 1. The get previous is getting all records with a value less than the start point to a limit of 1 which is the first record in the table in standard sort order.

If you change the select statement for the previous to include
Expand|Select|Wrap|Line Numbers
  1. order by contactid desc
you will get the records you are after but in reverse sort order

So you can either nest two select statements to correct the order or select into an array and sort in PHP (doing it in the SQL should be quicker)

Purple
Jun 12 '07 #2
Purple
404 Expert 256MB
Hi,

Apologies for the double post, it has been a while since I have worked on MySQL (the solution proposed will work on MSSQL which at 2000 misses the ability to use limit and offset)

So the better way to the previous page is :

[PHP]SELECT * FROM table
LIMIT 10 OFFSET 100[/PHP]

where you want to return ten records from one hundred. So:
Offset = start point - number of records per page
Limit = number of records per page.

Hope this helps

Purple
Jun 12 '07 #3
mmm not wotk the offset. Do nothing :(.

Any other idea?
Jun 12 '07 #4
Purple
404 Expert 256MB
Hi,

How many records in the table ? Are you getting an error back ? Have you got error messages turned on ?

Purple
Jun 12 '07 #5
NO, no error, do nothing. 4000 records.

Thanks.
Jun 12 '07 #6
Purple
404 Expert 256MB
Hi Tomas,

can you echo the sql statement you are processing and post it up plse.

Purple
Jun 12 '07 #7
Expand|Select|Wrap|Line Numbers
  1. //NEXT RECORD. WORKS FINE
  2. $querySEG = "SELECT * FROM products_description where product_id > '".$id."' AND campaign_categorie_id = '" . $categoria ."' ORDER BY '".$id."' LIMIT 1";
  3. $resultSEG = mysql_query($querySEG, $this->link) or $this->_Error(mysql_error(), 'ERROR | DB_ERROR'); 
  4. $rowSEG = mysql_fetch_array($resultSEG);
  5.  
  6. //PREVIUS RECORD. DONT WORK :(     
  7. $queryANT = "SELECT * FROM products_description where product_id < '".$id."' AND campaign_categorie_id = '" . $categoria ."' ORDER BY '".$id."' DESC LIMIT 1";
  8. $resultANT = mysql_query($queryANT, $this->link) or $this->_Error(mysql_error(), 'ERROR | DB_ERROR'); 
  9. $rowANT = mysql_fetch_array($resultANT);
  10.  
Jun 12 '07 #8
Purple
404 Expert 256MB
Hi,

Expand|Select|Wrap|Line Numbers
  1. //PREVIUS RECORD. DONT WORK :( 
  2. $queryANT = "SELECT * FROM products_description where product_id < '".$id."' AND campaign_categorie_id = '" . $categoria ."' ORDER BY '".$id."' DESC LIMIT 1";
  3. $resultANT = mysql_query($queryANT, $this->link) or $this->_Error(mysql_error(), 'ERROR | DB_ERROR'); 
  4. $rowANT = mysql_fetch_array($resultANT);
the ORDER BY ".$id." DESC LIMIT 1 should reference a column not a row
try changing to ORDER BY product_id DESC LIMIT 1

I am a little suprised this did not generate an error

Purple
Jun 12 '07 #9
Purple
404 Expert 256MB
Also..

if that works, I suggest you work on the offset approach cause it is significantly more efficient.

Purple
Jun 12 '07 #10

Sign in to post your reply or Sign up for a free account.

Similar topics

0
by: Bruce Davis | last post by:
I'm having a problem on windows (both 2000 and XP) with a multi-threaded tkinter gui application. The problem appears to be a deadlock condition when a child thread pops up a Pmw dialog window in...
11
by: Kostatus | last post by:
I have a virtual function in a base class, which is then overwritten by a function of the same name in a publically derived class. When I call the function using a pointer to the derived class...
0
by: Refky Wahib | last post by:
Hi I need Technical Support I finished a Great project using .Net and SQL Server and .Net Mobile Control My Business case is to implement this Program to accept about 1 Million concurrent...
9
by: Sudesh Sawant | last post by:
Hello, We have an application which communicates using remoting. There is a server which is a Windows Service. The server exposes an object which is a singleton. The client is a Web Application...
117
by: Peter Olcott | last post by:
www.halting-problem.com
17
by: Jon Slaughter | last post by:
I'm having a little trouble understanding what the slicing problem is. In B.S.'s C++ PL3rdEd he says "Becayse the Employee copy functions do not know anything about Managers, only the Employee...
28
by: Jon Davis | last post by:
If I have a class with a virtual method, and a child class that overrides the virtual method, and then I create an instance of the child class AS A base class... BaseClass bc = new ChildClass();...
6
by: Ammar | last post by:
Dear All, I'm facing a small problem. I have a portal web site, that contains articles, for each article, the end user can send a comment about the article. The problem is: I the comment length...
16
by: Dany | last post by:
Our web service was working fine until we installed .net Framework 1.1 service pack 1. Uninstalling SP1 is not an option because our largest customer says service packs marked as "critical" by...
2
by: Mike Collins | last post by:
I cannot get the correct drop down list value from a drop down I have on my web form. I get the initial value that was loaded in the list. It was asked by someone else what the autopostback was...
0
by: taylorcarr | last post by:
A Canon printer is a smart device known for being advanced, efficient, and reliable. It is designed for home, office, and hybrid workspace use and can also be used for a variety of purposes. However,...
0
by: Charles Arthur | last post by:
How do i turn on java script on a villaon, callus and itel keypad mobile phone
0
by: aa123db | last post by:
Variable and constants Use var or let for variables and const fror constants. Var foo ='bar'; Let foo ='bar';const baz ='bar'; Functions function $name$ ($parameters$) { } ...
0
by: ryjfgjl | last post by:
If we have dozens or hundreds of excel to import into the database, if we use the excel import function provided by database editors such as navicat, it will be extremely tedious and time-consuming...
0
BarryA
by: BarryA | last post by:
What are the essential steps and strategies outlined in the Data Structures and Algorithms (DSA) roadmap for aspiring data scientists? How can individuals effectively utilize this roadmap to progress...
1
by: nemocccc | last post by:
hello, everyone, I want to develop a software for my android phone for daily needs, any suggestions?
0
by: Hystou | last post by:
There are some requirements for setting up RAID: 1. The motherboard and BIOS support RAID configuration. 2. The motherboard has 2 or more available SATA protocol SSD/HDD slots (including MSATA, M.2...
0
marktang
by: marktang | last post by:
ONU (Optical Network Unit) is one of the key components for providing high-speed Internet services. Its primary function is to act as an endpoint device located at the user's premises. However,...
0
jinu1996
by: jinu1996 | last post by:
In today's digital age, having a compelling online presence is paramount for businesses aiming to thrive in a competitive landscape. At the heart of this digital strategy lies an intricately woven...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.