基本信息
源码名称:安卓SqlServer直连Demo
源码大小:1.18M
文件格式:.zip
开发语言:Java
更新时间:2019-05-31
   友情提示:(无需注册或充值,赞助后即可获取资源下载链接)

     嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300

本次赞助数额为: 2 元 
   源码介绍
在安卓移动端,通过网络,JDBC直连Windows桌面的SqlServer数据库;经测试可正常使用

package com.example.sqlserverandroidtest2;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;

import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.Toast;

public class MainActivity extends Activity {

    // 按钮控件
    private Button btnInsert;
    // jtds驱动路径
    private String drive = "net.sourceforge.jtds.jdbc.Driver";
    // SQL连接字符串,格式是 jdbc:jtds:sqlserver://服务器IP:端口号/数据库名称
    // 端口号默认为1433,如果不是,可以打开SQL Server配置管理器设定,
    // 如果你的SQL Server不是默认实例,需添加连接字符串为
    // jdbc:jtds:sqlserver://服务器IP:端口号/数据库名称;instance=实例名,不过博主没有试验过,你可以百度一下。
    private String connStr = "jdbc:jtds:sqlserver://172.21.56.14:1433/adotest";
    // 用户名和密码,则是对应的数据库的帐号,博主使用sa进行说明,如果你用的不是sa,记得在数据库表中打开你的帐号的权限。
    private String uid = "sa";
    private String pwd = "1";
    // 连接对象,相当于C#中的SqlConnection
    private Connection con = null;
    // 执行对象,相当于C#中的SqlCommand
    private PreparedStatement pstm = null;
    // handler处理对象,用于在跨线程时,在线程间的响应,用于控制主线程的控件(不能跨线程控制控件)
    private Handler handler = new Handler();

    // 执行语句
    private String sql = "insert into [GdInfoSTJF]([barcode],[gdName],[gdColor]) values ('01','aaa','color-01');"
    		  "insert into [GdInfoSTJF]([barcode],[gdName],[gdColor]) values ('6901','bbb','color-02');";
    // 执行结果,受影响行数
    private int resultCount;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        // 找到btnInsert按钮
        btnInsert = (Button) findViewById(R.id.btnInsert);
        // 设定btnInsert的click操作的监听事件,btnInsert被点击时,触发clickEvent()方法
        btnInsert.setOnClickListener(clickEvent());
    }

    // clickEvent()方法
    public OnClickListener clickEvent() {
        return new OnClickListener() {

            // 方法体
            @Override
            public void onClick(View view) {
                // TODO Auto-generated method stub
                if (view == btnInsert) {
                    // 必须开启新的线程执行
                    Thread thread = new Thread(new Runnable() {

                        @Override
                        public void run() {
                            // TODO Auto-generated method stub
                            // 线程在运行后,执行Insert()方法,返回受影响行数,赋值给resultCount
                            resultCount = Insert();
                            // 使用handler,使主线程响应并执行runShowResult方法
                            handler.post(runShowResult);
                        }
                    });
                    // 线程运行
                    thread.start();
                }
            }
        };
    }

    // 操作数据库的方法
    public int Insert() {
        int count = 0;
        try {
            // 加载驱动
            Class.forName(drive);
        } catch (ClassNotFoundException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        try {
            // 创建连接对象,加入连接字符串、用户名、密码
            con = DriverManager.getConnection(connStr, uid, pwd);
            // 创建执行对象,并加入执行语句
            pstm = con.prepareStatement(sql);
            // 执行SQL语句,并返回受影响行数
            count = pstm.executeUpdate();
        } catch (SQLException e) {
            e.printStackTrace();
            count = -1;
        } finally {
            try {
                // 关闭连接
                pstm.close();
                con.close();
            } catch (Exception e2) {
                // TODO: handle exception
                e2.printStackTrace();
            }
        }
        return count;
    }

    // 主线程响应方法,用于显示提示气泡
    public Runnable runShowResult = new Runnable() {

        @Override
        public void run() {
            // TODO Auto-generated method stub
            String tips = "受影响行数为:"   resultCount;
            // 弹出气泡
            Toast.makeText(getApplicationContext(), tips, Toast.LENGTH_SHORT).show();
        }
    };

    // 暂不需要理会
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }

    // 暂不需要理会
    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();
        if (id == R.id.action_settings) {
            return true;
        }
        return super.onOptionsItemSelected(item);
    }
}