質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
SQLite

SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

2回答

7422閲覧

PHP から SQLite3 の DB に変数の値を INSERT したい

TsuyoshiOshima

総合スコア13

SQLite

SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2016/06/11 12:51

PHP から SQLite3 のデータベースへデータを格納したいと考えています。

下記のコードで DB 接続と TABLE 作成のところまでは上手く行きました。

DB に変数の値を INSERT しようとしているのですが、実行後の DB の中を覗くとデータが入っておらず空っぽの状態でした。

Q1.VALUES の値に変数をそのまま使うことはできないのでしょうか?
(VALUES に直接テキスト(今回の例なら'人間失格'、'太宰治')を入れたら上手く行きました)

Q2. VALUES の値に変数を使いたい場合は、なにか他に上手い方法があるのでしょうか?

初歩的な質問で大変恐縮ではありますが、よろしくお願いします。

PHP

1<?php 2// 変数定義 3$title = "人間失格"; 4$author = "太宰治"; 5 6// DB接続 7$db = new SQLite3("./booklist.db"); 8 9// TABLE 作成 10$db->exec("CREATE TABLE booklist (title text, author text)"); 11 12// DBに変数をINSERT 13$db->query("INSERT INTO booklist (title, author) VALUES ($title, $author)");

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

とりあえずはこれで解決できます.

php

1$db->query("INSERT INTO booklist (title, author) VALUES ($title, $author)");

php

1$db->query("INSERT INTO booklist (title, author) VALUES ('$title', '$author')");

今回のように入力がプログラマによって用意される場合はこれで問題はありませんが,もしユーザによって用意される場合には絶対にこんなコードを書いてはいけません.

正しいやり方はこうです.

php

1$stmt = $db->prepare("INSERT INTO booklist (title, author) VALUES (?, ?)"); 2$stmt->bindValue(1, '人間失格', SQLITE3_TEXT); 3$stmt->bindValue(2, '太宰治', SQLITE3_TEXT); 4$stmt->execute();

蛇足ですが,一般的にはSQLite3専用クラス群ではなくPDOクラス群を使うことが推奨されます.SQLite3にベットリなコードを書いてしまうと,「MySQLに乗り換えたいな」「PostgreSQLに乗り換えたいな」というときに困りますし,各データベースごとにクラスの使い方をバラバラに覚える必要がある点でも無駄があります.

投稿2016/06/11 13:24

編集2016/06/11 13:27
mpyw

総合スコア5223

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

TsuyoshiOshima

2016/06/11 14:38

ご回答ありがとうございます。 シングルクォーテーションを付けたことで無事動きました。 こんな簡単なことを見逃してしまっていた自分が恥ずかしいです。 SQLインジェクションとPDOについてもご紹介、ありがとうございました。 さっそく調べてみたいと思います。 まだまだ覚えることがたくさんありますが、コツコツと勉強していきたいと思います。 今回はありがとうございました。
guest

0

あっ、すいません、質問間違えました、、、

投稿2016/06/11 13:17

編集2016/06/11 13:23
Z-TALBO

総合スコア525

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問