SQLITE более 397 символов - PullRequest
       6

SQLITE более 397 символов

0 голосов
/ 08 февраля 2012

Я пытаюсь сохранить данные из базы данных MySQL в локальной базе данных SQLite. Проблема в том, что я получил описание художника более 500 слов. Я могу напечатать идентификатор исполнителя и имя исполнителя на моем экране, но не могу отобразить описание исполнителя, если не использую substr ($ artist_description, 0, 397). 0, 397 показывает все 397 символов на экране, но когда я изменяю его на 398, он ничего не показывает.

<?php

    $artist_id = $_GET['artist_id'];

    mysql_connect("localhost", "root", "")
        or die("Failed to connect to database.");
    mysql_select_db("testdb");

    $query = "SELECT * FROM artist WHERE artist_id=$artist_id";
    $result = mysql_query($query);
    $row = mysql_fetch_array($result);

    echo $row['artist_name'];
    echo '<br />';
    echo $row['artist_description'];

    $artist_name = $row['artist_name'];
    $artist_description = $row['artist_description'];

    ?>

    <!DOCTYPE HTML>
    <html>
    <head>
    <script type="text/javascript">
        var db = openDatabase('mydb', '3.0', 'Test DB', 20 * 1024 * 1024);
        var msg;
        db.transaction(function (tx) {
          tx.executeSql('CREATE TABLE IF NOT EXISTS LOGS (id UNIQUE, artist_name, artist_description TEXT)');
          tx.executeSql('INSERT INTO LOGS (id, artist_name, artist_description) VALUES ("<?=$artist_id?>", "<?=$artist_name?>", "<?=substr($artist_description, 0, 397)?>")');
          msg = '<p>Log message created and row inserted.</p>';
          document.querySelector('#status').innerHTML =  msg;
        });

        db.transaction(function (tx) {
          tx.executeSql('SELECT * FROM LOGS', [], function (tx, results) {
           var len = results.rows.length, i;
           msg = "<p>Found rows: " + len + "</p>";
           document.querySelector('#status').innerHTML +=  msg;
           for (i = 0; i < len; i++){
             msg = "<p><b>" + results.rows.item(i).id + "</b> " + results.rows.item(i).artist_name + "<br>" + results.rows.item(i).artist_description + "</p>";
             document.querySelector('#status').innerHTML +=  msg;
           }
         }, null);
        });
    </script>
    </head>
    <body>
    <div id="status" name="status">Status Message</div>
    </body>

</html>

* редактировать: распечатывает ’n, ó, & и т. Д.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...