Skip to main content

Rating Counter using PHP




First, we should maintain the rate count in the database separately for each record (whichever we are going to rate). For this we can use a separate column for this, which will be referred to as rating in this post.

Basically, what is to be done is to increment the rating, which should be 0 by default, by one each time the +1 button is clicked and to decrement when the -1 button is clicked.



if(isset($_GET['postIdPlus'])) //if plus button is clicked
{
$sql1="UPDATE posts SET rating=rating+1";
$result1=mysqli_query($conn,$sql1);
}
if(isset($_GET['postIdMinus'])) //if minus button is clicked
{

$sql1="UPDATE posts SET rating=rating-1";
$result1=mysqli_query($conn,$sql1);

}

When there are many posts, we should distinguish which post was rated. For this purpose, we shall embed the post_id (retrieved from the database along with the other details) to the URL. 

echo "<a href=\"tview.php?postIdPlus=$postId\"><img src=\"Images/1up.png\"></a>
<div style=\"width:100%\">$count</div>

<a href=\"tview.php?postIdMinus=$postId\"><img src=\"Images/1d.png\"></a>";

Once the image (link) is clicked the corresponding post_id will be embeded in the URL.

To get the value in the URL and update the count below is the complete code.

if(isset($_GET['postIdPlus']))
{
$post=$_GET['postIdPlus'];
$sql1="UPDATE posts SET rating=rating+1 WHERE post_id='$post'";
$result1=mysqli_query($conn,$sql1);
}

if(isset($_GET['postIdMinus']))
{
$post=$_GET['postIdMinus'];
$sql1="UPDATE posts SET rating=rating-1 WHERE post_id='$post'";
$result1=mysqli_query($conn,$sql1);

}

Comments

Popular posts from this blog

Admin panel of a Q & A Forum

In a Q & A Forum, when a user posts a question, it should be sent to the administrator for approval in case it contains inappropriate content. After approval it should be removed from this pending approval page and other users should be able to see the question afterwards. To enable this, we should maintain an approval column in our database table of records and for each record approval should be set to false by default. In the Pending approvals page only the records with approval=false should be displayed. Below is  the MySQL  statement for retrieval, $sql="SELECT * FROM topics WHERE approval=false"; To know which post was approved we should embed the post_id to the URL. And the relevant post should be updated as approval=true. Below is the complete code. <?php $sql="SELECT * FROM topics WHERE approval=false"; $query=mysqli_query($conn,$sql); echo '<form name="approve" method="p...

Fixing 'java RMI - ConnectException: Operation timed out' in WSO2 Enterprise Integrator 6.4

If you ever come across the below exception when running WSO2 Enterprise Integrator 6.4, here is the fix. This error occurs when you have multiple IP addresses from different networks configured in your etc/hosts as below. 10.xxx.x.xxx localhost 192.xxx.x.xxx localhost So simply, removing the unnecessary one and leaving the one of the network that you are currently connected to should resolve this issue. 10.xxx.x.xxx localhost

Student Information System - Java (SLIIT - ST2 PROJECT)

Student Information System (Github Project) This system is developed in Java and mySQL as a group project by me and 3 other members during a period of 1 month. The system allows the administrator to,  enroll students to the system  update enroll information  add/update course and degree program details  generate reports  create exams and edit relevant information  calculate gpa of the relevant exam  assign lecturers to courses  add lecturers/update details Lecturers to,  assign course grades  view their feedback  generate reports  view student / course / degree program details Students to,  view their profile  view their grading information  give feedback to lecturers   view lecturer / course / degree program details and other features. Below are some interfaces of the project. (Splash Screen) (Login) (Admin View) (Student Re...