Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/370.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java SQLite数据库文件中有一个错误。请告诉我如何更正它_Java_Android_Sqlite - Fatal编程技术网

Java SQLite数据库文件中有一个错误。请告诉我如何更正它

Java SQLite数据库文件中有一个错误。请告诉我如何更正它,java,android,sqlite,Java,Android,Sqlite,当我运行此项目时,SQLite数据库文件中出现错误应用程序被强制关闭,并在第36行中指出错误请告诉我如何更正。。。。。 在这里输入代码 package com.flocate import com.flocator.R;`enter code here` import android.app.Activity; import android.content.Context; import android.content.Intent; import and

当我运行此项目时,SQLite数据库文件中出现错误应用程序被强制关闭,并在第36行中指出错误请告诉我如何更正。。。。。 在这里输入代码 package com.flocate

    import com.flocator.R;`enter code here`
    import android.app.Activity;
    import android.content.Context;
    import android.content.Intent;
    import android.database.Cursor;
    import android.database.sqlite.SQLiteDatabase;
    import android.os.Bundle;
    import android.telephony.TelephonyManager;
    import android.view.View;
    import android.widget.EditText;
    import android.widget.Toast;



    public class Friendfinderactivity extends Activity {
        /** C`

    `alled when the activity is first created. */
        String deviceid = "";


        String device_id = "";
        String user_id = "";

        @Override
        public void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);

            DBHelper dbhelper = new DBHelper(this);
            SQLiteDatabase db = dbhelper.getWritableDatabase();

            TelephonyManager tm = (TelephonyManager) this
                    .getSystemService(Context.TELEPHONY_SERVICE);

            deviceid = tm.getDeviceId();

            Cursor cursor = db.rawQuery("select * from"
                    + DBHelper.SUBSCRIBE_TABLE_NAME, null);

            int rows = cursor.getCount();

            if (rows > 0) {
                cursor.moveToFirst();
                user_id = cursor.getString(0);
                device_id = cursor.getString(3);
            }
            db.close();
            if (device_id.equals(deviceid)) {
                setContentView(R.layout.subscriber);
            } else
                setContentView(R.layout.subscribe);
        }

        public void subscribeUser(View v) {
            // get access to views
            EditText editName = (EditText) this.findViewById(R.id.editName);
            EditText editPhone = (EditText) this.findViewById(R.id.editPhone);
            EditText editArea = (EditText) this.findViewById(R.id.editArea);
            EditText editCity = (EditText) this.findViewById(R.id.editCity);

            boolean done = DBHelper.AddFriends(this, editName.getText().toString(),
                    editPhone.getText().toString(), deviceid, editArea.getText()
                            .toString(), editCity.getText().toString());

            if(done) {
                Toast.makeText(this, "Subscribed Successfully!", Toast.LENGTH_LONG).show();
                Intent intent = new Intent(this,Friendfinderactivity.class);
                startActivity(intent);
            }
            else
                Toast.makeText(this, "Sorry! Could not subscribe!", Toast.LENGTH_LONG).show();
        }

        public void addFriends(View v) {
            Intent intent = new Intent(this,AddFriends.class);
            startActivity(intent);
        }

        public void viewFriends(View v) {
            Intent intent = new Intent(this,SeeFriends.class);
            startActivity(intent);
        }

        public void seeLocation(View v) {
            Intent intent = new Intent(this,SeeFriends.class);
            startActivity(intent);
        }

        public void updateDetails(View v) {
            Intent intent = new Intent(this,UpdateFriends.class);
            intent.putExtra("userid", user_id);
            startActivity(intent);
        }
    }

ERROR MESSAGE :
05-20 02:04:45.380: E/SQLiteLog(1851): (1) near "fromnull": syntax error
05-20 02:04:45.381: E/AndroidRuntime(1851): FATAL EXCEPTION: main
05-20 02:04:45.381: E/AndroidRuntime(1851): Process: com.flocator, PID: 1851
05-20 02:04:45.381: E/AndroidRuntime(1851): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.flocator/com.flocater.Friendfinderactivity}: android.database.sqlite.SQLiteException: near "fromnull": syntax error (code 1): , while compiling: select * fromnull
05-20 02:04:45.381: E/AndroidRuntime(1851):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2298)
05-20 02:04:45.381: E/AndroidRuntime(1851):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360)
05-20 02:04:45.381: E/AndroidRuntime(1851):     at android.app.ActivityThread.access$800(ActivityThread.java:144)
05-20 02:04:45.381: E/AndroidRuntime(1851):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278)
05-20 02:04:45.381: E/AndroidRuntime(1851):     at android.os.Handler.dispatchMessage(Handler.java:102)
05-20 02:04:45.381: E/AndroidRuntime(1851):     at android.os.Looper.loop(Looper.java:135)
05-20 02:04:45.381: E/AndroidRuntime(1851):     at android.app.ActivityThread.main(ActivityThread.java:5221)
05-20 02:04:45.381: E/AndroidRuntime(1851):     at java.lang.reflect.Method.invoke(Native Method)
05-20 02:04:45.381: E/AndroidRuntime(1851):     at java.lang.reflect.Method.invoke(Method.java:372)
05-20 02:04:45.381: E/AndroidRuntime(1851):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
05-20 02:04:45.381: E/AndroidRuntime(1851):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
05-20 02:04:45.381: E/AndroidRuntime(1851): Caused by: android.database.sqlite.SQLiteException: near "fromnull": syntax error (code 1): , while compiling: select * fromnull
05-20 02:04:45.381: E/AndroidRuntime(1851):     at android.database.sqlite.SQLiteConnection.nativePrepareStatement(Native Method)
05-20 02:04:45.381: E/AndroidRuntime(1851):     at android.database.sqlite.SQLiteConnection.acquirePreparedStatement(SQLiteConnection.java:889)
05-20 02:04:45.381: E/AndroidRuntime(1851):     at android.database.sqlite.SQLiteConnection.prepare(SQLiteConnection.java:500)
05-20 02:04:45.381: E/AndroidRuntime(1851):     at android.database.sqlite.SQLiteSession.prepare(SQLiteSession.java:588)
05-20 02:04:45.381: E/AndroidRuntime(1851):     at android.database.sqlite.SQLiteProgram.<init>(SQLiteProgram.java:58)
05-20 02:04:45.381: E/AndroidRuntime(1851):     at android.database.sqlite.SQLiteQuery.<init>(SQLiteQuery.java:37)
05-20 02:04:45.381: E/AndroidRuntime(1851):     at android.database.sqlite.SQLiteDirectCursorDriver.query(SQLiteDirectCursorDriver.java:44)
05-20 02:04:45.381: E/AndroidRuntime(1851):     at android.database.sqlite.SQLiteDatabase.rawQueryWithFactory(SQLiteDatabase.java:1316)
05-20 02:04:45.381: E/AndroidRuntime(1851):     at android.database.sqlite.SQLiteDatabase.rawQuery(SQLiteDatabase.java:1255)
05-20 02:04:45.381: E/AndroidRuntime(1851):     at com.flocater.Friendfinderactivity.onCreate(Friendfinderactivity.java:37)
05-20 02:04:45.381: E/AndroidRuntime(1851):     at android.app.Activity.performCreate(Activity.java:5933)
05-20 02:04:45.381: E/AndroidRuntime(1851):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1105)
05-20 02:04:45.381: E/AndroidRuntime(1851):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2251)
05-20 02:04:45.381: E/AndroidRuntime(1851):     ... 10 more
问题1:在from和后面添加空格


问题2:您的DBHelper.SUBSCRIBE\u TABLE\u NAME似乎解析为null

检查SUBSCRIBE\u TABLE\u NAME=DBHelper中的null编译时:select*fromnull-您需要一个表名,请使用空格将select*from更改为“select*from”。您的logcat cleary在fromnull:语法错误附近显示了1。你知道为什么会有logcat吗?是的,我尝试了你给出的解决方案,但没有解决相同的错误,所以请告诉我另一种解决方案来纠正它…这是正确的吗??:Cursor Cursor=db.rawQueryselect*from+DBHelper.SUBSCRIBE\u TABLE\u NAME,null;是的,它应该可以工作,但您的“DBHelper.SUBSCRIBE_TABLE_NAME”可能仍然返回“null”嗨,我确信我的应用程序不工作,请提供您的电子邮件id我发送我的应用程序,然后请更正我的错误。。。
Cursor cursor = db.rawQuery("select * from"
                    + DBHelper.SUBSCRIBE_TABLE_NAME, null);