提问人:The NXP 提问时间:1/17/2023 最后编辑:The NXP 更新时间:1/17/2023 访问量:45
SQLite语法错误代码1,尝试修复但修复无济于事
SQLite syntax error code 1, tried to fix but fixes doesn't helped
问:
构建成功,但当我尝试通过以下方式打开数据库时,应用程序崩溃并附在下面附加错误myDataBaseManager.openDataBase()
有一个崩溃日志:
FATAL EXCEPTION:
main Process: com.example.smartwardrobe, PID: 9535
java.lang.RuntimeException: Unable to resume activity
{com.example.smartwardrobe/com.example.smartwardrobe.LoginActivity}:
android.database.sqlite.SQLiteException: near "myTableOfClothes": syntax
error (code 1 SQLITE_ERROR): , while compiling: myTableOfClothes
并且有一个类是数据库的构造:
public final class MyDataBaseContract {
public static final String USER_TABLE_NAME = "usersMyTable";
public static final String USER_ID = "userID";
public static final String USER_LOGIN = "login";
public static final String USER_PASSWORD = "password";
public static final String CLOTHE_TABLE_NAME = "clothesMyTable";
public static final String CLOTHE_COLOUR = "clothe_Colour";
public static final String CLOTHE_WARMTH = "clotheWarmth";
public static final String CLOTHE_TYPE = "clotheType";
public static final String CLOTHE_NAME = "clotheName";
public static final String CLOTHE_IMAGE_INDEX = "clotheImageIndex";
public static final String CLOTHE_OWNER_ID = "ownerId";
public static final String CLOTHE_ID = "clotheID";
public static final String DATABASE_NAME = "wardrobeDatabase.db";
public static final int DB_VERSION = 1;
public static final String USER_TABLE_STRUCTURE = "CREATE TABLE IF NOT EXISTS " +
USER_TABLE_NAME + " (" + USER_ID + " INTEGER PRIMARY KEY," + USER_LOGIN + " TEXT," +
USER_PASSWORD + " TEXT)";
public static final String CLOTHE_TABLE_STRUCTURE = "CREATE TABLE IF NOT EXISTS " +
CLOTHE_TABLE_NAME + " (" + CLOTHE_ID + " INTEGER PRIMARY KEY," + CLOTHE_COLOUR + " TEXT," +
CLOTHE_WARMTH + " TEXT," + CLOTHE_TYPE + " TEXT," + CLOTHE_NAME + " TEXT," + CLOTHE_IMAGE_INDEX + " TEXT," +
CLOTHE_OWNER_ID + " TEXT)";
public static final String DROP_CLOTHE_TABLE = "DROP TABLE IF EXIST " + CLOTHE_TABLE_NAME;
public static final String DROP_USER_TABLE = "DROP TABLE IF EXIST " + USER_TABLE_NAME;
}
有一个 MyDataBaseManager 类:
@SuppressLint("Range")
public class MyDataBaseManager {
private Context context;
private MyDataBaseHelper myDataBaseHelper;
private SQLiteDatabase database;
public MyDataBaseManager(Context context) {
this.context = context;
myDataBaseHelper = new MyDataBaseHelper(context);
}
public void openDataBase(){
database = myDataBaseHelper.getWritableDatabase();
}
public void closeDataBase(){
myDataBaseHelper.close();
}
public void insertUserToUserDataBase(String login, String password){
ContentValues cv = new ContentValues();
cv.put(MyDataBaseContract.USER_LOGIN, login);
cv.put(MyDataBaseContract.USER_PASSWORD, password);
database.insert(MyDataBaseContract.USER_TABLE_NAME, null, cv);
}
public void insertClotheToClotheDatabase(String type, String warmth, String colour,
String name, int ownerId){
ContentValues cv = new ContentValues();
cv.put(MyDataBaseContract.CLOTHE_TYPE, type);
cv.put(MyDataBaseContract.CLOTHE_WARMTH, warmth);
cv.put(MyDataBaseContract.CLOTHE_COLOUR, colour);
cv.put(MyDataBaseContract.CLOTHE_NAME, name);
cv.put(MyDataBaseContract.CLOTHE_OWNER_ID, ownerId);
database.insert(MyDataBaseContract.CLOTHE_TABLE_NAME, null, cv);
}
public ArrayList<Clothe> getAllClothesByOwnerId(int ownerId){
Cursor cursor = database.query(MyDataBaseContract.CLOTHE_TABLE_NAME,
null, null, null,
null, null, null);
ArrayList<Clothe> clothes = new ArrayList<>();
while (cursor.moveToNext()){
if(ownerId == cursor.getInt(cursor.getColumnIndex(MyDataBaseContract.CLOTHE_OWNER_ID))){
Clothe clothe = new Clothe(
cursor.getInt(cursor.getColumnIndex(MyDataBaseContract.CLOTHE_ID)),//Clothe ID
cursor.getString(cursor.getColumnIndex(MyDataBaseContract.CLOTHE_WARMTH)), //Clothe warmth
cursor.getString(cursor.getColumnIndex(MyDataBaseContract.CLOTHE_TYPE)), // Clothe type
cursor.getString(cursor.getColumnIndex(MyDataBaseContract.CLOTHE_COLOUR)), //Clothe colour
cursor.getString(cursor.getColumnIndex(MyDataBaseContract.CLOTHE_NAME)), //Clothe name
cursor.getInt(cursor.getColumnIndex(MyDataBaseContract.CLOTHE_OWNER_ID))); //Owner ID
clothes.add(clothe);
}
}
cursor.close();
return clothes;
}
public boolean doesLoginExist(String login){
Cursor cursor = database.query(MyDataBaseContract.USER_TABLE_NAME,
null, null, null,
null, null, null);
while (cursor.moveToNext()){
if(login.equals(cursor.getString(cursor.getColumnIndex(MyDataBaseContract.USER_LOGIN))))
{
cursor.close();
return true;
};
}
cursor.close();
return false;
}
public User getUserByLogin(String login){
if (!doesLoginExist(login)) return null;
Cursor cursor = database.query(MyDataBaseContract.USER_TABLE_NAME,
null, null, null,
null, null, null);
while (cursor.moveToNext()){
if(login.equals(cursor.getString(cursor.getColumnIndex(MyDataBaseContract.USER_LOGIN)))){
User user = new User(login, cursor.getString(cursor.getColumnIndex(MyDataBaseContract.USER_PASSWORD)),
cursor.getInt(cursor.getColumnIndex(MyDataBaseContract.USER_ID)));
cursor.close();
return user;
}
}
cursor.close();
return null;
}
public User getUserByID(int userID){
Cursor cursor = database.query(MyDataBaseContract.USER_TABLE_NAME,
null, null, null,
null, null, null);
while (cursor.moveToNext()){
if (userID == cursor.getInt(cursor.getColumnIndex(MyDataBaseContract.USER_ID))){
User user = new User(cursor.getString(cursor.getColumnIndex(MyDataBaseContract.USER_LOGIN)),
cursor.getString(cursor.getColumnIndex(MyDataBaseContract.USER_PASSWORD)),
cursor.getInt(cursor.getColumnIndex(MyDataBaseContract.USER_ID)));
cursor.close();
return user;
}
}
return null;
}
}
此外,还有一个类的用法为:myDataBaseManager.openDataBase()
public class LoginActivity extends AppCompatActivity {
private MyDataBaseManager myDataBaseManager;
@SuppressLint("MissingInflatedId")
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_login);
//Buttons
Button btn_login = findViewById(R.id.btn_LoginPage_SignIn);
Button btn_register = findViewById(R.id.btn_LoginPage_OpenRegisterDialog);
//Edit Texts
EditText et_login = findViewById(R.id.et_LoginPage_Login);
EditText et_password = findViewById(R.id.et_LoginPage_Password);
//Other
myDataBaseManager = new MyDataBaseManager(this);
Activity activity = this;
btn_register.setOnClickListener(v -> startRegistration(activity, myDataBaseManager));
btn_login.setOnClickListener(v -> {
String login = et_login.getText().toString();
if (myDataBaseManager.doesLoginExist(login)){
User tempUser = myDataBaseManager.getUserByLogin(login);
String password = et_password.getText().toString();
if(tempUser.getPassword().equals(password)){
Intent intent = new Intent(activity, MainActivity.class);
intent.putExtra("UserID", tempUser.getUserID());
startActivity(intent);
myDataBaseManager.closeDataBase();
finishActivity(0);
}
else
Toast.makeText(activity, "Password is incorrect. Check it and try again", Toast.LENGTH_SHORT).show();
}
else Toast.makeText(activity, "User with this login does not exist. Sign up!(^_^)", Toast.LENGTH_SHORT).show();
});
}
@Override
protected void onResume() {
super.onResume();
myDataBaseManager.openDataBase();
}
我在搜索数据库语法错误或其他类错误时检查了几次代码,但没有找到任何东西。
附加信息: 虚拟设备:Pixel 6 pro API 33
答:
具体错误是“myTableOfClothes”附近的语法不正确。您似乎正在尝试使用该名称创建表,但它不存在于您共享的代码中,表名似乎拼写错误,或者它不是您尝试创建的正确表名。
请检查您尝试创建的表的名称,并检查您是否使用了正确的 SQL 语句来创建表。 在共享的代码中,该表在 MyDataBaseContract 类中称为“clothesMyTable”,创建该表的语句称为 CLOTHE_TABLE_STRUCTURE。
此外,请确保尚未创建该表,并且您正在尝试再次创建它,如果是这样,则应先删除它,然后再使用 DROP_CLOTHE_TABLE 语句再次创建它。
同样重要的是要注意,如果您在 SQL 语句中使用硬编码字符串文字,请确保使用正确的表名和列名。
public static final String CLOTHE_TABLE_NAME = “clothesMyTable”;
public static final String CLOTHE_TABLE_STRUCTURE = “CREATE TABLE IF NOT EXISTS ” + CLOTHE_TABLE_NAME + “ (” + CLOTHE_ID + “整数主键”,+ CLOTHE_COLOUR + “文本”,+ CLOTHE_WARMTH + “文本”,+ CLOTHE_TYPE + “文本”,+ CLOTHE_NAME + “文本”,+ CLOTHE_IMAGE_INDEX + “文本”,+ CLOTHE_OWNER_ID + “ 文本)”;
此外,还需要更新代码中所有使用的表名称,以匹配正确的表名称。
此外,请确保您使用的是正确的 SQL
评论