অ্যান্ড্রয়েডে ডিফল্ট ভাবেই আমাদের ব্যবহার করার জন্য একোটা ডেটাবেজ থাকে, তা হচ্ছে SQLite. কিন্তু আমারা যদি MySQL বা অন্য কোন ডেটাবেজ ব্যবহার করতে চাই, তাহলে আমাদের নিজস্ব সার্ভারে তা ইন্সটল করে ব্যবহার করতে হবে। যারা ওয়েব ডেভেলপার, তাদের প্রায় সবাই MySQL এর সাথে পরিচিত। অনেক গুলো ওয়েব অ্যাপ এর ডাটাবেজ MySQL হওয়াতে আমাদের তৈরি বিভিন্ন অ্যাপ থেকে MySQL এক্সেস করতে হয়। আমরা আজ ছোট্ট একটা টিউটোরিয়াল দেখব, কিভাবে এন্ড্রয়েড ফোন থেকে কোন ডেটা সার্ভারের ডাটাবেজ এ সেভ করা যায়। আর সার্ভার সাইড প্রোগ্রামিং ল্যাঙ্গুয়েজ হিসেবে আমরা ব্যবহার করব PHP। নিজের কোন সার্ভার না থাকলে লোকালি PHP এবং MySQL ইন্সটল করা যেতে পারে। আর তার জন্য ম্যানুয়ালি ইন্সটল বা WAMP সার্ভার ব্যবহার করে সহজেই ইন্সটল করে নেওয়া যায়। এগুলো সম্পর্কে ধারণা না থাকলে নিচের লেখাটি দেখা যেতে পারেঃ
এ ছাড়া যদি phpMyAdmin সহ এসব সম্পর্কে ধারণা না থাকে, তাহলে নিচের লেখা দুইটি দেখলে অনেক কিছুই সহজ মনে হবেঃ

আমারা অনেক সিম্পল একটা অ্যাপ তৈরি করব। যেখান থেকে শুধু ব্যবহারকারীর নাম এবং ইমেইল সার্ভারে সেভ করা যাবে। এ জন্য আমরা একটা ডেটাবেজ তৈরি করব। এবং তার মধ্যে একটা টেবিল তৈরি করব, যার মধ্যে থাকবে দুইটি column. phpMyAdmin থেকে সহজেই গ্রাফিকাল ইউজার ইন্টারফেস দিয়ে এ কাজ গুলো করা যাবে। নিচে ডাটাবেজ এর কলাম তৈরির একটা স্ক্রিন সর্ট দিয়েছিঃ
আমাদের এন্ড্রয়েড অ্যাপ থেকে সার্ভারে ডেটা পাঠাবো, ডেটা গুলো রিসিভ করা এবং তা ডেটাবেজে সেভ করার জন্য php কোড এর প্রয়োজন। এই অ্যাপের জন্য প্রয়োজনীয় PHP কোড, ধরে নিচ্ছি ফাইলটির নামঃ process.php
<?php
$servername = "localhost"; // set your server address.
$username = "username"; // set your database username
$password = "db_pass"; // give your db user password
$dbname = "db_name"; // change this to your data base name
// Create connection
$conn = mysqli_connect($servername, $username, $password, $dbname);
// Check connection
if (!$conn) {
die("Connection failed: " . mysqli_connect_error());
}
// get posted data
$name= $_POST['name'];
$email = $_POST['email'];
// save into database
$sql = "INSERT INTO table_name(name, email)
VALUES ('$name', '$email')";
// check if success
if (mysqli_query($conn, $sql)) {
echo 'data saved';
} else {
echo "Error: " . $sql . "
" . mysqli_error($conn);
}
mysqli_close($conn);
?>
অ্যাপ থেকে ডেটা সার্ভারে/HTTP Post এর জন্য আমাদের অ্যাপের ইন্টারনেট এক্সেস লাগবে। তার জন্য Andorid Mainifests এ নিচের পারমিশন যুক্ত করে দিবঃ
<uses-permission android:name="android.permission.INTERNET"></uses-permission>
সার্ভারে HTTP রিকোয়েস্ট পাঠানোর জন্য আমাদের Apacche HTTP লাইব্রেরী লাগবে। তার জন্য আমাদের build.gradle এ নিচের dependencie যুক্ত করে দিব।
dependencies {
compile 'org.jbundle.util.osgi.wrapped:org.jbundle.util.osgi.wrapped.org.apache.http.client:4.1.2'
}
আমাদের মেইন লেআউটে একটা বাটন রাখব, যেখানে ক্লিক করলে সার্ভারে আমদের ডেটা পোস্ট করবেঃ
<?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_width="match_parent" android:layout_height="match_parent" android:paddingBottom="@dimen/activity_vertical_margin" android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingTop="@dimen/activity_vertical_margin" tools:context="me.jakir.database.MainActivity">
<Button android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Save data to server" android:id="@+id/button" android:layout_alignParentTop="true" android:layout_centerHorizontal="true" android:layout_marginTop="129dp" />
</RelativeLayout>
আমাদের MainActivity ক্লাস।
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
public class MainActivity extends Activity {
Button button;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
button = (Button) findViewById(R.id.button);
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
new UpdateTask().execute();
}
});
}
}
যখন বাটনে ক্লিক করবে, তখন আমরা আরেকটা ক্লাসকে কল করব। তার জন্য আমাদের একটা ক্লাস তৈরি করে নিতে হবে। প্যাকেজের উপর রাইট ক্লিক করে নতুন ক্লাস তৈরি করে নিতে হবে। আমরা নাম দিলামঃ UpdateTask
UpdateTask class:
import android.os.AsyncTask;
import android.util.Log;
import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.HttpClient;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.message.BasicNameValuePair;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.util.ArrayList;
import java.util.List;
class UpdateTask extends AsyncTask<String, String,String> {
protected String doInBackground(String... urls) {
HttpClient httpClient = new DefaultHttpClient();
// replace with your url
HttpPost httpPost = new HttpPost("http://utopianlab.com/app/process.php");
//Post Data
List<NameValuePair> nameValuePair = new ArrayList<NameValuePair>(2);
nameValuePair.add(new BasicNameValuePair("name", "Jack"));
nameValuePair.add(new BasicNameValuePair("email", "[email protected]"));
//Encoding POST data
try {
httpPost.setEntity(new UrlEncodedFormEntity(nameValuePair));
} catch (UnsupportedEncodingException e) {
// log exception
e.printStackTrace();
}
//making POST request.
try {
HttpResponse response = httpClient.execute(httpPost);
// write response to log
Log.d("Http Post Response:", response.toString());
} catch (ClientProtocolException e) {
// Log exception
e.printStackTrace();
} catch (IOException e) {
// Log exception
e.printStackTrace();
}
return null;
}
}
এখানেই মূলত আমরা সার্ভারে ডেটা পোস্ট করার কোড লিখেছি। AsyncTask এর মানে হচ্ছে ব্যাকগ্রাউন্ড প্রসেস টাস্ক। যখন আমরা সার্ভারে ডেটা পোস্ট করব, তখন তা ব্যাকগ্রাউন্ডে কাজ করবে। এবং নিজ থেকেই একটার পর একটা রিকোয়েস্ট ওয়েব সার্ভারে পাঠাবে। আমরা ডেটা গুলো পাঠাবো জোড়া অনুযায়ী। একটা হচ্ছে নাম, আরেকটা হচ্ছে ডেটা। আর আমাদের সব গুলো ডেটা আমরা একটা লিস্টে রাখব, জোড়া অনুযায়ী। উপরের কোডে আমরা মাত্র দুইটি ডেটা রেখেছি। এবং শেষে আমরা HttpPost এর মাধ্যমে আমাদের ডেটা সার্ভারে পাঠিয়েছি। যা পিএইচপি ডেটাবেজে যুক্ত করবে।
এখন যদি আমরা ডেটাবেজের টেবিল দেখি, তাহলে দেখতে পাবো আমাদের ডেটা যুক্ত হয়েছে ডেটাবেজে। তা phpMyAdmin থেকেই দেখতে পাবেন।
এখানে আমরা স্ট্যাটিক ভাবে, ভ্যালু যুক্ত করে দিয়েছি। যেমন Name এবং email। এ কোডকে মডিফাই করে ডাইনামিক করার চেষ্টা করতে পারেন। যেমন ইউজার যেন নিজের নাম এবং ইমেইল এখানে পোস্ট করতে পারে, তার জন্য লেআউট ফাইলে টেক্সট ফিল্ড যুক্ত করতে পারেন।
এছাড়া যদি সার্ভারে সেভ হওয়া ডেটা গুলো ওয়েব সাইটে দেখাতে চান, তা সহজেই করতে পারেন পিএইচপি কোয়েরীর মাধ্যমে। তার জন্য উপরে শেয়ার করা লিঙ্কঃ পিএইচপি এবং MySQL দিয়ে সিম্পল প্রজেক্ট দেখলে নিজে নিজে করতে পারবেন।
ধন্যবাদ সবাইকে 🙂

source code টা জিপ ফাইলে দিলে ভাল হত
Vai just awesome .
can we use oracle / SQL server i/o MySQL?
vai source code ta dile bujhte subidha hoto.
Thank you jakir bhai for your post. Alhamdulillah create a simple billing apps.
ডাটাবেস নিয়ে কিছু জানারছিল তা পেলাম না এখানেও।