2011-03-19 15 views
6

मैंने इस अपवाद के बारे में अन्य प्रश्नों को देखा है, लेकिन उनमें से सभी को समाधान के साथ हल किया गया है कि निर्दिष्ट प्राथमिक कुंजी के साथ एक पंक्ति पहले से मौजूद है। यह मेरे लिए मामला प्रतीत नहीं होता है। मैंने दोहरे उद्धरणों के साथ अपने तारों में सभी सिंगल कोट्स को बदलने की कोशिश की है, लेकिन एक ही समस्या होती है।एंड्रॉइड SQLiteConstraintException: त्रुटि कोड 19: बाधा विफल

मैं SQLite डेटाबेस मैं ऐसा करके बना लिया है की सेटिंग तालिका में एक पंक्ति सम्मिलित करने के लिए कोशिश कर रहा हूँ निम्नलिखित:

private static String CREATE_SETTINGS_TABLE = "CREATE TABLE IF NOT EXISTS " + Settings.SETTINGS_TABLE_NAME + "(" 
+ Settings.SETTING_UNIQUE_ID + " TEXT NOT NULL PRIMARY KEY, " 
+ Settings.SETTING_DEVICE_ID + " TEXT NOT NULL , " 
+ Settings.SETTING_CONNECTION_PREFERENCE + " TEXT NOT NULL CHECK("+Settings.SETTING_CONNECTION_PREFERENCE+" IN("+Settings.SETTING_CONNECTION_PREFERENCE_ALLOWED+")), " 
+ Settings.SETTING_AD_HOC_ENABLED + " TEXT NOT NULL CHECK("+Settings.SETTING_AD_HOC_ENABLED+" IN("+Settings.SETTING_AD_HOC_ENABLED_ALLOWED+")), " 
+ Settings.SETTING_SERVER_ADDRESS + " TEXT NOT NULL, " 
+ Settings.SETTING_RECORDING_MODE + " TEXT NOT NULL CHECK("+Settings.SETTING_RECORDING_MODE+" IN("+Settings.SETTING_RECORDING_MODE_ALLOWED+")), " 
+ Settings.SETTING_PREVIEW_ENABLED + " TEXT NOT NULL CHECK("+Settings.SETTING_PREVIEW_ENABLED+" IN("+Settings.SETTING_PREVIEW_ENABLED_ALLOWED+")), " 
+ Settings.SETTING_PICTURE_RESOLUTION_X + " TEXT NOT NULL, " 
+ Settings.SETTING_PICTURE_RESOLUTION_Y + " TEXT NOT NULL, " 
+ Settings.SETTING_VIDEO_RESOLUTION_X + " TEXT NOT NULL, " 
+ Settings.SETTING_VIDEO_RESOLUTION_Y + " TEXT NOT NULL, " 
+ Settings.SETTING_VIDEO_FPS + " TEXT NOT NULL, " 
+ Settings.SETTING_AUDIO_BITRATE_KBPS + " TEXT NOT NULL, " 
+ Settings.SETTING_STORE_TO_SD + " TEXT NOT NULL CHECK("+Settings.SETTING_STORE_TO_SD+" IN("+Settings.SETTING_STORE_TO_SD_ALLOWED+")), " 
+ Settings.SETTING_STORAGE_LIMIT_MB + " TEXT NOT NULL)"; 
:

db.execSQL("DROP TABLE IF EXISTS "+Settings.SETTINGS_TABLE_NAME + ";"); 
db.execSQL(CREATE_MEDIA_TABLE); 
db.execSQL(CREATE_SETTINGS_TABLE); 
Cursor c = getAllSettings(); 
//If there isn't already a settings row, create a row full of defaults 
if(c.getCount()==0){ 
    ContentValues cv = new ContentValues(); 
    cv.put(Settings.SETTING_UNIQUE_ID, "'"+Settings.uniqueID+"'");   
    cv.put(Settings.SETTING_DEVICE_ID, Settings.SETTING_DEVICE_ID_DEFAULT); 
    cv.put(Settings.SETTING_CONNECTION_PREFERENCE, Settings.SETTING_CONNECTION_PREFERENCE_DEFAULT); 
    cv.put(Settings.SETTING_AD_HOC_ENABLED, Settings.SETTING_AD_HOC_ENABLED_DEFAULT); 
    cv.put(Settings.SETTING_SERVER_ADDRESS, Settings.SETTING_SERVER_ADDRESS_DEFAULT); 
    cv.put(Settings.SETTING_RECORDING_MODE, Settings.SETTING_RECORDING_MODE_DEFAULT); 
    cv.put(Settings.SETTING_PREVIEW_ENABLED, Settings.SETTING_PREVIEW_ENABLED_DEFAULT); 
    cv.put(Settings.SETTING_PICTURE_RESOLUTION_X, Settings.SETTING_PICTURE_RESOLUTION_X_DEFAULT); 
    cv.put(Settings.SETTING_PICTURE_RESOLUTION_Y, Settings.SETTING_PICTURE_RESOLUTION_Y_DEFAULT); 
    cv.put(Settings.SETTING_VIDEO_RESOLUTION_X, Settings.SETTING_VIDEO_RESOLUTION_X_DEFAULT); 
    cv.put(Settings.SETTING_VIDEO_RESOLUTION_Y, Settings.SETTING_VIDEO_RESOLUTION_Y_DEFAULT); 
    cv.put(Settings.SETTING_VIDEO_FPS, Settings.SETTING_VIDEO_FPS_DEFAULT); 
    cv.put(Settings.SETTING_AUDIO_BITRATE_KBPS, Settings.SETTING_AUDIO_BITRATE_KBPS_DEFAULT); 
    cv.put(Settings.SETTING_STORE_TO_SD, Settings.SETTING_STORE_TO_SD_DEFAULT); 
    cv.put(Settings.SETTING_STORAGE_LIMIT_MB, Settings.SETTING_STORAGE_LIMIT_MB_DEFAULT); 

    this.db.insert(Settings.SETTINGS_TABLE_NAME, null, cv); 
} 

CREATE_SETTINGS_TABLE स्ट्रिंग निम्नलिखित के रूप में परिभाषित किया गया है

हालांकि, जब मैं अपने डालने पर अमल, मैं हमेशा मिलती है:

03-19 19:37:36.974: ERROR/Database(386): Error inserting server_address='0.0.0.0' storage_limit='-1' connection='none' preview_enabled='0' sd_enabled='1' video_fps='15' audio_bitrate='96' device_id='-1' recording_mode='none' picture_resolution_x='-1' picture_resolution_y='-1' unique_id='000000000000000' adhoc_enable='0' video_resolution_x='320' video_resolution_y='240' 
03-19 19:45:34.284: ERROR/Database(446): android.database.sqlite.SQLiteConstraintException: error code 19: constraint failed 

यह देखना एमएस जैसे कि मेरे सम्मिलन में सभी कॉलम शून्य नहीं हैं। पंक्ति की प्राथमिक कुंजी अद्वितीय होना चाहिए, क्योंकि यह तालिका में एकमात्र पंक्ति है। इसलिए, केवल एक चीज जिसे मैं सोच सकता हूं वह है मेरी जांच की शर्तें सच नहीं हैं। यहां पूर्वनिर्धारित तार हैं जिनका उपयोग मैं कर रहा हूं:

public static final String SETTING_UNIQUE_ID = "unique_id"; 

public static final String SETTING_DEVICE_ID = "device_id"; 
public static final String SETTING_DEVICE_ID_DEFAULT = "'-1'"; 

public static final String SETTING_CONNECTION_PREFERENCE = "connection"; 
public static final String SETTING_CONNECTION_PREFERENCE_3G = "'3g'"; 
public static final String SETTING_CONNECTION_PREFERENCE_WIFI = "'wifi'"; 
public static final String SETTING_CONNECTION_PREFERENCE_NONE = "'none'"; 
public static final String SETTING_CONNECTION_PREFERENCE_ALLOWED = SETTING_CONNECTION_PREFERENCE_3G+","+SETTING_CONNECTION_PREFERENCE_WIFI+","+SETTING_CONNECTION_PREFERENCE_NONE; 
public static final String SETTING_CONNECTION_PREFERENCE_DEFAULT = SETTING_CONNECTION_PREFERENCE_NONE; 

public static final String SETTING_AD_HOC_ENABLED = "adhoc_enable"; 
public static final String SETTING_AD_HOC_ENABLED_ALLOWED = TRUE+","+FALSE; 
public static final String SETTING_AD_HOC_ENABLED_DEFAULT = FALSE; 

public static final String SETTING_SERVER_ADDRESS = "server_address"; 
public static final String SETTING_SERVER_ADDRESS_DEFAULT = "'0.0.0.0'"; 

public static final String SETTING_RECORDING_MODE = "recording_mode"; 
public static final String SETTING_RECORDING_MODE_VIDEO = "'video'"; 
public static final String SETTING_RECORDING_MODE_AUDIO = "'audio'"; 
public static final String SETTING_RECORDING_MODE_PICTURE = "'picture'"; 
public static final String SETTING_RECORDING_MODE_NONE = "'none'"; 
public static final String SETTING_RECORDING_MODE_ALLOWED = SETTING_RECORDING_MODE_VIDEO+","+SETTING_RECORDING_MODE_AUDIO+","+SETTING_RECORDING_MODE_PICTURE+","+SETTING_RECORDING_MODE_NONE; 
public static final String SETTING_RECORDING_MODE_DEFAULT = SETTING_RECORDING_MODE_NONE; 

public static final String SETTING_PREVIEW_ENABLED = "preview_enabled"; 
public static final String SETTING_PREVIEW_ENABLED_ALLOWED = TRUE+","+FALSE; 
public static final String SETTING_PREVIEW_ENABLED_DEFAULT = FALSE; 

public static final String SETTING_PICTURE_RESOLUTION_X = "picture_resolution_x"; 
public static final String SETTING_PICTURE_RESOLUTION_X_DEFAULT = "'-1'"; 

public static final String SETTING_PICTURE_RESOLUTION_Y = "picture_resolution_y"; 
public static final String SETTING_PICTURE_RESOLUTION_Y_DEFAULT = "'-1'"; 

public static final String SETTING_VIDEO_RESOLUTION_X = "video_resolution_x"; 
public static final String SETTING_VIDEO_RESOLUTION_X_DEFAULT = "'320'"; 

public static final String SETTING_VIDEO_RESOLUTION_Y = "video_resolution_y"; 
public static final String SETTING_VIDEO_RESOLUTION_Y_DEFAULT = "'240'"; 

public static final String SETTING_VIDEO_FPS = "video_fps"; 
public static final String SETTING_VIDEO_FPS_DEFAULT = "'15'"; 

public static final String SETTING_AUDIO_BITRATE_KBPS = "audio_bitrate"; 
public static final String SETTING_AUDIO_BITRATE_KBPS_DEFAULT = "'96'"; 

public static final String SETTING_STORE_TO_SD = "sd_enabled"; 
public static final String SETTING_STORE_TO_SD_ALLOWED = TRUE+","+FALSE; 
public static final String SETTING_STORE_TO_SD_DEFAULT = TRUE; 

public static final String SETTING_STORAGE_LIMIT_MB = "storage_limit"; 
public static final String SETTING_STORAGE_LIMIT_MB_DEFAULT = "'-1'"; 

public static final String SETTING_CLIP_LENGTH_SECONDS = "clip_length"; 
public static final String SETTING_CLIP_LENGTH_SECONDS_DEFAULT = "'300'"; 

क्या कोई देखता है कि क्या हो सकता है? मैं उलझन में हूं। अग्रिम में धन्यवाद।

+0

क्या आपने 'कनेक्शन =" 'कोई नहीं' के साथ प्रयास किया था "मैं कल्पना कर सकता हूं कि आपके पास एस्ट्रोफ़े – Pentium10

+0

के साथ उन जांच हैं, अभी भी काम नहीं किया है। आप सही हैं कि जो मैं जांच रहा हूं वह अल्पविराम से अलग प्रत्येक तत्व के चारों ओर apostrophes है। क्या यह सही नहीं है? –

+0

यदि आप नीचे दिए गए उत्तर को देखते हैं, तो आप मूल रूप से सही थे। –

उत्तर

0

क्या आपने अपने एकल उद्धरण से बचने का प्रयास किया है? जैसे

public static final String SETTING_SERVER_ADDRESS_DEFAULT = "\'0.0.0.0\'"; 

यदि इससे यह दुरुस्त नहीं है, मैं यह सब नीचे टूट जाएगा जब तक आप केवल एक ही स्तंभ है, और कहा कि काम करने के लिए मिलता है। फिर एक बार में प्रत्येक कॉलम जोड़ें ताकि आप यह पता लगा सकें कि कौन सी समस्याएं समस्या पैदा कर रही हैं।

+0

सुझाव के लिए धन्यवाद। एकल उद्धरण से बचने से समस्या ठीक नहीं होती है, इसलिए जैसा कि आप सुझाव देते हैं, मैं कर सकता हूं। –

+0

जैसा आपने सुझाव दिया था मैंने किया था, और एक बहुत ही सरल तालिका बनाई थी। डालने के बाद जैसे ही मैं सम्मिलन कथन में कनेक्शन वरीयता जोड़ता हूं, सम्मिलन विफल होने लगता है, इसलिए मेरी जांच स्थिति में कुछ गलत होना चाहिए। –

1

ऐसा लगता है कि एंड्रॉइड डाल (स्ट्रिंग, स्ट्रिंग) विधि पहले से ही आपके मूल्य स्ट्रिंग के चारों ओर उद्धरण जोड़ना चाहिए ... जैसे ही मैंने मैन्युअल उद्धरण लिया था, मैं अपने मूल्य स्ट्रिंग्स के आसपास प्रवेश कर रहा था (लेकिन उन्हें रखा "अनुमति" में) तार मैं जांच करने के लिए गुजर रहा था, समस्या हल हो गई थी।

+0

हां। 'कंटेंट वैल्यू' को शाब्दिक एसक्यूएल जैसे कच्चे एसक्यूएल में अक्षर के रूप में बाध्य किया जाएगा, आपको स्ट्रिंग अक्षर के लिए उद्धरणों का उपयोग करना होगा। – laalto

संबंधित मुद्दे