实例介绍
【实例简介】在安卓移动端,通过网络,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); } }
好例子网口号:伸出你的我的手 — 分享!
小贴士
感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。
- 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
- 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
- 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
- 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。
关于好例子网
本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明
网友评论
我要评论