2016-07-30 35 views
0

刚刚开始使用android并尝试创建简单的数据库。创建数据库不起作用Android/Android Studio

这里是我的代码:

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(Native Method) 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 2) at com.android.ddmlib.HandleHeap.sendREAQ(HandleHeap.java:349) at com.android.ddmlib.Client.requestAllocationStatus(Client.java:517) at com.android.ddmlib.DeviceMonitor.createClient( DeviceMonitor.java:573) 在com.android.ddmlib.DeviceMonitor.openClient(DeviceMonitor.java:545) 在com.android.ddmlib.DeviceMonitor.processIncomingJdwpData(DeviceMoni ...(秀气球)

+0

我建议创建之前,DB(使用SQLite工具)和部署它作为您的应用中的资产。方式更容易。 –

+0

接下来会尝试这个,但想要学习如何首先这样做 –

+0

错误表示Android Studio甚至无法启动您的应用程序。调试器不起作用。 –

回答

相关问题