这是我在 Blackberry java Eclipse 插件中的代码 我如何在此代码中调用 webservice 以通过从此代码调用 web 服务将以下提到的字段(如 _firstName 、_lastName 、address、mobileNumber )存储在数据库中。请说一下数据库,我如何在黑莓应用程序中设置数据库以在黑莓应用程序中调用 web 服务,即在我的 ui 设计中,我有名字、姓氏、手机号码和地址,我必须通过调用将此字段存储在数据库中网络服务,请给我一些关于网络服务的想法或代码,并设置特定于黑莓应用程序的数据库。提前致谢
package mypackage;
import net.rim.device.api.database.Database;
import net.rim.device.api.database.DatabaseFactory;
import net.rim.device.api.database.Statement;
import net.rim.device.api.io.URI;
import net.rim.device.api.ui.DrawStyle;
import net.rim.device.api.ui.Field;
import net.rim.device.api.ui.FieldChangeListener;
import net.rim.device.api.ui.component.BasicEditField;
import net.rim.device.api.ui.component.ButtonField;
import net.rim.device.api.ui.component.DateField;
import net.rim.device.api.ui.component.Dialog;
import net.rim.device.api.ui.component.LabelField;
import net.rim.device.api.ui.component.RadioButtonField;
import net.rim.device.api.ui.component.RadioButtonGroup;
import net.rim.device.api.ui.component.RichTextField;
import net.rim.device.api.ui.component.SeparatorField;
import net.rim.device.api.ui.container.HorizontalFieldManager;
import net.rim.device.api.ui.container.MainScreen;
import net.rim.device.api.ui.container.VerticalFieldManager;
public final class CreateProfileScreen extends MainScreen {
Database d;
BasicEditField _firstName = new BasicEditField("First Name:", "");
BasicEditField _lastName = new BasicEditField("Last Name:", "");
BasicEditField mobileNumber = new BasicEditField("MobileNumber:", "");
BasicEditField address = new BasicEditField("Address:", "");
public CreateProfileScreen() {
HorizontalFieldManager btns = new HorizontalFieldManager(
HorizontalFieldManager.FIELD_HCENTER);
ButtonField save = new ButtonField("Save", ButtonField.FIELD_HCENTER);
// adding these objects to the Blackberry Application.
VerticalFieldManager vfm = new VerticalFieldManager(
VerticalFieldManager.FIELD_LEFT);
vfm.add(_firstName);
vfm.add(new SeparatorField());
vfm.add(_lastName);
vfm.add(new SeparatorField());
vfm.add(mobileNumber);
vfm.add(new SeparatorField());
RadioButtonGroup rbg = new RadioButtonGroup();
vfm.add(new RadioButtonField("Male", rbg, true));
vfm.add(new RadioButtonField("Female", rbg, false));
vfm.add(new SeparatorField());
vfm.add(new DateField("DOB:", System.currentTimeMillis(),
DateField.DATE | DrawStyle.LEFT));
vfm.add(new SeparatorField());
vfm.add(address);
vfm.add(new SeparatorField());
vfm.add(save);
add(vfm);
FieldChangeListener btnlistener = new FieldChangeListener() {
public void fieldChanged(Field field, int context) {
// Open a new screen
String fname = _firstName.getText();
String lname = _lastName.getText();
String mobno = mobileNumber.getText();
String addr = address.getText();
if (fname.length() == 0 || lname.length() == 0)
Dialog.alert("firstname and lastname is mandatory!");
LabelField title = new LabelField("SQLite Insert Data "
+ "Schema Sample", LabelField.ELLIPSIS
| LabelField.USE_ALL_WIDTH);
setTitle(title);
add(new RichTextField("Attempting to insert data into "
+ "MyTestDatabase.db on the SDCard."));
try {
URI myURI = URI.create("D:///db/" + "MyTestDatabase2.db");
d = DatabaseFactory.open(myURI);
Statement st = d
.createStatement("INSERT INTO People(Name,Age) "
+ "VALUES ('John',37)");
st.prepare();
st.execute();
st.close();
d.close();
add(new RichTextField("inserting data successful"));
System.out.println("inserting data successful");
} catch (Exception e) {
System.out.println(e.getMessage());
e.printStackTrace();
}
}
};
save.setChangeListener(btnlistener);
}
}