Android Java连接到在线数据库

时间:2012-02-29 05:04:01

标签: java android database

好的,我的网站上有1and1.com托管的数据库..

我怎样才能从android连接数据库和存储信息,并从应用程序中检索信息?

3 个答案:

答案 0 :(得分:0)

您无法直接从Android访问远程数据库。据我所知,您需要在服务器数据库上执行CRUD操作,即您希望更改反映在服务器端。执行此操作的最佳方法是通过WebServices公开您的CRUD操作,并在您的Android应用程序中使用它们。

答案 1 :(得分:0)

您需要使用php或其他您熟悉的语言编写服务,并将您的sql响应作为XML / JSON返回。从Android应用程序,您需要执行HTTPURLConnection并使用inbuit JSON / XML解析器,您需要解析响应。

答案 2 :(得分:0)

我假设你了解网络服务。 使用.net编写Web服务然后使用 ksoap库,您将得到响应。 然后根据您的要求格式化响应。 代码供参考:

private static final String NAMESPACE = "http://tempuri.org/"; 
private static final String URL ="http://localhost/Web_Service.asmx?";// you can use   IP address instead of localhost
private static final String METHOD_NAME = "Function_Name";
private static final String SOAP_ACTION = NAMESPACE+METHOD_NAME;

SoapObject request = new SoapObject(NAMESPACE, METHOD_NAME); 
request.addProperty("parm_name",prm_value);// Parameter for Method
SoapSerializationEnvelope envelope = new SoapSerializationEnvelope(SoapEnvelope.VER11); 
envelope.dotNet = true;
envelope.setOutputSoapObject(request);
HttpTransportSE androidHttpTransport = new HttpTransportSE(URL);
try {
androidHttpTransport.call(SOAP_ACTION, envelope);//call the eb service Method
} catch (Exception e) {
e.printStackTrace();}//Next task is to get Response and format that response
SoapObject obj,obj1,obj2,obj3;
obj= (SoapObject) envelope.getResponse();
obj1=(SoapObject) obj.getProperty("diffgram");
obj2=(SoapObject) obj1.getProperty("NewDataSet");
for(int i=0;i<obj2.getPropertyCount();i++)//the method getPropertyCount() return the number of rows
{
obj3=(SoapObject) obj2.getProperty(i);  
obj3.getProperty(0).toString();//value of column 1
obj3.getProperty(1).toString();//value of column 2
//like that you will get value from each column
}

Link for Ksoap library for Android

您可以从上面的链接下载库。 我知道这会解决你的问题。 如果您对此有任何疑问,请添加评论。