『壹』 Android資料庫操作表的兩種方法,通過sql 語句法和谷歌提供的api 方法進行比較情況如何
DirverManager類:是JDBC的管理層,作用於用戶和驅動之間。該類負責注冊和載入JDBC驅動。
Connection介面:代表與資料庫的鏈接,並擁有創建SQL語句的方法,以完成基本的SQL操作,同時為資料庫事務提供提交和回滾方法。如:上面的例子就是鏈接到了TestData資料庫。
Statement介面:用於執行不帶參數的簡單SQL語句。創建Statement實例對象後可以調用JDBC提供的3種執行SQL語句的方法:
(1)executeUpdate()方法,一般用於執行SQL的INSERT,DELETE,UPDATE語句
(2)executeQuery()方法,一般用於執行SQL的SELECT語句,因為 它的返回值是執行SQL語句後產生的一個ResultSet介面的實例(結果集)
(3)execute()方法,即一般它執行的SQL語句既有查詢又有更新值,約等於executeUpdate()和executeQuery()兩個方法的合輯。
PreparedStatement介面:它與Statement 的主要區別
(1)它包含的SQL語句是預編譯的,所以當多次執行一條SQL語句時用它會更快
(2)在設置參數是可以用「?」代替。如:
PreparedStatement pstmt=conn.preparedStatement(insert into test values(?,?));
pstmt.setString(1,'gg');
pstmt.setString(2,'123');
ResultSet介面:包含了Statement和PreparedStatement的executeQuery方法中SELECT的結果集。相當於用它來讀取資料庫里每列的值。
DatabaseMetaData介面:主要是用來得到資料庫的相關信息的。如:資料庫版本啊
ResultSetMetaData介面:主要是用來獲取資料庫中表的相關信息的。如:表的行數啊。,謝謝
『貳』 android 怎麼查看資料庫中的數據
1,進入到控制台中,輸入adb shell,進入到命令模式的環境中
2,輸入:cd /data/data/
3, 選擇你所在的資料庫文件,比如我的com.android.homework, 輸入命令:cd com.android.homework
4, 可以使用ls -l 命令查看當前目錄中的文件
5,輸入: cd databases 進入到資料庫文件中
6, ls -l 顯示你資料庫中你建立的資料庫
7, sqlite3 info.db 進入到你選擇的資料庫中
8, .tables :查看你建的表
9, select * from table_name;s 可以查看整個表的信息
10, 使用其他的SQL語句可以進一步對表進行操作,注意SQL語句必須用分號(;)結尾
『叄』 android app如何從資料庫中獲取需要的數據
Android 不自動提供資料庫。在 Android 應用程序中使用 SQLite,必須自己創建資料庫,然後創建表、索引,填充數據。Android 提供了 SQLiteOpenHelper 幫助你創建一個資料庫,你只要繼承 SQLiteOpenHelper 類,就可以輕松的創建資料庫。SQLiteOpenHelper 類根據開發應用程序的需要,封裝了創建和更新資料庫使用的邏輯。SQLiteOpenHelper 的子類,至少需要實現三個方法:
構造函數,調用父類 SQLiteOpenHelper 的構造函數
onCreate()方法;// TODO 創建資料庫後,對資料庫的操作
onUpgrage()方法。// TODO 更改資料庫版本的操作
當你完成了對資料庫的操作(例如你的 Activity 已經關閉),需要調用 SQLiteDatabase 的 Close() 方法來釋放掉資料庫連接。
操作資料庫的最佳實踐是創建一個輔助類,例如聯系人模塊
class ContactsDatabaseHelper extends SQLiteOpenHelper
3.2 Cursor類
Android使用Cursor類返回一個需要的值,Cursor作為一個指針從資料庫查詢返回結果集,使用Cursor允許Android更有效地管理它們需要的行和列,你使用ContentValues對象存儲鍵/值對,它的put()方法允許你插入不同數據類型的鍵值。
3.3 數據類型
SQLite 和其他資料庫最大的不同就是對數據類型的支持,創建一個表時,可以在 CREATE TABLE 語句中指定某列的數據類型,但是你可以把任何數據類型放入任何列中。當某個值插入資料庫時,SQLite 將檢查它的類型。如果該類型與關聯的列不匹配,則 SQLite 會嘗試將該值轉換成該列的類型。如果不能轉換,則該值將作為其本身具有的類型存儲。比如可以把一個字元串(String)放入 INTEGER 列。SQLite 稱這為「弱類型」(manifest typing.)。
四、資料庫操作
4.1創建和打開資料庫
在Android中創建和打開一個資料庫都可以使用openOrCreateDatabase方法來實現,因為它會自動去檢測是否存在這個資料庫,如果存在則打開,如果不存在則創建一個資料庫:創建成功則返回一個SQLiteDatebase對象,否則拋出異常FileNotFoundException。
下面我們來創建一個名為Test的資料庫,並返回一個SQLiteDatabase對象mSQLiteDatabase。
mSQLiteDatabase=this.openOrCreateDatabase("Test",MODE_PRIVATE,null);
4.2創建表
通過execSQL方法來執行一條SQL語句。
String CREATE_TABLE="create table 表名(列名,列名,……)";
mSQLiteDatabase.execSQL(CREATE_TABLE);
創建表的時候總要確定一個主鍵,這個欄位是64位整型,別名_rowid。其特點就是自增長功能。當到達最大值時,會搜索該欄位未使用的值(某些記錄被刪除_rowid會被回收),所以要唯一嚴格增長的自動主鍵必須加入關鍵字autoincrement。
4.3刪除表
mSQLiteDatabase("drop table 表名");
『肆』 android sqlite怎麼讀取資料庫
第一步先判斷在指定的路勁是否存在,不存在就創建。第二步將android的資源下的資料庫復制到指定路徑下面。第三步就是根據指定路徑打開或者創建資料庫,然後得到操作資料庫的對象,得到操作資料庫的對象了,自然就可以對資料庫中的表進行增刪改查等操作了。
[java] view plain print?
<span style="font-size:12px;">SQLiteDatabase db;
private final String DATABASE_PATH = android.os.Environment
.getExternalStorageDirectory().getAbsolutePath() + "/vote";
private String DATABASE_FILENAME = "db_vote.db";
// 初始化資料庫
private SQLiteDatabase openDatabase() {
try {
String databaseFilename = DATABASE_PATH + "/" + DATABASE_FILENAME;
File dir = new File(DATABASE_PATH);
if (!dir.exists())
dir.mkdir();
if (!(new File(databaseFilename)).exists()) {
InputStream is = getResources().openRawResource(R.raw.db_vote);
FileOutputStream fos = new FileOutputStream(databaseFilename);
byte[] buffer = new byte[8192];
int count = 0;
while ((count = is.read(buffer)) > 0) {
fos.write(buffer, 0, count);
}
fos.close();
is.close();
}
db = SQLiteDatabase.openOrCreateDatabase(databaseFilename, null);
return db;
} catch (Exception e) {
e.printStackTrace();
}
return null;
}</span>
方法二:
1. 准備SQLite database文件
假設你已經創建了一個sqlite資料庫,我們需要對其進行一些修改。
(譯者註:這里原文是推薦了一個SQLite資料庫管理軟體,這個我覺得可以隨自己的喜好,最Windows下面有多款可視化的SQlite資料庫管理軟體,可以方便的讀取,編輯資料庫,例如我用的是sqlitestudio
打開資料庫,添加一個新的table 「android_metadata",插入一行數據,具體的SQL如下:
『伍』 android 查詢資料庫有幾個表
rawquery("select
*
from
kechengbiao
where
week
=
?
and
firstweek
<
?
and
lastweek
>
?",
new
string[]{weekday,"5","1"});
這樣得到的sql查詢語句為:
select
*
from
kechengbiao
where
week=weekday(這里應該是你的weekday代表的字元串)
and
firstweek
<
5
and
lastweek
>
1
如果你想在sql語句中使用字元串,需要在new
string[]{}中修改,比如
rawquery("select
*
from
kechengbiao
where
kecheng
=
?",
new
string[]{"'english'"});//注意english前後分別有一個雙引號和一個單引號
得到的sql查詢語句為:
select
*
from
kechengbiao
where
kecheng
=
'english'
『陸』 android中在怎麼獲取資料庫數據
android讀取資料庫可以使用sqlite一些api進行讀取,實例如下:
/**
* 查找一條數據
* @param uid
*/
public User find(Integer uid){
SQLiteDatabase db=dbOpenHelper.getReadableDatabase(); //創建資料庫輔助類
Cursor cursor =db.rawQuery("select * from user where uid=?", new String[]{uid.toString()}); //創建一個游標
if(cursor.moveToFirst()){ //循環遍歷查找數組
int uid2=cursor.getInt(cursor.getColumnIndex("uid"));
String uname=cursor.getString(cursor.getColumnIndex("uname"));
String uaddress=cursor.getString(cursor.getColumnIndex("uaddress"));
User user=new User();
user.setUid(uid2);
user.setUname(uname);
user.setUaddress(uaddress);
return user;
}
cursor.close();
return null;
}
『柒』 android 怎麼讀取sqlite資料庫
SQLite介紹
SQLite是輕量級的、嵌入式的、關系型資料庫,目前已經在iPhone、Android等手機系統中使用,SQLite可移植性好,很容易使用,很小,高效而且可靠。SQLite嵌入到使用它的應用程序中,它們共用相同的進程空間,而不是單獨的一個進程。從外部看,它並不像一個RDBMS,但在進程內部,它卻是完整的,自包含的資料庫引擎。
在android中當需要操作SQLite資料庫的時候需要得到一個SQLiteOpenHelper對象,而SQLiteOpenHelper是一個抽象類,用戶需要繼承這個類,並實現該類中的一些方法。
1、繼承SQLiteOpenHelper之後就擁有了以下兩個方法:
◆getReadableDatabase() 創建或者打開一個查詢資料庫
◆getWritableDatabase()創建或者打開一個可寫資料庫
◆他們都會返回SQLiteDatabase對象,用戶通過得到的SQLiteDatabase對象進行後續操作
2、同時用戶還可以覆蓋以下回調函數,再對資料庫進行操作的時候回調以下方法:
◆onCreate(SQLiteDatabase):在資料庫第一次創建的時候會調用這個方法,一般我們在這個方法里邊創建資料庫表。
◆onUpgrade(SQLiteDatabase,int,int):當資料庫需要修改的時候,Android系統會主動的調用這個方法。一般我們在這個方法里邊刪除資料庫表,並建立新的資料庫表,當然是否還需要做其他的操作,完全取決於應用程序的需求。
◆onOpen(SQLiteDatabase):這是當打開資料庫時的回調函數,一般也不會用到。
需要注意
1、在SQLiteOepnHelper的子類當中,必須有以下該構造函數
public DatabaseHelper(Context context, String name, CursorFactory factory, int version) { //必須通過super調用父類當中的構造函數 super(context, name, factory, version); }為了方便,也可以創建其它的構造函數,含二個參數或者三個參數的。
2、函數public void onCreate(SQLiteDatabase db)是在調用getReadableDatabase()或者是getWritableDatabase()第一次創建資料庫的時候執行,實際上是在第一次得到SQLiteDatabse對象的時候,才會調用這個方法.
public void onCreate(SQLiteDatabase db) { System.out.println("create a Database"); //execSQL函數用於執行SQL語句 db.execSQL("create table user(id int,name varchar(20))"); }在向資料庫的表中插入記錄時,需要先將數據包含在一個ContentValues中,向該對象當中插入鍵值對,其中鍵是列名,值是希望插入到這一列的值,值必須和資料庫當中的數據類型一致。接著調用Databasehelper的getWritableDatabase方法來獲得可以寫入的Databasehelper對象,再向其中insert記錄。注意調用DatabaseHelper對象的insert,update或者query方法的參數的傳遞。
另外執行query方法後,返回的是一個Cursor游標,游標最開始指向的是記錄集合中第一行的上一行,因此首先需要先調用cursor.next()將游標移動到記錄集合的第一行,接著再獲取數據即可。
Java代碼
public class SQLiteActivity extends Activity { /** Called when the activity is first created. */ private Button createButton; private Button insertButton; private Button updateButton; private Button updateRecordButton; private Button queryButton; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); createButton = (Button)findViewById(R.id.createDatabase); updateButton = (Button)findViewById(R.id.updateDatabase); insertButton = (Button)findViewById(R.id.insert); updateRecordButton = (Button)findViewById(R.id.update); queryButton = (Button)findViewById(R.id.query); createButton.setOnClickListener(new CreateListener()); updateButton.setOnClickListener(new UpdateListener()); insertButton.setOnClickListener(new InsertListener()); updateRecordButton.setOnClickListener(new UpdateRecordListener()); queryButton.setOnClickListener(new QueryListener()); } class CreateListener implements OnClickListener{ @Override public void onClick(View v) { //創建一個DatabaseHelper對象 DatabaseHelper dbHelper = new DatabaseHelper(SQLiteActivity.this,"test_mars_db"); //只有調用了DatabaseHelper對象的getReadableDatabase()方法,或者是getWritableDatabase()方法之後,才會創建,或打開一個資料庫 SQLiteDatabase db = dbHelper.getReadableDatabase(); } } class UpdateListener implements OnClickListener{ @Override public void onClick(View v) { DatabaseHelper dbHelper = new DatabaseHelper(SQLiteActivity.this,"test_mars_db",2); SQLiteDatabase db = dbHelper.getReadableDatabase(); } } class InsertListener implements OnClickListener{ @Override public void onClick(View v) { //生成ContentValues對象 ContentValues values = new ContentValues(); //想該對象當中插入鍵值對,其中鍵是列名,值是希望插入到這一列的值,值必須和資料庫當中的數據類型一致 values.put("id", 1); values.put("name","zhangsan"); DatabaseHelper dbHelper = new DatabaseHelper(SQLiteActivity.this,"test_mars_db",2); SQLiteDatabase db = dbHelper.getWritableDatabase(); //調用insert方法,就可以將數據插入到資料庫當中 db.insert("user", null, values); } } //更新操作就相當於執行SQL語句當中的update語句 //UPDATE table_name SET XXCOL=XXX WHERE XXXXCOL=XX... class UpdateRecordListener implements OnClickListener{ @Override public void onClick(View arg0) { // TODO Auto-generated method stub //得到一個可寫的SQLiteDatabase對象 DatabaseHelper dbHelper = new DatabaseHelper(SQLiteActivity.this,"test_mars_db"); SQLiteDatabase db = dbHelper.getWritableDatabase(); ContentValues values = new ContentValues(); values.put("name", "zhangsanfeng"); //第一個參數是要更新的表名 //第二個參數是一個ContentValeus對象 //第三個參數是where子句 db.update("user", values, "id=?", new String[]{"1"}); } } class QueryListener implements OnClickListener{ @Override public void onClick(View v) { System.out.println("aaa------------------"); Log.d("myDebug", "myFirstDebugMsg"); DatabaseHelper dbHelper = new DatabaseHelper(SQLiteActivity.this,"test_mars_db"); SQLiteDatabase db = dbHelper.getReadableDatabase(); Cursor cursor = db.query("user", new String[]{"id","name"}, "id=?", new String[]{"1"}, null, null, null); while(cursor.moveToNext()){ String name = cursor.getString(cursor.getColumnIndex("name")); System.out.println("query--->" + name); } } } }