如何使用 android studio 和 phpmyadmin(wampserver) 将数据插入数据库?
Posted
技术标签:
【中文标题】如何使用 android studio 和 phpmyadmin(wampserver) 将数据插入数据库?【英文标题】:how to insert a data into database using android studio and phpmyadmin(wampserver)? 【发布时间】:2017-01-17 03:22:04 【问题描述】:我是 android 新手..我正在使用 android studio 1.0.1 和 phpmyadmin(wampserver)。我想创建一个应用程序,通过单击按钮将学生详细信息添加到数据库中。我的页面将包含 Rollno,name ,Degree,Course.On 添加按钮点击这些数据必须插入到数据库库app下的学生表中。我已经创建了一个数据库和学生表,但不知道数据库连接。请帮助我..提前谢谢..
【问题讨论】:
你的意思是说,你想将本地数据库数据上传到服务器(phpmyadmin)对吗?你有没有像sqlite一样将数据存储到android中的本地数据库? 【参考方案1】:我有一个类似的保存用户名和密码的例子,尝试根据你的想法修改。这个过程非常相似。
//Layout of Activity
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_
android:layout_
android:padding="2dp"
tools:context="com.test.test.ScreenOne">
<EditText
android:layout_
android:layout_
android:id="@+id/etUsername"
android:layout_marginTop="150dp"
android:hint="username"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true" />
<EditText
android:layout_
android:layout_
android:id="@+id/etPassword"
android:hint="password"
android:layout_below="@+id/etUsername"
android:layout_centerHorizontal="true" />
<Button
android:layout_
android:layout_
android:text="Save"
android:id="@+id/bSave"
android:layout_below="@+id/bLogin"
android:layout_centerHorizontal="true"
android:layout_marginTop="42dp" />
</RelativeLayout>
Activity 有 1 个按钮和 2 个 EditText,Save 按钮将您的数据保存在服务器中:
package com.test.test;
import android.app.ProgressDialog;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.view.Window;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
import com.android.volley.AuthFailureError;
import com.android.volley.Request;
import com.android.volley.Response;
import com.android.volley.VolleyError;
import com.android.volley.toolbox.StringRequest;
import java.util.HashMap;
import java.util.Map;
public class ScreenOne extends AppCompatActivity
private static final String URL_SAVE = "http://IP_ADDRESS/save.php";
private EditText username;
private EditText password;
Button save;
String name;
String pass;
@Override
protected void onCreate(Bundle savedInstanceState)
super.onCreate(savedInstanceState);
setContentView(R.layout.screen_one);
username = (EditText) findViewById(R.id.etUsername);
password = (EditText) findViewById(R.id.etPassword);
(save = (Button) findViewById(R.id.bSave)).setOnClickListener(new View.OnClickListener()
@Override
public void onClick(View v)
saveRequest();
);
private void saveRequest()
name = username.getText().toString().trim();
pass = password.getText().toString().trim();
final ProgressDialog mDialog = new ProgressDialog(this);
mDialog.requestWindowFeature(Window.FEATURE_NO_TITLE);
mDialog.setMessage("Loading...");
mDialog.show();
StringRequest request = new StringRequest(Request.Method.POST, URL_SAVE,
new Response.Listener<String>()
@Override
public void onResponse(String response)
mDialog.dismiss();
Toast.makeText(ScreenOne.this, response, Toast.LENGTH_LONG).show();
username.setText("");
password.setText("");
,
new Response.ErrorListener()
@Override
public void onErrorResponse(VolleyError error)
mDialog.dismiss();
Toast.makeText(ScreenOne.this, "Something went wrong", Toast.LENGTH_LONG).show();
)
@Override
protected Map<String, String> getParams() throws AuthFailureError
Map<String, String> key = new HashMap<>();
key.put("username", name);
key.put("password", pass);
return key;
;
NetworkCalls.getInstance().addToRequestQueue(request);
Volley 请求的单例类:
import android.content.Context;
import com.android.volley.Request;
import com.android.volley.RequestQueue;
import com.android.volley.toolbox.Volley;
/**
* Created by W4R10CK on 13-09-2016.
*/
public class NetworkCalls
private RequestQueue requestQueue;
private static Context context;
private static NetworkCalls ourInstance = new NetworkCalls();
public static NetworkCalls getInstance()
return ourInstance;
private NetworkCalls()
public RequestQueue getRequestQueue()
requestQueue = Volley.newRequestQueue(context.getApplicationContext());
return requestQueue;
public <T> void addToRequestQueue(Request<T> request)
getRequestQueue().add(request);
调用服务器的API:
//conn.php for connection (file one)
<?php
$host = "localhost";
$user = "root";
$pass = "";
$db_name = "hello";
$con = new mysqli($host,$user,$pass,$db_name);
if($con -> connect_error)
echo "Connection error";
//save.php(file two)
<?php
$username = $_POST['username'];
$password = $_POST['password'];
require_once('conn.php');
$sql = "INSERT INTO user (username, password) VALUES ('$username','$password')";
if($con -> query($sql) === TRUE)
echo "User added";
//$con -> close();
?>
?>
最后创建一个名为 hello 的数据库和 localhost user 中的表,其中包含 2 个字段 username、password。
【讨论】:
【参考方案2】:正如你所说,首先你必须创建 PHP/Java API 来与数据库通信。在 android 中,您必须使用网络调用,例如“凌空”。使用 volley 进行网络通话非常简单和酷。我建议阅读一些教程:Registration via Volley (WampServer)
【讨论】:
我不会使用任何本地数据库。我想将数据直接插入到phpmyadmin中。 有必要使用Volley吗?请告诉我Volley以外的方法与phpmyadmin实现数据库连接.. @Chaitra 下面的答案正是我所说的。寻找下面给出的答案。 感谢您的信息..有必要使用 Volley 吗?我可以使用任何其他方法(如 http)..? @Chaitra volley 非常快速且易于使用。使用 w4r10ck 的以下答案。以上是关于如何使用 android studio 和 phpmyadmin(wampserver) 将数据插入数据库?的主要内容,如果未能解决你的问题,请参考以下文章
使用 json/php 的 Android Studio 简单通知
如何建立与 Android studio和 gradle android 库
我无法通过 MySQL、PHP、Volley 按点的降序获取 Android Studio 上的玩家列表