編輯:關於Android編程
做任何開發都會用的數據庫,Android也一樣,Android一般都要用的兩個數據庫本地數據庫和遠程數據庫,本地數據庫就是sqlite,遠程數據庫的話,我一般用的是mysql,這次先了解下本地數據庫sqlite,一般數據庫類型為varchar(20) 如果你輸入個大於20位的數據時,會報錯,不能插入吧,但是sqlite裡就不一樣了,他就可以,這是sqlite的特色之一吧應該是。下來就看看sqlite的 crud:
MainActivity
package com.example.sqlite; import android.os.Bundle; import android.app.Activity; import android.view.Menu; import android.widget.TextView; public class MainActivity extends Activity { @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); TextView t; DBOpenHelter dbopenhelper=new DBOpenHelter(this); } @Override public boolean onCreateOptionsMenu(Menu menu) { getMenuInflater().inflate(R.menu.activity_main, menu); return true; } }
PersonService
package com.example.sqlite; import com.example.bean.Person; import android.content.Context; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; public class PersonService { private DBOpenHelter dbOpenHelper; public PersonService(Context context){ this.dbOpenHelper=new DBOpenHelter(context); } public void save(Person person){ SQLiteDatabase db=dbOpenHelper.getWritableDatabase(); StringBuilder sql=new StringBuilder(128); //這個沒用 sql.append("insert "); //這個沒用 db.execSQL("insert into person(name,phone) values(?,?)",new Object[]{person.getName(),person.getPhone()}); db.close(); } public Person find(Integer id){ Person person=new Person(); SQLiteDatabase db=dbOpenHelper.getReadableDatabase(); Cursor cursor=db.rawQuery("select * from testpersion wehre name=?",new String[]{id.toString()}); while(cursor.moveToNext()){ int personid=cursor.getInt(cursor.getColumnIndex("id")); } return person; } }
package com.example.sqlite;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;
public class DBOpenHelter extends SQLiteOpenHelper{
public DBOpenHelter(Context context) {
super(context, "itcast.db", null, 1);
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL("CREATE TABLE testpersion(persionid integer primary key autoincrement,name varchar(20))");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// TODO Auto-generated method stub
db.execSQL("ALTER TABLE testpersion ADD phone VARCHAR(12) NULL");
}
}
組合模式 Android中對組合模式的應用,可謂是泛濫成粥,隨處可見,那就是View和ViewGroup類的使用。在android UI設計,幾乎所有的widget和布
昨天,華為榮耀V8已經在華為商城和京東上正式開賣了,榮耀V8是華為榮耀推出的全新V系列手機,它采用了雙卡雙待的模式,擁有5.7英寸大屏,配備了2K分辨率顯示
深受啟發,所以就寫了這遍文章使用文中的方法實現功能的插件化(雖用不同方法來實現的相同功能,但會從(1)中摘錄許多)。在360安全衛士一些應用中,有些功能需要添加(下載)後
上一篇,我們從源碼的角度分析了View的事件分發過程,這篇我們從實例的角度來看看不同實例下具體的輸出會是什麼樣子的呢?好的,我們開始吧!同樣我們的測試布局文件: