Vreemde foutmelding
Warning: mysql_num_rows(): supplied argument is not a valid MySQL result resource in /data/members/paid/k/i/kijk-vergelijk.nl/htdocs/www/index.php on line 312
Warning: mysql_fetch_object(): supplied argument is not a valid MySQL result resource in /data/members/paid/k/i/kijk-vergelijk.nl/htdocs/www/index.php on line 321
----------->code uit de foutmelding
Code (php)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
<?php
if (mysql_num_rows ($result2) == 0)
{
echo "<tr><td align='center'>$row8->catBanner</td></tr>";
}
else
echo "<tr><td align='center' class='linkTitel'><b>Subcategorie van $row8->cat_naam</b></td></tr>";
while ($row2 = mysql_fetch_object($result2))
{
echo "<tr><td><img src='pijlWit.jpg' border='0' align='left'><a href='?cat_id=$cat_id&sub_id=$row2->sub_id'> $row2->sub_naam</a></td></tr>";
}
$query9 = "SELECT * FROM subcategorie WHERE cat_id = '$cat_id' ORDER BY sub_naam ";
$result9 = mysql_query($query9) or die ("Sorry maar ik kan de subcategorie banner niet weergeven");
if ($row9 = mysql_fetch_object($result9))
{
echo "<tr><td height='150' valign='middle' align='center'>$row9->subBanner</td></tr>";
}
echo "</table>";
?>
if (mysql_num_rows ($result2) == 0)
{
echo "<tr><td align='center'>$row8->catBanner</td></tr>";
}
else
echo "<tr><td align='center' class='linkTitel'><b>Subcategorie van $row8->cat_naam</b></td></tr>";
while ($row2 = mysql_fetch_object($result2))
{
echo "<tr><td><img src='pijlWit.jpg' border='0' align='left'><a href='?cat_id=$cat_id&sub_id=$row2->sub_id'> $row2->sub_naam</a></td></tr>";
}
$query9 = "SELECT * FROM subcategorie WHERE cat_id = '$cat_id' ORDER BY sub_naam ";
$result9 = mysql_query($query9) or die ("Sorry maar ik kan de subcategorie banner niet weergeven");
if ($row9 = mysql_fetch_object($result9))
{
echo "<tr><td height='150' valign='middle' align='center'>$row9->subBanner</td></tr>";
}
echo "</table>";
?>
---------------------->
Uitleg bij code:
Als je in het menu klikt en een item heeft géén subcategorie laat dan een banner zien.
Anders ga verder met de code en laat de subcategorieën in de rechter kolom zien.
Het vreemde is dat de andere pagina's die ik op de zelfde manier include het wel gewoon doen.
bv. link toevoegen, partners enz.
Dit is de website
edit: ook mooier om je vars buiten je echo te houden of je querys
dus
WHERE var='".$var."' AND etcetc
Gewijzigd op 27/02/2006 16:09:00 door - wes -
Code (php)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
<?php
echo "<table width='100%' >";
if (mysql_num_rows ($result2) == 0)
{
echo "<tr><td align='center'>$row8->catBanner</td></tr>";
}
else
if ($result9 && mysql_num_rows($result9) >= 1)
{
echo "<tr><td align='center' class='linkTitel'><b>Subcategorie van $row8->cat_naam</b></td></tr>";
while ($row2 = mysql_fetch_object($result2))
{
echo "<tr><td><img src='pijlWit.jpg' border='0' align='left'><a href='?cat_id=$cat_id&sub_id=$row2->sub_id'> $row2->sub_naam</a></td></tr>";
}
$query9 = "SELECT * FROM subcategorie WHERE cat_id = '$cat_id' ORDER BY sub_naam ";
$result9 = mysql_query($query9) or die ("Sorry maar ik kan de subcategorie banner niet weergeven");
if ($row9 = mysql_fetch_object($result9))
{
echo "<tr><td height='150' valign='middle' align='center'>$row9->subBanner</td></tr>";
}
}
echo "</table>";
?>
echo "<table width='100%' >";
if (mysql_num_rows ($result2) == 0)
{
echo "<tr><td align='center'>$row8->catBanner</td></tr>";
}
else
if ($result9 && mysql_num_rows($result9) >= 1)
{
echo "<tr><td align='center' class='linkTitel'><b>Subcategorie van $row8->cat_naam</b></td></tr>";
while ($row2 = mysql_fetch_object($result2))
{
echo "<tr><td><img src='pijlWit.jpg' border='0' align='left'><a href='?cat_id=$cat_id&sub_id=$row2->sub_id'> $row2->sub_naam</a></td></tr>";
}
$query9 = "SELECT * FROM subcategorie WHERE cat_id = '$cat_id' ORDER BY sub_naam ";
$result9 = mysql_query($query9) or die ("Sorry maar ik kan de subcategorie banner niet weergeven");
if ($row9 = mysql_fetch_object($result9))
{
echo "<tr><td height='150' valign='middle' align='center'>$row9->subBanner</td></tr>";
}
}
echo "</table>";
?>
Je doet volgens mij eerst de if() met de mysql_num_rows($result9) terwijl pas verderop de query wordt uitgevoerd met $result9 = mysql_query($query9)
Het zijn allemaal pagina's die ik include.
Code (php)
1
2
3
4
5
6
7
8
9
10
11
12
13
2
3
4
5
6
7
8
9
10
11
12
13
<?php
//Query voor submenu oa. home, nieuwsbrief enz
if (isset ($_GET['id']))
{
$submenu_id = $_GET['id'];
$query = "SELECT * FROM submenu WHERE id = '$id' ";
$result = mysql_query($query) or die ("Sorry maar ik kan het submenu niet weergeven");
while ($row = mysql_fetch_object($result))
{
include($row->url);
}
// einde query submenu
?>
//Query voor submenu oa. home, nieuwsbrief enz
if (isset ($_GET['id']))
{
$submenu_id = $_GET['id'];
$query = "SELECT * FROM submenu WHERE id = '$id' ";
$result = mysql_query($query) or die ("Sorry maar ik kan het submenu niet weergeven");
while ($row = mysql_fetch_object($result))
{
include($row->url);
}
// einde query submenu
?>
Wie kan er nog helpen?
In de mysql_query()-regels die je wel hebt gepost, doe je steeds een "or die". Dat zou inhouden dat wanneer er iets mis gaat met de query, het script ermee stopt. Als je dat consequent doet, is het if-statement van Wes niet nodig. Ik heb trouwens net als SanThe mijn bedenkingen over de plaats waar je het if-statement hebt neergezet. Ik zou je dan ook adviseren om die regel weer weg te halen, want het enige wat je er op dit moment mee bereikt, is dat de rest van je code nooit(!) zal worden uitgevoerd.
Op dit moment kan ik de volgende oorzaken bedenken van je probleem:
1) Je hebt geen $result2 = mysql_query(blabla) in je code staan. Op het moment dat je $result2 gaat gebruiken (regel 312) krijg je dus een foutmelding
2) Je hebt een mooie query en dus een goede $result2, maar je overschrijft de waarde van $result2 voor je hem gebruikt in mysql_num_rows()
3) Je hebt een query die $result2 een waarde geeft, maar de query mislukt en je gebruikt geen "or die" om fouten mee af te vangen
het hele script
Code (php)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
<?php
//Query voor submenu oa. home, nieuwsbrief enz
if (isset ($_GET['id']))
{
$submenu_id = $_GET['id'];
$query = "SELECT * FROM submenu WHERE id = '$id' ";
$result = mysql_query($query) or die ("Sorry maar ik kan het submenu niet weergeven");
while ($row = mysql_fetch_object($result))
{
include($row->url);
}
// einde query submenu
}
else
{
//Als je op de pagina komt verschijnt de welkomstekst
if( !isset($_GET['cat_id']))
{
echo "<table class='intro'>";
echo "<tr>";
echo "<td><h1>Welkom op kijk-vergelijk.nl</h1></td></tr>";
echo "<tr>";
echo "<td class='introtekst'>U vergelijkt toch ook graag eerst de producten voordat u iets koopt?<br>Kijk & Vergelijk heeft speciaal voor u vele aanbieders geselecteerd zodat u eenvoudig een vergelijk kunt maken voordat u tot een aankoop overgaat.<br><br></td></tr>";
echo "<tr><td align='center'><script language='javascript' type='text/javascript' src='http://rotator.tradetracker.nl/877/js/4659/cp'></script></td></tr>";
echo "</table><br>";
}
else
{
//als er op een link in het menu geklikt is verschijnen de linken
$subcategorie_id = $_GET['cat_id'];
if (isset($_GET['letter9']) && $_GET['letter9'] != ""){
$letter9=$_GET['letter9'];
}
else {
$letter9="";
}
$query2 = "SELECT * FROM subcategorie WHERE cat_id = '$cat_id' ORDER BY sub_naam ";
$result2 = mysql_query($query2) or die ("Sorry maar ik kan de subcategorie niet weergeven");
//begin navigatie setup
$iPP = 10; // items per pagina
$noL = 7; // aantal links (default 7 / only required when you want an other number of links / use odd numbers)
$pn = ( !isset($_GET['pn']) || empty($_GET['pn']) ? 1 : $_GET['pn'] ); // pagina nummer (niet wijzigen!)
$offset = ($pn-1)*$iPP.",".$iPP; // SQL LIMIT offset (niet wijzigen!)
$navArr = explode("(|)",navGEN("SELECT count(*) FROM linken WHERE cat_id = '$cat_id' AND link_naam LIKE '".$_GET['letter9']."%'",$pn,$iPP,$noL)); // navGEN output (just change the SQL query
// === END navGEN setup
$query4 = ("SELECT * FROM linken WHERE cat_id = '$cat_id' AND link_naam LIKE '".$letter9."%' ORDER BY link_naam LIMIT ".$offset);
$result4 = mysql_query($query4) or die ("Sorry maar ik kan de linken niet weergeven");
//en worden de linken weergegeven
//Maak het alfabet voor de linken zonder subcategorie
if (isset ($_GET['cat_id']))
{
$query9=mysql_query("SELECT * FROM linken WHERE cat_id='$cat_id' ORDER BY link_naam");
while ($gegevens9=mysql_fetch_array($query9)){
// eerste letter als array maken
$alfabet9[]=substr($gegevens9['link_naam'],0,1);
}
$alfabet9=array_unique($alfabet9);
if (in_array($_GET['letter9'],$alfabet9)){
// wanneer goed
$letter9=$_GET['letter9'];
}
else{
// wanneer fout
$letter9="";
}
//einde alfabet maken voor linken zonder subcategorie
if (!isset($_GET['sub_id']))
{
//Begin paginanummering boven aan de pagina
echo"<table width='90%' border='0' cellpadding='0' cellspacing='0'><tr><td class='navigatie'>".$navArr[0]."</td><td class='navigatie' align='center'>".$navArr[1]."</td></tr></table>";
// normal query to generate output ('LIMIT ".$offset' must be in the query!)
//Einde pagina nummering
//Query 7 geeft een titel weer boven de linken van de categorieën
$query7 = "SELECT * FROM categorie WHERE cat_id = '$cat_id'";
$result7 = mysql_query($query7) or die ("Sorry maar ik kan de categorieën niet weergeven");
$row7 = mysql_fetch_object($result7);
//einde query 7
//Hier worden de linken weergegeven van de categorie
echo "<table class='tabelLinken' border='0' cellpadding='2' cellspacing='2' width='90%' align='center'>";
echo "<tr><td class='linkTitel' ><b>$row7->cat_naam</b> Of zoek op alfabet: ";
//hier staat de code voor het weergeven van het alfabet bij de linken zonder subcategorie
foreach($alfabet9 as $letters9)
{
if ($letter9 == $letters9)
{
echo "<img src='http://www.kijk-vergelijk.nl/pijl.jpg' 'border='0'><b>".$letters9."<img src='http://www.kijk-vergelijk.nl/pijlReverse.jpg' 'border='0'></b>";
}
else
{
echo '<a href="?cat_id='.$_GET['cat_id'].'&letter9='.$letters9.'">'.$letters9.'</a>-';
}
}
//einde weergeven alfabet
echo "</td></tr>";
echo "<tr>";
echo "<td>";
echo "<table cellpadding='2' cellspacing='2' width='100%' >";
while ($row4 = mysql_fetch_object($result4))
{
if($row4->link_tekst)
{
echo "<tr><td class='titelLink' valign='middle'>$row4->link_naam</td><td class='linkTekst' align='left' valign='top'>$row4->link_tekst</td></tr>";
}
else
{
echo "<tr><td class='titelLink' valign='middle'>$row4->link_naam</td><td class='linkTekst' align='left' valign='top'>$row4->link_javascript</td></tr>";
}
}
echo "</tr></table>\n";
echo "</td>\n" ;
echo "</tr></table>";
//Einde weergeven linken van categorie (query7)
//Begin pagina nummering onderaan de pagina
echo"<table width='90%' border='0' cellpadding='0' cellspacing='0'><tr><td class='navigatie'>".$navArr[0]."</td><td class='navigatie' align='center'>".$navArr[1]."</td></tr></table>";
//Einde pagina nummering
}
}
}
}
//Als er op een subcategorie geklikt is verschijnen de winkels en kun je ook kiezen om op alfabet te kijken
if (isset ($_GET['sub_id']))
{
$query=mysql_query("SELECT * FROM linken WHERE sub_id='$sub_id' ORDER BY link_naam");
while ($gegevens=mysql_fetch_array($query)){
// eerste letter als array maken
$alfabet[]=substr($gegevens['link_naam'],0,1);
}
$alfabet=array_unique($alfabet);
if (in_array($_GET['letter'],$alfabet)){
// wanneer goed
$letter=$_GET['letter'];
}
else{
// wanneer fout
$letter="";
}
$query3 = ("SELECT * FROM linken WHERE sub_id = '$sub_id' AND link_naam LIKE '".$_GET['letter']."%' ORDER BY link_naam LIMIT ".$offset);
$result3 = mysql_query($query3) or die ("Sorry maar ik kan de subcategorie linken niet weergeven");
//Begin van navigatie boven de linken
$navArr = explode("(|)",navGEN("SELECT count(*) FROM linken WHERE sub_id = '$sub_id' AND link_naam LIKE '".$_GET['letter']."%'",$pn,$iPP,$noL)); // navGEN output (just change the SQL query
echo"<table width='90%' border='0' cellpadding='0' cellspacing='0'><tr><td class='navigatie'>".$navArr[0]."</td><td class='navigatie' align='center'>".$navArr[1]."</td></tr></table>";
//einde navigatie boven de linken
//Query 6 geeft een titel weer boven de linken van de subcategorieën
$query6 = "SELECT * FROM subcategorie WHERE sub_id = '$sub_id'";
$result6 = mysql_query($query6) or die ("Sorry maar ik kan de categorieën niet weergeven");
$row6 = mysql_fetch_object($result6);
echo "<table cellpadding='2' cellspacing='2' class='tabelLinken' border='0' width='90%' align='center'>";
echo "<tr><td class='linkTitel' ><b>$row6->sub_naam</b> Of zoek op alfabet: ";
//einde query 6
//hier staat de code voor het weergeven van het alfabet
foreach($alfabet as $letters){
if ($letter == $letters){
echo "<img src='http://www.kijk-vergelijk.nl/pijl.jpg' 'border='0'><b>".$letters."</b><img src='http://www.kijk-vergelijk.nl/pijlReverse.jpg' 'border='0'>";
}
else{
echo '<a href="?cat_id='.$_GET['cat_id'].'&sub_id='.$_GET['sub_id'].'&letter='.$letters.'">'.$letters.'</a>-';
}
}
echo "</td></tr>";
echo "<tr>";
//einde weergeven alfabet
//Query 3 geeft de linken weer van de subcategorie
echo "<td>";
echo "<table cellpadding='2' cellspacing='2' width='100%' ><tr>";
while ($row3 = mysql_fetch_object($result3))
{
if($row3->link_tekst)
{
echo "<tr><td class='titelLink' valign='middle'>$row3->link_naam</td><td class='linkTekst' align='left' valign='top'>$row3->link_tekst</td></tr>";
}
else
{
echo "<tr><td class='titelLink' valign='middle'>$row3->link_naam</td><td class='linkTekst' align='left' valign='top'>$row3->link_javascript</td></tr>";
}
}
echo "</tr></table>\n";
echo "</td>\n" ;
echo "</tr></table>";
//einde query 3
//Begin pagina nummering onderaan de pagina
echo"<table width='90%' border='0' cellpadding='0' cellspacing='0'><tr><td class='navigatie'>".$navArr[0]."</td><td class='navigatie' align='center'>".$navArr[1]."</td></tr></table>";
//Einde pagina nummering
}
?>
//Query voor submenu oa. home, nieuwsbrief enz
if (isset ($_GET['id']))
{
$submenu_id = $_GET['id'];
$query = "SELECT * FROM submenu WHERE id = '$id' ";
$result = mysql_query($query) or die ("Sorry maar ik kan het submenu niet weergeven");
while ($row = mysql_fetch_object($result))
{
include($row->url);
}
// einde query submenu
}
else
{
//Als je op de pagina komt verschijnt de welkomstekst
if( !isset($_GET['cat_id']))
{
echo "<table class='intro'>";
echo "<tr>";
echo "<td><h1>Welkom op kijk-vergelijk.nl</h1></td></tr>";
echo "<tr>";
echo "<td class='introtekst'>U vergelijkt toch ook graag eerst de producten voordat u iets koopt?<br>Kijk & Vergelijk heeft speciaal voor u vele aanbieders geselecteerd zodat u eenvoudig een vergelijk kunt maken voordat u tot een aankoop overgaat.<br><br></td></tr>";
echo "<tr><td align='center'><script language='javascript' type='text/javascript' src='http://rotator.tradetracker.nl/877/js/4659/cp'></script></td></tr>";
echo "</table><br>";
}
else
{
//als er op een link in het menu geklikt is verschijnen de linken
$subcategorie_id = $_GET['cat_id'];
if (isset($_GET['letter9']) && $_GET['letter9'] != ""){
$letter9=$_GET['letter9'];
}
else {
$letter9="";
}
$query2 = "SELECT * FROM subcategorie WHERE cat_id = '$cat_id' ORDER BY sub_naam ";
$result2 = mysql_query($query2) or die ("Sorry maar ik kan de subcategorie niet weergeven");
//begin navigatie setup
$iPP = 10; // items per pagina
$noL = 7; // aantal links (default 7 / only required when you want an other number of links / use odd numbers)
$pn = ( !isset($_GET['pn']) || empty($_GET['pn']) ? 1 : $_GET['pn'] ); // pagina nummer (niet wijzigen!)
$offset = ($pn-1)*$iPP.",".$iPP; // SQL LIMIT offset (niet wijzigen!)
$navArr = explode("(|)",navGEN("SELECT count(*) FROM linken WHERE cat_id = '$cat_id' AND link_naam LIKE '".$_GET['letter9']."%'",$pn,$iPP,$noL)); // navGEN output (just change the SQL query
// === END navGEN setup
$query4 = ("SELECT * FROM linken WHERE cat_id = '$cat_id' AND link_naam LIKE '".$letter9."%' ORDER BY link_naam LIMIT ".$offset);
$result4 = mysql_query($query4) or die ("Sorry maar ik kan de linken niet weergeven");
//en worden de linken weergegeven
//Maak het alfabet voor de linken zonder subcategorie
if (isset ($_GET['cat_id']))
{
$query9=mysql_query("SELECT * FROM linken WHERE cat_id='$cat_id' ORDER BY link_naam");
while ($gegevens9=mysql_fetch_array($query9)){
// eerste letter als array maken
$alfabet9[]=substr($gegevens9['link_naam'],0,1);
}
$alfabet9=array_unique($alfabet9);
if (in_array($_GET['letter9'],$alfabet9)){
// wanneer goed
$letter9=$_GET['letter9'];
}
else{
// wanneer fout
$letter9="";
}
//einde alfabet maken voor linken zonder subcategorie
if (!isset($_GET['sub_id']))
{
//Begin paginanummering boven aan de pagina
echo"<table width='90%' border='0' cellpadding='0' cellspacing='0'><tr><td class='navigatie'>".$navArr[0]."</td><td class='navigatie' align='center'>".$navArr[1]."</td></tr></table>";
// normal query to generate output ('LIMIT ".$offset' must be in the query!)
//Einde pagina nummering
//Query 7 geeft een titel weer boven de linken van de categorieën
$query7 = "SELECT * FROM categorie WHERE cat_id = '$cat_id'";
$result7 = mysql_query($query7) or die ("Sorry maar ik kan de categorieën niet weergeven");
$row7 = mysql_fetch_object($result7);
//einde query 7
//Hier worden de linken weergegeven van de categorie
echo "<table class='tabelLinken' border='0' cellpadding='2' cellspacing='2' width='90%' align='center'>";
echo "<tr><td class='linkTitel' ><b>$row7->cat_naam</b> Of zoek op alfabet: ";
//hier staat de code voor het weergeven van het alfabet bij de linken zonder subcategorie
foreach($alfabet9 as $letters9)
{
if ($letter9 == $letters9)
{
echo "<img src='http://www.kijk-vergelijk.nl/pijl.jpg' 'border='0'><b>".$letters9."<img src='http://www.kijk-vergelijk.nl/pijlReverse.jpg' 'border='0'></b>";
}
else
{
echo '<a href="?cat_id='.$_GET['cat_id'].'&letter9='.$letters9.'">'.$letters9.'</a>-';
}
}
//einde weergeven alfabet
echo "</td></tr>";
echo "<tr>";
echo "<td>";
echo "<table cellpadding='2' cellspacing='2' width='100%' >";
while ($row4 = mysql_fetch_object($result4))
{
if($row4->link_tekst)
{
echo "<tr><td class='titelLink' valign='middle'>$row4->link_naam</td><td class='linkTekst' align='left' valign='top'>$row4->link_tekst</td></tr>";
}
else
{
echo "<tr><td class='titelLink' valign='middle'>$row4->link_naam</td><td class='linkTekst' align='left' valign='top'>$row4->link_javascript</td></tr>";
}
}
echo "</tr></table>\n";
echo "</td>\n" ;
echo "</tr></table>";
//Einde weergeven linken van categorie (query7)
//Begin pagina nummering onderaan de pagina
echo"<table width='90%' border='0' cellpadding='0' cellspacing='0'><tr><td class='navigatie'>".$navArr[0]."</td><td class='navigatie' align='center'>".$navArr[1]."</td></tr></table>";
//Einde pagina nummering
}
}
}
}
//Als er op een subcategorie geklikt is verschijnen de winkels en kun je ook kiezen om op alfabet te kijken
if (isset ($_GET['sub_id']))
{
$query=mysql_query("SELECT * FROM linken WHERE sub_id='$sub_id' ORDER BY link_naam");
while ($gegevens=mysql_fetch_array($query)){
// eerste letter als array maken
$alfabet[]=substr($gegevens['link_naam'],0,1);
}
$alfabet=array_unique($alfabet);
if (in_array($_GET['letter'],$alfabet)){
// wanneer goed
$letter=$_GET['letter'];
}
else{
// wanneer fout
$letter="";
}
$query3 = ("SELECT * FROM linken WHERE sub_id = '$sub_id' AND link_naam LIKE '".$_GET['letter']."%' ORDER BY link_naam LIMIT ".$offset);
$result3 = mysql_query($query3) or die ("Sorry maar ik kan de subcategorie linken niet weergeven");
//Begin van navigatie boven de linken
$navArr = explode("(|)",navGEN("SELECT count(*) FROM linken WHERE sub_id = '$sub_id' AND link_naam LIKE '".$_GET['letter']."%'",$pn,$iPP,$noL)); // navGEN output (just change the SQL query
echo"<table width='90%' border='0' cellpadding='0' cellspacing='0'><tr><td class='navigatie'>".$navArr[0]."</td><td class='navigatie' align='center'>".$navArr[1]."</td></tr></table>";
//einde navigatie boven de linken
//Query 6 geeft een titel weer boven de linken van de subcategorieën
$query6 = "SELECT * FROM subcategorie WHERE sub_id = '$sub_id'";
$result6 = mysql_query($query6) or die ("Sorry maar ik kan de categorieën niet weergeven");
$row6 = mysql_fetch_object($result6);
echo "<table cellpadding='2' cellspacing='2' class='tabelLinken' border='0' width='90%' align='center'>";
echo "<tr><td class='linkTitel' ><b>$row6->sub_naam</b> Of zoek op alfabet: ";
//einde query 6
//hier staat de code voor het weergeven van het alfabet
foreach($alfabet as $letters){
if ($letter == $letters){
echo "<img src='http://www.kijk-vergelijk.nl/pijl.jpg' 'border='0'><b>".$letters."</b><img src='http://www.kijk-vergelijk.nl/pijlReverse.jpg' 'border='0'>";
}
else{
echo '<a href="?cat_id='.$_GET['cat_id'].'&sub_id='.$_GET['sub_id'].'&letter='.$letters.'">'.$letters.'</a>-';
}
}
echo "</td></tr>";
echo "<tr>";
//einde weergeven alfabet
//Query 3 geeft de linken weer van de subcategorie
echo "<td>";
echo "<table cellpadding='2' cellspacing='2' width='100%' ><tr>";
while ($row3 = mysql_fetch_object($result3))
{
if($row3->link_tekst)
{
echo "<tr><td class='titelLink' valign='middle'>$row3->link_naam</td><td class='linkTekst' align='left' valign='top'>$row3->link_tekst</td></tr>";
}
else
{
echo "<tr><td class='titelLink' valign='middle'>$row3->link_naam</td><td class='linkTekst' align='left' valign='top'>$row3->link_javascript</td></tr>";
}
}
echo "</tr></table>\n";
echo "</td>\n" ;
echo "</tr></table>";
//einde query 3
//Begin pagina nummering onderaan de pagina
echo"<table width='90%' border='0' cellpadding='0' cellspacing='0'><tr><td class='navigatie'>".$navArr[0]."</td><td class='navigatie' align='center'>".$navArr[1]."</td></tr></table>";
//Einde pagina nummering
}
?>
<td width="160" align="left" valign="top" bgcolor="#FFFFFF" class="stippel">
Code (php)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
<?php
//Query 8 geeft de naam weer boven de subcategorie
$query8 = "SELECT * FROM categorie WHERE cat_id = '$cat_id'";
$result8 = mysql_query($query8) or die ("Sorry maar ik kan de categorieën niet weergeven");
$row8 = mysql_fetch_object($result8);
//einde query 8
echo "<table width='100%' >";
if (mysql_num_rows ($result2) == 0)
{
echo "<tr><td align='center'>$row8->catBanner</td></tr>";
}
else
echo "<tr><td align='center' class='linkTitel'><b>Subcategorie van $row8->cat_naam</b></td></tr>";
while ($row2 = mysql_fetch_object($result2))
{
echo "<tr><td><img src='pijlWit.jpg' border='0' align='left'><a href='?cat_id=$cat_id&sub_id=$row2->sub_id'> $row2->sub_naam</a></td></tr>";
}
$query9 = "SELECT * FROM subcategorie WHERE cat_id = '$cat_id' ORDER BY sub_naam ";
$result9 = mysql_query($query9) or die ("Sorry maar ik kan de subcategorie banner niet weergeven");
if ($row9 = mysql_fetch_object($result9))
{
echo "<tr><td height='150' valign='middle' align='center'>$row9->subBanner</td></tr>";
}
echo "</table>";
//einde query ?>
//Query 8 geeft de naam weer boven de subcategorie
$query8 = "SELECT * FROM categorie WHERE cat_id = '$cat_id'";
$result8 = mysql_query($query8) or die ("Sorry maar ik kan de categorieën niet weergeven");
$row8 = mysql_fetch_object($result8);
//einde query 8
echo "<table width='100%' >";
if (mysql_num_rows ($result2) == 0)
{
echo "<tr><td align='center'>$row8->catBanner</td></tr>";
}
else
echo "<tr><td align='center' class='linkTitel'><b>Subcategorie van $row8->cat_naam</b></td></tr>";
while ($row2 = mysql_fetch_object($result2))
{
echo "<tr><td><img src='pijlWit.jpg' border='0' align='left'><a href='?cat_id=$cat_id&sub_id=$row2->sub_id'> $row2->sub_naam</a></td></tr>";
}
$query9 = "SELECT * FROM subcategorie WHERE cat_id = '$cat_id' ORDER BY sub_naam ";
$result9 = mysql_query($query9) or die ("Sorry maar ik kan de subcategorie banner niet weergeven");
if ($row9 = mysql_fetch_object($result9))
{
echo "<tr><td height='150' valign='middle' align='center'>$row9->subBanner</td></tr>";
}
echo "</table>";
//einde query ?>
Dat heeft trouwens niet alleen met het overzicht te maken. Die query2 wordt uitgevoerd in een if-then constructie, en de mysql_num_rows() wordt ver daarbuiten pas uitgevoerd. Je hebt dus geen zekerheid dat query2 is uitgevoerd op het moment dat je die $result2 gaat gebruiken. Als je die code bij elkaar houdt, heb je dat probleem niet.
In dit geval vermoed ik, dat wanneer je op contact klikt, je cat_id niet wordt geset. De query2 wordt dan niet uitgevoerd, en dat geeft de foutmelding op mysql_num_rows().
Je had helemaal gelijk, het lag te ver uit elkaar.
Ik heb er maar een query10 van gemaakt en het erboven geplaatst.
Het werkt nu goed.....bedankt voor jullie hulp :)
Code (php)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
<?php
//Query 10 plaatst een banner in de rechter kolom als er geen subcategorie is
//en anders geeft hij de subcategorie weer met een kleine banner er onder
$query10 = "SELECT * FROM subcategorie WHERE cat_id = '$cat_id' ORDER BY sub_naam ";
$result10 = mysql_query($query10) or die ("Sorry maar ik kan de subcategorie niet weergeven");
if (mysql_num_rows ($result10) == 0)
{
echo "<tr><td align='center'>$row8->catBanner</td></tr>";
}
else
echo "<tr><td align='center' class='linkTitel'><b>Subcategorie van $row8->cat_naam</b></td></tr>";
while ($row10 = mysql_fetch_object($result10))
{
echo "<tr><td><img src='pijlWit.jpg' border='0' align='left'><a href='?cat_id=$cat_id&sub_id=$row10->sub_id'> $row10->sub_naam</a></td></tr>";
}
$query9 = "SELECT * FROM subcategorie WHERE cat_id = '$cat_id' ORDER BY sub_naam ";
$result9 = mysql_query($query9) or die ("Sorry maar ik kan de subcategorie banner niet weergeven");
if ($row9 = mysql_fetch_object($result9))
{
echo "<tr><td height='150' valign='middle' align='center'>$row9->subBanner</td></tr>";
}
echo "</table>";
?>
//Query 10 plaatst een banner in de rechter kolom als er geen subcategorie is
//en anders geeft hij de subcategorie weer met een kleine banner er onder
$query10 = "SELECT * FROM subcategorie WHERE cat_id = '$cat_id' ORDER BY sub_naam ";
$result10 = mysql_query($query10) or die ("Sorry maar ik kan de subcategorie niet weergeven");
if (mysql_num_rows ($result10) == 0)
{
echo "<tr><td align='center'>$row8->catBanner</td></tr>";
}
else
echo "<tr><td align='center' class='linkTitel'><b>Subcategorie van $row8->cat_naam</b></td></tr>";
while ($row10 = mysql_fetch_object($result10))
{
echo "<tr><td><img src='pijlWit.jpg' border='0' align='left'><a href='?cat_id=$cat_id&sub_id=$row10->sub_id'> $row10->sub_naam</a></td></tr>";
}
$query9 = "SELECT * FROM subcategorie WHERE cat_id = '$cat_id' ORDER BY sub_naam ";
$result9 = mysql_query($query9) or die ("Sorry maar ik kan de subcategorie banner niet weergeven");
if ($row9 = mysql_fetch_object($result9))
{
echo "<tr><td height='150' valign='middle' align='center'>$row9->subBanner</td></tr>";
}
echo "</table>";
?>