下のエラーのようにtable usersはdataというcolumnを持っていません。と出るのですが、どうすれば良いのでしょうか?
あどば
"create table " + UserContract.Users.TABLE_NAME + "(" +
UserContract.Users._ID+ " integer primary key autoincrement, " +
UserContract.Users.COL_TITLE + " title," +
UserContract.Users.COL_CONTENT + " content, " +
UserContract.Users.COL_DATA + "data" +
")";
E/SQLiteLog: (1) table users has no column named data
04-11 07:06:51.366 19394-19394/com.example.android.sample.memo E/SQLiteDatabase: Error inserting data=android.support.v7.widget.AppCompatEditText@41932740 content=android.support.v7.widget.AppCompatEditText@41931730 title=android.support.v7.widget.AppCompatEditText@4192de48
android.database.sqlite.SQLiteException: table users has no column named data (code 1): , while compiling: INSERT INTO users(data,content,title) VALUES (?,?,?)
at android.database.sqlite.SQLiteConnection.nativePrepareStatement(Native Method)
at android.database.sqlite.SQLiteConnection.acquirePreparedStatement(SQLiteConnection.java:893)
at android.database.sqlite.SQLiteConnection.prepare(SQLiteConnection.java:504)
at android.database.sqlite.SQLiteSession.prepare(SQLiteSession.java:588)
at android.database.sqlite.SQLiteProgram.<init>(SQLiteProgram.java:58)
at android.database.sqlite.SQLiteStatement.<init>(SQLiteStatement.java:31)
at android.database.sqlite.SQLiteDatabase.insertWithOnConflict(SQLiteDatabase.java:1475)
//EditActivity
public class EditActivity extends AppCompatActivity {
// 保存ファイル名
String mFileName = "";
// 保存なしフラグ
boolean mNotSave = false;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_edit);
//open helper
//open db memoDBHelperに変更
MemoDBHelper memoDBHelper = new MemoDBHelper(this);
SQLiteDatabase db = memoDBHelper.getWritableDatabase();
//日時の下だから上のは、いらん
// タイトルと内容入力用の EditText を取得
EditText eTxtTitle = (EditText) findViewById(R.id.eTxtTitle);
EditText eTxtContent = (EditText) findViewById(R.id.eTxtContent);
//実行日の取得
EditText eTxtData = (EditText) findViewById(R.id.eTxtData);
Intent intent = getIntent();
//String name = intent.getStringExtra("NAME");
String insertk = intent.getStringExtra("INSERT");
if (insertk.length() != 0) {
//insertじゃないならば、それは、updateだからデータを取得
eTxtTitle.setText(intent.getStringExtra("TITLE"));
eTxtContent.setText(intent.getStringExtra("CONTENT"));
eTxtData.setText(intent.getStringExtra("DATA"));
} else {
Calendar calendar = Calendar.getInstance();
int month = calendar.get(Calendar.MONTH) + 1;
int day = calendar.get(Calendar.DATE);
eTxtData.setText(month + "月" + day + "日");
}
}
@Override
protected void onPause() {
super.onPause();
if (mNotSave) {
return;
}
}
// メニュー生成
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.edit, menu);
return true;
}
// メニュー選択時の処理
@Override
public boolean onOptionsItemSelected(MenuItem item) {
//open helper
//open db memoDBHelperに変更
MemoDBHelper memoDBHelper = new MemoDBHelper(this);
SQLiteDatabase db = memoDBHelper.getWritableDatabase();
Cursor c = null;
String title = null;
String content = null;
String data = null;
EditText eTxtTitle = null;
EditText eTxtContent = null;
EditText eTxtData = null;
//ここのidにcancelとupdateを入れる
switch (item.getItemId()) {
case R.id.action_can:
//キャンセルが押された場合
mNotSave = true;
this.finish();
break;
case R.id.action_upd:
// タイトル、内容、実行日の追加
eTxtTitle = (EditText) findViewById(R.id.eTxtTitle);
eTxtContent = (EditText) findViewById(R.id.eTxtContent);
eTxtData = (EditText) findViewById(R.id.eTxtData);
title = eTxtTitle.getText().toString();
content = eTxtContent.getText().toString();
data = eTxtData.getText().toString();
// タイトル、内容が空白の場合、保存しない
Intent intent = getIntent();
//あえてinsertkに変更
String insertk = intent.getStringExtra("INSERT");
if (title.isEmpty() || content.isEmpty()) {
Toast.makeText(this, R.string.msg_destruction, Toast.LENGTH_SHORT).show();
}
if (insertk.length() == 0) {
try {
//書き換えをしていく
ContentValues newData = new ContentValues();
newData.put(UserContract.Users.COL_DATA, data);
int updateCount = db.update(
UserContract.Users.TABLE_NAME,
newData,
UserContract.Users.COL_TITLE + "= ?",
new String[]{title}
);
ContentValues newContent = new ContentValues();
newContent.put(UserContract.Users.COL_CONTENT, content);
int updateCount1 = db.update(
UserContract.Users.TABLE_NAME,
newContent,
UserContract.Users.COL_TITLE + "= ?",
new String[]{title}
);
ContentValues newTitle = new ContentValues();
newTitle.put(UserContract.Users.COL_TITLE, title);
int updateCount2 = db.update(
UserContract.Users.TABLE_NAME,
newTitle,
UserContract.Users.COL_TITLE + "= ?",
new String[]{title}
);
//保存に成功しました。
Toast.makeText(this, R.string.msg_upd, Toast.LENGTH_SHORT).show();
} catch (Exception e) {
Toast.makeText(this, "強制returnしました。", Toast.LENGTH_LONG).show();
}
//updateCount1とか2とかは、エラーのやつでしょ?
} else {
try {
//この下のinsertには、updateのように、textから取得したデータをinsertする
ContentValues newUser = new ContentValues();
newUser.put(UserContract.Users.COL_TITLE, eTxtTitle.toString());
newUser.put(UserContract.Users.COL_CONTENT, eTxtContent.toString());
newUser.put(UserContract.Users.COL_DATA, eTxtData.toString());
long newId = db.insert(UserContract.Users.TABLE_NAME,
null,
newUser
);
//close db
Toast.makeText(this, R.string.msg_upd, Toast.LENGTH_SHORT).show();
} catch (Exception e) {
Toast.makeText(this, "強制returnしました。", Toast.LENGTH_LONG).show();
}
}
db.close();
}
return super.onOptionsItemSelected(item);
}
}
-
気になる質問をクリップする
クリップした質問は、後からいつでもマイページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
クリップを取り消します
-
良い質問の評価を上げる
以下のような質問は評価を上げましょう
- 質問内容が明確
- 自分も答えを知りたい
- 質問者以外のユーザにも役立つ
評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。
質問の評価を上げたことを取り消します
-
評価を下げられる数の上限に達しました
評価を下げることができません
- 1日5回まで評価を下げられます
- 1日に1ユーザに対して2回まで評価を下げられます
質問の評価を下げる
teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。
- プログラミングに関係のない質問
- やってほしいことだけを記載した丸投げの質問
- 問題・課題が含まれていない質問
- 意図的に内容が抹消された質問
- 過去に投稿した質問と同じ内容の質問
- 広告と受け取られるような投稿
評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。
質問の評価を下げたことを取り消します
この機能は開放されていません
評価を下げる条件を満たしてません
質問の評価を下げる機能の利用条件
この機能を利用するためには、以下の事項を行う必要があります。
- 質問回答など一定の行動
-
メールアドレスの認証
メールアドレスの認証
-
質問評価に関するヘルプページの閲覧
質問評価に関するヘルプページの閲覧
+3
もしかしてなんですが、最近dataというカラムを追加したのでは?
CREATE文に新しくカラムを追加してもすでにSQLiteでdbファイルが出来上がっていたら過去のカラムのままだと思います。一度dbファイルを削除するか、ALTER TABLE文などでカラムを追加する必要があります。
投稿
-
回答の評価を上げる
以下のような回答は評価を上げましょう
- 正しい回答
- わかりやすい回答
- ためになる回答
評価が高い回答ほどページの上位に表示されます。
-
回答の評価を下げる
下記のような回答は推奨されていません。
- 間違っている回答
- 質問の回答になっていない投稿
- スパムや攻撃的な表現を用いた投稿
評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。
+1
クリエイト文が間違っています。
SQLに関する質問の場合、SQLも質問に追記してください。
また、あなたは自分のSQL文を確認してから質問していますか?全てを回答してもらうのは非効率です。
投稿
-
回答の評価を上げる
以下のような回答は評価を上げましょう
- 正しい回答
- わかりやすい回答
- ためになる回答
評価が高い回答ほどページの上位に表示されます。
-
回答の評価を下げる
下記のような回答は推奨されていません。
- 間違っている回答
- 質問の回答になっていない投稿
- スパムや攻撃的な表現を用いた投稿
評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。
checkベストアンサー
0
CREATE_TABLE= "create table" + UserContract.Users.TABLE_NAME +"("
+ UserContract.Users._ID + " integer primary key autoincrement, "
+ UserContract.Users.COL_TITLE + " title," // ?
+ UserContract.Users.COL_CONTENT + " content, " // ?
+ UserContract.Users.COL_DATA + "data" // ?
+ ")";
create文がおかしいって過去数回指摘されていますよね?
ちゃんとcreate文について調べました?
前よりもひどくなっているような気がするのですが・・・
投稿
-
回答の評価を上げる
以下のような回答は評価を上げましょう
- 正しい回答
- わかりやすい回答
- ためになる回答
評価が高い回答ほどページの上位に表示されます。
-
回答の評価を下げる
下記のような回答は推奨されていません。
- 間違っている回答
- 質問の回答になっていない投稿
- スパムや攻撃的な表現を用いた投稿
評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。
15分調べてもわからないことは、teratailで質問しよう!
- ただいまの回答率 88.09%
- 質問をまとめることで、思考を整理して素早く解決
- テンプレート機能で、簡単に質問をまとめられる
質問への追記・修正、ベストアンサー選択の依頼
akabee
2017/04/11 13:07
そのエラーの通り、usersテーブルにdataという列がないのでは?確実にあるということを確認されているということですか?接続先を誤ったりしていませんか?
edoooooo
2017/04/11 13:11 編集
ContentValues newUser = new ContentValues(); newUser.put(UserContract.Users.COL_TITLE, eTxtTitle.toString()); newUser.put(UserContract.Users.COL_CONTENT, eTxtContent.toString()); newUser.put(UserContract.Users.COL_DATA, eTxtData.toString());
long newId = db.insert(UserContract.Users.TABLE_NAME, null,
newUser のようにinsertしており、
CREATE_TABLE= "create table " + UserContract.Users.TABLE_NAME + "(" + UserContract.Users._ID+ " integer primary key autoincrement, " + UserContract.Users.COL_TITLE + " title," + UserContract.Users.COL_CONTENT + " content, " + UserContract.Users.COL_DATA + "data" + ")";
このようにテーブルを作っています。
public static final String COL_DATA="data";
そして、このように定義しているので、確実にあるとは思っているのですが、接続先をもう一度見てみます。
SVC34
2017/04/11 13:22 編集
以前の質問に対するアドバイスがまったく活かされていませんね。https://teratail.com/questions/71520 https://teratail.com/questions/71806
edoooooo
2017/04/11 13:35 編集
申し訳ありません。以前のアドバイスでは、createの際にスペースがないためにエラーとなっている、という指摘をうけ、修正し、その後createはいじった記憶がなかったのですが、また同じミスをしていたようです。なおしてみます。
SVC34
2017/04/11 13:41 編集
「一度CREATE_TABLE、INIT_TABLE、DROP_TABLEの中身を出力してSQL構文が合っているか確認された方がいいと思います。」
「データ型の指定がおかしいです」
edoooooo
2017/04/11 13:41
ありがとうございます。ログで出力します。