【冠亚体育手机网站】Android数据库中事务操作方法之银行转账示例,Android开发实现拨打电话与发送信息的方法分析

本文实例讲述了Android开发实现拨打电话与发送信息的方法。分享给大家供大家参考,具体如下:

本文实例讲述了Android数据库中事务操作方法之银行转账功能。分享给大家供大家参考,具体如下:

xml布局:

主java

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="fill_parent"
  android:layout_height="fill_parent"
  android:orientation="vertical" >
  <LinearLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content">
    <TextView
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="电话号码" />
    <EditText
      android:id="@+id/edit_main_number"
      android:layout_width="fill_parent"
      android:layout_height="wrap_content"
      android:hint="请输入电话号码"/>
   </LinearLayout>
   <LinearLayout
     android:layout_width="match_parent"
     android:layout_height="wrap_content">
     <TextView
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:text="短信内容"/>
     <EditText
       android:id="@+id/edit_main_content"
       android:layout_width="fill_parent"
       android:layout_height="wrap_content"
       android:hint="请输入短信内容"/>
   </LinearLayout>
   <LinearLayout
     android:layout_width="match_parent"
     android:layout_height="wrap_content">
     <Button
       android:id="@+id/btn_call"
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:text="拨打电话"/>
     <Button
        android:id="@+id/btn_send"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="发送信息"/>
   </LinearLayout>
</LinearLayout>
package com.itheima.transtation;
import com.itheima.transtation.db.BankOpenHelper;
import android.os.Bundle;
import android.app.Activity;
import android.database.sqlite.SQLiteDatabase;
import android.view.Menu;
import android.view.View;
public class MainActivity extends Activity {
 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
 }
 //点击按钮执行该方法
 public void transtation(View v){
  //1.创建一个帮助类的对象
  BankOpenHelper bankOpenHelper = new BankOpenHelper(this);
  //2.调用数据库帮助类对象的getReadableDatabase创建数据库,初始化表数据,获取一个SqliteDatabase对象去做转账(sql语句)
  SQLiteDatabase db = bankOpenHelper.getReadableDatabase();
  //3.转账,将李四的钱减200,张三加200
  db.beginTransaction();//开启一个数据库事务
  try {
   db.execSQL("update account set money= money-200 where name=?",new String[]{"李四"});
   int i = 100/0;//模拟一个异常
   db.execSQL("update account set money= money+200 where name=?",new String[]{"张三"});
   db.setTransactionSuccessful();//标记事务中的sql语句全部成功执行
  } finally {
   db.endTransaction();//判断事务的标记是否成功,如果不成功,回滚错误之前执行的sql语句
  }
 }
}

java代码:

最好自己创建一个包来写数据库类

package com.wenzhi.interndemo;
import java.net.URL;
import android.net.Uri;
import android.os.Bundle;
import android.telephony.SmsManager;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.View.OnLongClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.app.Activity;
import android.content.Intent;
/**
 * 拨打电话与发送信息
 * @author xiaowen
 * @2016-1-5 下午10:48:53
 */
public class ThreeActivity extends Activity implements OnLongClickListener {
  private EditText edit_main_number;
  private EditText edit_main_content;
  private Button btn_call;
  private Button btn_send;
  private OnClickListener listener=new OnClickListener() {
    @Override
    public void onClick(View v) {
      if(v==btn_call){
        //点击拨打电话 创建一个Intent(隐式)
        //String action=Intent.ACTION_DIAL;
        //Intent intent=new Intent(action);
        Intent intent=new Intent(Intent.ACTION_DIAL);
        //携带数据
        String number=edit_main_number.getText().toString();
        intent.setData(Uri.parse("tel:"+number));
        //启动Activity
        startActivity(intent);
      }else if(v==btn_send){
        //点击发送信息  创建一个Intent(隐式)
        Intent intent=new Intent(Intent.ACTION_SENDTO);
        //携带数据
        String number=edit_main_number.getText().toString();
        String content=edit_main_content.getText().toString();
        intent.setData(Uri.parse("smsto:"+number));
        intent.putExtra("sms_body", content);
        startActivity(intent);
      }
    }
  };
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_three);
    edit_main_number=(EditText) findViewById(R.id.edit_main_number);
    edit_main_content=(EditText) findViewById(R.id.edit_main_content);
    btn_call=(Button) findViewById(R.id.btn_call);
    btn_send=(Button) findViewById(R.id.btn_send);
    //给视图对象设置点击监听
    btn_call.setOnClickListener(listener);
    btn_send.setOnClickListener(listener);
    //给视图对象设置长按监听
    btn_call.setOnLongClickListener(this);
    btn_send.setOnLongClickListener(this);
  }
  @Override
  public boolean onLongClick(View v) {
    if(v==btn_call){
     //长按拨打电话 创建一个Intent(隐式),必须在AndroidManifest.xml加入权限配置
     Intent intent=new Intent(Intent.ACTION_CALL);
     //携带数据
     String number =edit_main_number.getText().toString();
     intent.setData(Uri.parse("tel:"+number));
     //启动Activity
     startActivity(intent);
    }else if(v==btn_send){
      //得到SmsManager的对象
      SmsManager smsManager=SmsManager.getDefault();
      //发送文本信息(短信)
      String number=edit_main_number.getText().toString();
      String content=edit_main_content.getText().toString();
      smsManager.sendTextMessage(number, null, content, null, null);
    }
    return true;
  }
}
package com.itheima.transtation.db;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;
public class BankOpenHelper extends SQLiteOpenHelper {
 public BankOpenHelper(Context context) {
  super(context, "bank.db", null, 1);
  // TODO Auto-generated constructor stub
 }
 @Override
 public void onCreate(SQLiteDatabase db) {
  db.execSQL("create table account (_id integer primary key autoincrement,name varchar(20),money varchar(20))");
  db.execSQL("insert into account ('name','money') values ('张三','2000')");
  db.execSQL("insert into account ('name','money') values ('李四','5000')");
 }
 @Override
 public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
  // TODO Auto-generated method stub
 }
}

注意:在AndroidManifest.xml加入权限配置

xml  一个按钮的点击事件,很特别

<uses-permission android:name="android.permission.CALL_PHONE"/><!-- 打电话的权限 -->
<uses-permission android:name="android.permission.SEND_SMS"/><!-- 发短信的权限 -->
<?xml version="1.0"?>
-<RelativeLayout tools:context=".MainActivity" android:paddingTop="@dimen/activity_vertical_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingBottom="@dimen/activity_vertical_margin" android:layout_height="match_parent" android:layout_width="match_parent" xmlns:tools="http://schemas.android.com/tools" xmlns:android="http://schemas.android.com/apk/res/android">
<Button android:layout_height="wrap_content" android:layout_width="fill_parent" android:text="@string/transtation" android:onClick="transtation" android:layout_centerInParent="true"/>
</RelativeLayout>

另,关于Android权限设置可参考Android
Manifest功能与权限描述大全

附:

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android开发入门与进阶教程》、《Android视图View技巧总结》、《Android编程之activity操作技巧总结》、《Android数据库操作技巧总结》、《Android文件操作技巧汇总》、《Android资源操作技巧汇总》及《Android控件用法总结》

数据库的事务说明:

希望本文所述对大家Android程序设计有所帮助。

事务:
执行多条sql语句,要么同时执行成功,要么同时执行失败,不能有的成功,有的失败

您可能感兴趣的文章:

  • Android无需申请权限拨打电话的两种方式
  • Android拨打电话功能实例详解
  • 编写android拨打电话apk应用实例代码
  • Android
    实现手机拨打电话的功能
  • Android实战教程第三篇之简单实现拨打电话功能
  • Android中Webview打开网页的同时发送HTTP头信息方法
  • Android实现将应用崩溃信息发送给开发者并重启应用的方法
  • Android发送短信功能代码
  • Android
    Mms之:短信发送流程(图文详解)
  • Android实现发送短信功能实例详解
  • android中可以通过两种方式调用接口发送短信

银行转账

//点击按钮执行该方法
public void transtation(View v){
 //1.创建一个帮助类的对象
 BankOpenHelper bankOpenHelper = new BankOpenHelper(this);
 //2.调用数据库帮助类对象的getReadableDatabase创建数据库,初始化表数据,获取一个SqliteDatabase对象去做转账(sql语句)
 SQLiteDatabase db = bankOpenHelper.getReadableDatabase();
 //3.转账,将李四的钱减200,张三加200
 db.beginTransaction();//开启一个数据库事务
 try {
  db.execSQL("update account set money= money-200 where name=?",new String[]{"李四"});
  int i = 100/0;//模拟一个异常
  db.execSQL("update account set money= money+200 where name=?",new String[]{"张三"});
  db.setTransactionSuccessful();//标记事务中的sql语句全部成功执行
 } finally {
  db.endTransaction();//判断事务的标记是否成功,如果不成功,回滚错误之前执行的sql语句
 }
}

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android数据库操作技巧总结》、《冠亚体育手机网站,Android操作SQLite数据库技巧总结》、《Android编程之activity操作技巧总结》、《Android文件操作技巧汇总》、《Android开发入门与进阶教程》、《Android资源操作技巧汇总》、《Android视图View技巧总结》及《Android控件用法总结》

希望本文所述对大家Android程序设计有所帮助。

您可能感兴趣的文章:

  • Android开发中的数据库事务用法分析
  • Android
    SQLite事务处理结合Listview列表显示功能示例
  • 深入Android SQLite
    事务处理详解
  • Android
    用SQLite实现事务的方法
  • Android
    SQLite数据库增删改查操作的使用详解
  • Android使用SQLite数据库的简单实例
  • android创建数据库(SQLite)保存图片示例
  • Android中的SQL查询语句LIKE绑定参数问题解决办法(sqlite数据库)
  • android实现raw文件夹导入数据库代码
  • Android中操作SQLite数据库快速入门教程
  • Android实现将已发送的短信写入短信数据库的方法
  • Android操作SQLite数据库(增、删、改、查、分页等)及ListView显示数据的方法详解

Post Author: admin

发表评论

电子邮件地址不会被公开。 必填项已用*标注