2016-07-30 20 views
0

アンドロイドを使い始め、単純なデータベースを作成しようとしています。ここでデータベースを作成するとAndroid/Androidスタジオが動作しません

は私のコードです:

ここ
FoodMacrosTable.java 
public class FoodMacrosTable { 

public static final String DB_NAME = "FoodDatabase.db"; 
public static final int DB_VERSION = 1; 

public class FoodMacros implements BaseColumns { 

    public static final String TABLE_NAME = "FoodMacros"; 


    public static final String FOOD_NAME = "Food name"; 
    public static final String FOOD_PROTEIN = "Amount of protein in 100g"; 
    public static final String FOOD_CARBS = "Amount of carbs in 100g"; 
    public static final String FOOD_FATS = "Amount of fats in 100g"; 
    public static final String FOOD_CALORIES = "Amount of calories in 100g"; 
    public static final String FOOD_VIT_A = "% of daily needs in 100g"; 

    public final String[] TABLE_COLUMNS = {FOOD_NAME,FOOD_PROTEIN,FOOD_CARBS,FOOD_FATS,FOOD_CALORIES, 
      FOOD_VIT_A}; 

} 

}

HealthyDbHanbler.java 

public class HealthyDbHandler extends SQLiteOpenHelper { 

public HealthyDbHandler(Context context){ 
    super(context,FoodMacrosTable.DB_NAME,null,FoodMacrosTable.DB_VERSION); 
} 

@Override 
public void onCreate(SQLiteDatabase sqLiteDatabase) { 
    String createTable = "CREATE TABLE " + FoodMacrosTable.FoodMacros.TABLE_NAME + " (" + 
      FoodMacrosTable.FoodMacros._ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " + 
      FoodMacrosTable.FoodMacros.FOOD_NAME + " TEXT NOT NULL, " + 
      FoodMacrosTable.FoodMacros.FOOD_PROTEIN + " TEXT NOT NULL, " + 
      FoodMacrosTable.FoodMacros.FOOD_CARBS + " TEXT NOT NULL, " + 
      FoodMacrosTable.FoodMacros.FOOD_FATS + " TEXT NOT NULL, " + 
      FoodMacrosTable.FoodMacros.FOOD_CALORIES + " TEXT NOT NULL, " + 
      FoodMacrosTable.FoodMacros.FOOD_VIT_A + " TEXT NOT NULL);"; 

    sqLiteDatabase.execSQL(createTable); 


} 

@Override 
public void onUpgrade(SQLiteDatabase sqLiteDatabase, int i, int i1) { 
    sqLiteDatabase.execSQL("DROP TABLE IF EXISTS " + FoodMacrosTable.FoodMacros.TABLE_NAME); 
    onCreate(sqLiteDatabase); 
} 

public void addFood(Food food){ 
    SQLiteDatabase db = this.getWritableDatabase(); 

    ContentValues values = new ContentValues(); 
    values.put(FoodMacrosTable.FoodMacros.FOOD_NAME,food.getFOOD_NAME()); 
    values.put(FoodMacrosTable.FoodMacros.FOOD_PROTEIN,food.getFOOD_PROTEIN()); 
    values.put(FoodMacrosTable.FoodMacros.FOOD_CARBS,food.getFOOD_CARBS()); 
    values.put(FoodMacrosTable.FoodMacros.FOOD_FATS,food.getFOOD_FATS()); 
    values.put(FoodMacrosTable.FoodMacros.FOOD_CALORIES,food.getFOOD_CALORIES()); 
    values.put(FoodMacrosTable.FoodMacros.FOOD_VIT_A,food.getFOOD_VIT_A()); 

    db.insert(FoodMacrosTable.FoodMacros.TABLE_NAME,null,values); 

    db.close(); 
} 

}

MainActivity.java 
public class MainActivity extends AppCompatActivity { 

@Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 

    HealthyDbHandler db = new HealthyDbHandler(this) ; 
    Log.v("DBINFO","Database created"); 

} 

}

私が取得エラーです: 1時42分56秒PMはバインドできませんデバッガのローカル8600へ 1:42:56 PMホストマシンのソフトウェアによって確立された接続が中止されました java.io.IOException:ホストマシンのソフトウェアによって確立された接続が中止されました at sun.nio.ch .SocketDispatcher.write0(ネイティブメソッド) at sun.nio.ch.SocketDispatcher.write(SocketDispatcher.java:51) at sun.nio.ch.IOUtil.writeFromNativeBuffer(IOUtil.java:93) at sun.nio。 ch.IOUtil.write(IOUtil.java:65) at sun.nio.ch.SocketChannelImpl.write(SocketChannelImpl.java:471) at com.android.ddmlib.JdwpPacket.write(JdwpPacket.java:179) at com.android.ddmlib.Client.send(Client.java:654) at com.android.ddmlib.jdwp.JdwpAgent.send(JdwpAgent.java:9) com.android.ddmlib.DeviceMonitor.createClientでcom.android.ddmlib.Client.requestAllocationStatus(Client.java:517でcom.android.ddmlib.HandleHeap.sendREAQ(HandleHeap.java:349) ) (AT 2) このエラーcom.android.ddmlib.DeviceMonitor.openClientでDeviceMonitor.java:573) (com.android.ddmlib.DeviceMonitor.processIncomingJdwpDataでDeviceMonitor.java:545) (DeviceMoni ...(ショーバルーン)

+0

私は(SQLiteのツールを使用して)前にDBを作成し、展開をお勧めしますそれはあなたのアプリで資産として。より簡単に。 –

+0

これを次に試してみましょうが、この方法で最初にやる方法を学びたい –

+0

このエラーは、Androidスタジオではあなたのアプリを起動することさえできないという。デバッガは動作しません。 –

答えて

0

sqliteやあなたのアプリケーションに関するものではありません。

のAndroidメーカー、ADBサーバー、お使いのデバイスで 再び有効にUSB-デバッグ、または関連するトピックから何かを再起動してみてください(何も助けていない場合) Eclipse DDMS error "Can't bind to local 8600 for debugger"

関連する問題