我正在创建一个登录应用程序,其中在EditText中键入的数据将在单击java文件中的按钮时进入变量,并且该值将存储到我创建的sqlite数据库中但是当我键入值时在EditText中单击按钮我没有在文件资源管理器中创建任何数据库。
这是我的代码:
import java.util.Locale;
import android.app.Activity;
import android.content.ContentValues;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
public class AAAActivity extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
EditText userid = (EditText)findViewById(R.id.et_un);
EditText password = (EditText)findViewById(R.id.et_pw);
final String uid;
final String pwd;
uid = userid.getText().toString();
pwd = password.getText().toString();
Button btn = (Button)findViewById(R.id.btn_login);
btn.setOnClickListener(new OnClickListener(){
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
InsertUser(uid, pwd);
show();
}
});
}
public void InsertUser(String user_name, String password){
//SQLiteDatabase db;
SQLiteDatabase db;
db = openOrCreateDatabase("TestData.db", SQLiteDatabase.CREATE_IF_NECESSARY,
null);
try{
db.setVersion(1);
db.setLocale(Locale.getDefault());
db.setLockingEnabled(true);
/*final String CREATE_TABLE_USERS = "CREATE TABLE users (" + "id INTEGER
PRIMARY KEY AUTOINCREMENT,"+" LoginName text not null, Password
text not null);"; */
String CREATE_TABLE_USERS = "CREATE TABLE users (" + "id INTEGER PRIMARY KEY
AUTOINCREMENT,"+" LoginName text not null, Password text not null);";
db.execSQL(CREATE_TABLE_USERS);
ContentValues values = new ContentValues();
values.put("LoginName", user_name);
values.put("Password", password);
db.insert("users", null, values);
}
catch(Exception e){
}
}
public void show(){
Toast toast=Toast.makeText(this, "your data is received", Toast.LENGTH_SHORT );
toast.show();
}
}
我是android的新手。任何帮助表示赞赏。
答案 0 :(得分:0)
我为类的不同功能创建了一个新的DBAdapter类,比如打开,关闭,更新插入和检索数据。然后我创建了另一个类来访问布局资源,我在按钮单击事件上调用了DBAdapter类的方法。
在我的代码的上一篇文章中,我发现每次将数据插入数据库时,我都会创建一个新数据库,这就是我认为创建问题。现在我将所有方法分开并单独调用它们。