この'?'
はプレースホルダーではなく、文字通りの疑問符です。プレースホルダーは引用されません。プレースホルダーが2つあり、3つの値がバインドされようとしました。
だから試してみてください:
$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");