基本信息
源码名称:安卓SqlServer直连Demo
源码大小:1.18M
文件格式:.zip
开发语言:Java
更新时间:2019-05-31
友情提示:(无需注册或充值,赞助后即可获取资源下载链接)
嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300
本次赞助数额为: 2 元×
微信扫码支付:2 元
×
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
源码介绍
在安卓移动端,通过网络,JDBC直连Windows桌面的SqlServer数据库;经测试可正常使用
在安卓移动端,通过网络,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); } }