现在android下,需要对表user(id,username)
进行 增 删 改 查
现问:1 在哪建表呀
      2 如何连表呀
      3 如何操作表呀
新手上路,请daxia指教,thanks

解决方案 »

  1.   

    你这个。先找点资料看看吧   关于sqlite的 
    db = this.openOrCreateDatabase(Datainfo.DATABASE_NAME, MODE_PRIVATE,
    null);
    String sql = "CREATE TABLE Teacher (" + ID
    + " text not null, " + NAME + " text not null," + COURSE
    + " text not null," + SCORE + " text not null " + ");";
    try {
    db.execSQL("DROP TABLE IF EXISTS T" + Teacherinfo.userID);
    db.execSQL(sql);
    } catch (SQLException e) {
    }
    这是最简单的创建的方法
      

  2.   

    在网上找点视频看看吧,谁一两句也跟你说不清楚。mars老师的视频不错。电驴上面有不少资源,可以利用一下。
      

  3.   

    先看点SQLite在看看正面的语句一切OK……
    package com.android.example.SQLiteSample1;import android.app.Activity;
    import android.content.Context;
    import android.database.Cursor;
    import android.database.SQLException;
    import android.database.sqlite.SQLiteDatabase;
    import android.database.sqlite.SQLiteOpenHelper;
    import android.os.Bundle;
    import android.util.Log;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.widget.Button;public class SQLiteSample1 extends Activity {
    OnClickListener listener1 = null;
    OnClickListener listener2 = null;
    OnClickListener listener3 = null;
    OnClickListener listener4 = null;
    OnClickListener listener5 = null; Button button1;
    Button button2;
    Button button3;
    Button button4;
    Button button5; DatabaseHelper mOpenHelper; private static final String DATABASE_NAME = "dbForTest.db";
    private static final int DATABASE_VERSION = 1;
    private static final String TABLE_NAME = "diary";
    private static final String TITLE = "title";
    private static final String BODY = "body"; /*
     * SQLiteOpenHelper类:一个用于数据库的创建和版本管理的帮助类
     * 实现 onCreate(SQLiteDatabase)、onUpgrade(SQLiteDatabase, int, int)
     * 和可选的 onOpen(SQLiteDatabase),来创建子类,一定要注意数据操作过程
     * 中的事务提交Transaction
     * */
    private static class DatabaseHelper extends SQLiteOpenHelper {
    DatabaseHelper(Context context) {
    super(context, DATABASE_NAME, null, DATABASE_VERSION);
    } @Override
    public void onCreate(SQLiteDatabase db) { String sql = "CREATE TABLE " + TABLE_NAME + " (" + TITLE
    + " text not null, " + BODY + " text not null " + ");";
    /*打印出转换的SQL语句*/
    Log.i("SQLite:createDB=", sql);
    db.execSQL(sql); } @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    }
    } @Override
    public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    /*注册按钮的click回调,不同按钮对应不同的数据库操作*/
    prepareListener();
    /*初始化按钮click监听*/
    initLayout();
    /*获取一个数据库Helper类的一个对象*/
    mOpenHelper = new DatabaseHelper(this); } private void initLayout() {
    button1 = (Button) findViewById(R.id.button1);
    button1.setOnClickListener(listener1); button2 = (Button) findViewById(R.id.button2);
    button2.setOnClickListener(listener2); button3 = (Button) findViewById(R.id.button3);
    button3.setOnClickListener(listener3);
    button4 = (Button) findViewById(R.id.button4);
    button4.setOnClickListener(listener4); button5 = (Button) findViewById(R.id.button5);
    button5.setOnClickListener(listener5); } private void prepareListener() {
    listener1 = new OnClickListener() {
    public void onClick(View v) {
    CreateTable();
    }
    };
    listener2 = new OnClickListener() {
    public void onClick(View v) {
    dropTable();
    }
    };
    listener3 = new OnClickListener() {
    public void onClick(View v) {
    insertItem();
    }
    };
    listener4 = new OnClickListener() {
    public void onClick(View v) {
    deleteItem();
    }
    };
    listener5 = new OnClickListener() {
    public void onClick(View v) {
    showItems();
    }
    };
    } /*
     * 重新建立数据表
     */
    private void CreateTable() {
    /*
     * getWritableDatabase:创建或打开一个用来读和写的数据库,
     * 一旦打开成功,数据库进入缓存,每次需要写数据到DB中,
     * 都调用该函数,如果你不在需要对该数据进行操作,最后请
     * 调用close函数关闭
     * */
    SQLiteDatabase db = mOpenHelper.getWritableDatabase();
    String sql = "CREATE TABLE " + TABLE_NAME + " (" + TITLE
    + " text not null, " + BODY + " text not null " + ");";
    Log.i("SQLite:createDB=", sql); try {
    db.execSQL("DROP TABLE IF EXISTS diary");
    db.execSQL(sql);
    setTitle("数据表成功重建");
    } catch (SQLException e) {
    setTitle("数据表重建错误");
    }
    } /*
     * 删除数据表
     */
    private void dropTable() {
    /*获取数据库缓存*/
    SQLiteDatabase db = mOpenHelper.getWritableDatabase();
    String sql = "drop table " + TABLE_NAME;
    try {
    db.execSQL(sql);
    setTitle("数据表成功删除:" + sql);
    } catch (SQLException e) {
    setTitle("数据表删除错误");
    }
    } /*
     * 插入两条数据
     */
    private void insertItem() {
    SQLiteDatabase db = mOpenHelper.getWritableDatabase();
    String sql1 = "insert into " + TABLE_NAME + " (" + TITLE + ", " + BODY
    + ") values('insert1', 'For Test');";
    String sql2 = "insert into " + TABLE_NAME + " (" + TITLE + ", " + BODY
    + ") values('insert2', '测试');";
    try {
    Log.i("SQLite:sql1=", sql1);
    Log.i("SQLite:sql2=", sql2);
    /*execSQL函数一次只支持一个SQL语句,如果我们要插入多个,必须调用多次*/
    db.execSQL(sql1);
    db.execSQL(sql2);
    setTitle("插入两条数据成功");
    } catch (SQLException e) {
    setTitle("插入两条数据失败");
    }
    } /*
     * 删除其中的一条数据
     */
    private void deleteItem() {
    try {
    SQLiteDatabase db = mOpenHelper.getWritableDatabase();
    db.delete(TABLE_NAME, " title = 'insert1'", null);
    setTitle("删除title为insert1的一条记录");
    } catch (SQLException e) { } } /*
     * 在屏幕的title区域显示当前数据表当中的数据的条数。
     */
    private void showItems() {
    /*获取读取数据的句柄*/
    SQLiteDatabase db = mOpenHelper.getReadableDatabase();
    String col[] = { TITLE, BODY };
    Cursor cur = db.query(TABLE_NAME, col, null, null, null, null, null);
    Integer num = cur.getCount();
    setTitle(Integer.toString(num) + " 条记录");
    }
    }
      

  4.   

    推荐 那个mars老师  的视频 挺不错的
      

  5.   

    看一看关于SQLiteOpenHelper,SQLiteDatabase, Cursor等有关的资料吧..
      

  6.   

    楼主需要补习下 sql 的相关知识了。显示全部记录,修改记录,这些都是 sql 语句最基本的操作啊。至于 sqlite 只要用过数据库的 ,看看就会了,无非就是几个 api 的事。最终还是要 执行 sql 语句的。
      

  7.   

    http://blog.csdn.net/ch_984326013/article/details/6621647
      

  8.   

    楼主可以看一下我写的文章:
    http://blog.csdn.net/redoffice/article/details/6695345就看SQLite那一部分就可以了。