在好例子网,分享、交流、成长!
您当前所在位置:首页Java 开发实例Android平台开发 → 安卓SqlServer直连Demo

安卓SqlServer直连Demo

Android平台开发

下载此实例
  • 开发语言:Java
  • 实例大小:1.18M
  • 下载次数:33
  • 浏览次数:241
  • 发布时间:2019-05-31
  • 实例类别:Android平台开发
  • 发 布 人:crazycode
  • 文件格式:.zip
  • 所需积分:2
 相关标签: sql 安卓 Server demo

实例介绍

【实例简介】在安卓移动端,通过网络,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);
    }
}

标签: sql 安卓 Server demo

实例下载地址

安卓SqlServer直连Demo

不能下载?内容有错? 点击这里报错 + 投诉 + 提问

好例子网口号:伸出你的我的手 — 分享

网友评论

发表评论

(您的评论需要经过审核才能显示)

查看所有0条评论>>

小贴士

感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。

  • 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
  • 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
  • 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
  • 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。

关于好例子网

本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明

;
报警