Ten '?'
nie jest symbolem zastępczym, jest dosłownym znakiem zapytania. Symbole zastępcze nie są cytowane. Tak jak masz dwa symbole zastępcze i trzy wartości, które próbowano powiązać.
Więc spróbuj:
$sth = $dbh->prepare("SELECT users.userID,fname,lname,status FROM users INNER JOIN friends ON users.userID = friends.friendID WHERE friends.userID = ? AND ((friends.status LIKE 'group%' OR friends.status = 'friends') OR (users.status = ?) OR (users.userID = ?)) ORDER BY friends.status,lname,fname ASC");