アンドロイドを使い始め、単純なデータベースを作成しようとしています。ここでデータベースを作成すると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 ...(ショーバルーン)
私は(SQLiteのツールを使用して)前にDBを作成し、展開をお勧めしますそれはあなたのアプリで資産として。より簡単に。 –
これを次に試してみましょうが、この方法で最初にやる方法を学びたい –
このエラーは、Androidスタジオではあなたのアプリを起動することさえできないという。デバッガは動作しません。 –