首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 移动开发 > Android >

Android打开SQList失败,生手求解

2013-06-19 
Android打开SQList失败,新手求解[imghttp://][/img]import android.net.Uriimport android.provider.Bas

Android打开SQList失败,新手求解
[img=http://][/img]

import android.net.Uri;
import android.provider.BaseColumns;

public interface databaseMataData {
//这个是外部访问的AUTHORITY,Content地址为:content//com.example.contentprovider.membercontentprovider
public static final String AUTHORITY="com.example.contentprovider.membercontentprovider";
//数据库名字
public static final String DATABASE_NAME="test";
//数据库版本
public static final int VERSION=1;

public static interface MeberTableMetaData extends BaseColumns{
public static final String TABLE_NAME="member";//表名称
public  static final Uri CONTENT_URI=Uri.parse("content://"+AUTHORITY+"/"+TABLE_NAME);//表的Uri地址

//得到member表中的全部记录
public static final String CONTENT_LIST="vnd.android.cursor.dir/vnd.contentprovider.member";
//取得一个member信息,相当于按ID查询
public static final String CONTENT_ITEM="vnd.android.cursor.item/vnd.contentprovider.member";

public  static final String MEMBER_NAME="name";
public  static final String MEMBER_AGE="age";
public  static final String MEMBER_BIRTHDAY="birthday";

public  static final String SORT_ORDER="_id DESC";//排序操作



}
}

package com.example.contentprovider;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;

public class MydatabaseHelper extends SQLiteOpenHelper {
/*
 * private static final String DATABASENAME="test.db"; private static final
 * int DATABASEVERSION=1; private static final String TABLENAME="member";
 */
public MydatabaseHelper(Context context) {
super(context, databaseMataData.DATABASE_NAME, null,
databaseMataData.VERSION);
}

@Override
public void onCreate(SQLiteDatabase db) {
String sql = "CREATE TABLE"
+ databaseMataData.MeberTableMetaData.TABLE_NAME + "("
+ databaseMataData.MeberTableMetaData._ID
+ "INTEGER PRIMARY KEY,)"
+ databaseMataData.MeberTableMetaData.MEMBER_NAME
+ "VARCHAR(50) NOT NULL,"
+ databaseMataData.MeberTableMetaData.MEMBER_AGE
+ "INTEGER NOT NULL,"
+ databaseMataData.MeberTableMetaData.MEMBER_BIRTHDAY
+ "VARCHAR(50) NOT NULL";
db.execSQL(sql);
}

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
String sql = "DROP TABLE IF EXISTS"
+ databaseMataData.MeberTableMetaData.TABLE_NAME;
db.execSQL(sql);
this.onCreate(db);
}

}

// 增加
@Override
public Uri insert(Uri uri, ContentValues values) {
SQLiteDatabase db=this.helper.getWritableDatabase();//以写方式打开数据库

long id=0;//取得增长后的数据id
switch(uriMatcher.match(uri)){
case GET_MEMBER_LIST:
return null;
case GET_MEMBER_ITEM:
System.out.println("GET_MEMBER_ITEM");
/*id=db.insert(databaseMataData.MeberTableMetaData.TABLE_NAME, databaseMataData.MeberTableMetaData._ID, values);


String uriPath=uri.toString();
System.out.println("****"+uriPath+id);*/
return null;
}
return null;
}


  <provider
            android:name=".MemberContentProvider"
            android:authorities="com.example.contentprovider.membercontentprovider" />

红色处报错
04-25 06:46:52.031: E/Database(335): Failure 1 (near "TABLEmember": syntax error) on 0x2479a8 when preparing 'CREATE TABLEmember(_idINTEGER PRIMARY KEY,)nameVARCHAR(50) NOT NULL,ageINTEGER NOT NULL,birthdayVARCHAR(50) NOT NULL'.
04-25 06:46:52.081: E/AndroidRuntime(335): android.database.sqlite.SQLiteException: near "TABLEmember": syntax error: CREATE TABLEmember(_idINTEGER PRIMARY KEY,)nameVARCHAR(50) NOT NULL,ageINTEGER NOT NULL,birthdayVARCHAR(50) NOT NULL
Android SQL
[解决办法]
引用:
[img=http://][/img]


Plain Text code
?



123456789101112131415161718192021222324252627282930

import android.net.Uri; import android.provider.BaseColumns;   public interface databaseMataDa……


是由于你写的sql语句有问题,注意字段之间的间隙 并且注意括号位置也错误了

        String sql = "CREATE TABLE "                 
+ databaseMataData.MeberTableMetaData.TABLE_NAME + " ( "                 
+ databaseMataData.MeberTableMetaData._ID                 
+ " INTEGER PRIMARY KEY,"                 
+ databaseMataData.MeberTableMetaData.MEMBER_NAME                 
+ " VARCHAR(50) NOT NULL,"                 
+ databaseMataData.MeberTableMetaData.MEMBER_AGE                 
+ " INTEGER NOT NULL,"                 + databaseMataData.MeberTableMetaData.MEMBER_BIRTHDAY                 
+ " VARCHAR(50) NOT NULL" + " )"; 

热点排行