Mysql
 sql >> Datenbank >  >> RDS >> Mysql

MySQL-Verkettungs- und Illegal-Mix-of-Collations-Fehler

Wenn Geld tatsächlich eine Zahl in einem VARCHAR ist, könnten Sie cast verwenden.

Versuchen Sie Folgendes:

concat_ws(pl.last_name,'-',cast(money AS unsigned)); // This is with decimals.
concat(`pl.last_name,'-',substring_index(money,',',1)) // Without decimals. If you use . i.e. the American currency notation you can substitute , with an .   

Bearbeiten

Sie sollten zuerst versuchen:concat(pl.last_name,'-',format(money,0));

Dies ist ein sehr einfacher PHP-Code, den Sie verwenden könnten.

<?php

function selecting_data(){

    $host = "host";
    $user = "username";
    $password = "password";
    $database = "database";
    $charset = "utf8";

    $link = mysqli_connect($host, $user, $password, $database);
    mysqli_set_charset($charset, $link);
    IF (!$link) {
        echo('Unable to connect to the database!');
    } ELSE {


        $query = "SELECT lastname, format(money,0) FROM mytable"; //Select query
        $result = mysqli_query($link, $query);
        while ($rows = mysqli_fetch_array($result, MYSQLI_BOTH)){
            echo $rows['lastname']."<br>".$rows['money'] ; 
        }
    }
    mysqli_close($link);


}
?>

<html>
<head><title>title</title></head>
<body>
<?PHP echo selecting_data(); ?>
</body>
</html>