如何使用 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 个字段 usernamepassword

【讨论】:

【参考方案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 php 连接

如何建立与 Android studio和 gradle android 库

我无法通过 MySQL、PHP、Volley 按点的降序获取 Android Studio 上的玩家列表

jsonobject无法转换为jsonarray android studio

如何使用 Android Studio 和 gradle 构建一个 android 库?