Android 使用jtds遠程訪問數據庫

最近老師讓我用jtds這個jar包遠程訪問數據庫中的數據,雖然不難,但有幾個點還是要注意一下的。

1、jtds的jar包我使用的是1.2.7這個版本的,如果是Java工程使用的是1.3.1這個版本,Android工程不能使用1.3.1否則連接不上數據庫

2、遠程數據庫服務器的防火墻要關閉

?

下面是如何使用jtds的案例

Javabean有兩個字段一個是id,一個是stuName

package com.ht.jdts;

public class StuDomain {
?? ?private String id;
?? ?private String stuName;
?? ?public String getId() {
?? ??? ?return id;
?? ?}
?? ?public void setId(String id) {
?? ??? ?this.id = id;
?? ?}
?? ?public String getStuName() {
?? ??? ?return stuName;
?? ?}
?? ?public void setStuName(String stuName) {
?? ??? ?this.stuName = stuName;
?? ?}
}

?

訪問sqlserver的工具類

package com.example.jdtsproc;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;

public class SqlHelper {
?? ?private String drive = "net.sourceforge.jtds.jdbc.Driver";
?? ?private String connStr;
?? ?private String server;
?? ?private String dbName;
?? ?private String userName;
?? ?private String userPwd;
?? ?private Connection con;
?? ?private PreparedStatement pstm;
?? ?private ResultSet rs;
?? ?private Statement stmt;

?? ?public SqlHelper(String server, String dbName, String userName,
?? ??? ??? ?String userPwd) {
?? ??? ?this.server = server;
?? ??? ?this.dbName = dbName;//數據庫名
?? ??? ?this.connStr = "jdbc:jtds:sqlserver://" + this.server + ":1433/"
?? ??? ??? ??? ?+ this.dbName;

?? ??? ?this.userName = userName;
?? ??? ?this.userPwd = userPwd;

?? ?
?? ?}

?? ?public List<StuDomain> ExecuteQuery(String sql) {

?? ??? ?List<StuDomain> stuLists = new ArrayList<StuDomain>();
?? ??? ?
?? ??? ?try {
?? ??? ??? ?Class.forName(drive);
?? ??? ??? ?System.out.println("驅動加載成功");
?? ??? ??? ?con = DriverManager.getConnection(this.connStr, this.userName,
?? ??? ??? ??? ??? ?this.userPwd);
?? ??? ??? ?System.out.println("數據庫連接成功");
?? ??? ??? ?//pstm = con.prepareStatement(sql);
?? ??? ??? ?
?? ??? ??? ?stmt = con.createStatement();
?? ??? ??? ?
?? ??? ??? ?rs = stmt.executeQuery(sql);
?? ??? ??? ?
?? ??? ??? ?while (rs.next()) {

?? ??? ??? ??? ?StuDomain stuDomain=new StuDomain();
?? ??? ??? ??? ?stuDomain.setId(rs.getString(1));
?? ??? ??? ??? ?stuDomain.setStuName(rs.getString(2));
?? ??? ??? ??? ?
?? ??? ??? ??? ?stuLists.add(stuDomain);

?? ??? ??? ?}
?? ??? ??? ?System.out.println("stuLists.size():"+stuLists.size());

?? ??? ?} catch (Exception e) {
?? ??? ??? ?System.out.println("數據庫連接異常");
?? ??? ??? ?e.printStackTrace();
?? ??? ??? ?return null;
?? ??? ?} finally {
?? ??? ??? ?try {
?? ??? ??? ??? ?if(rs!=null){
?? ??? ??? ??? ??? ?rs.close();?? ??? ??? ?
?? ??? ??? ??? ?}
?? ??? ??? ??? ?if(stmt!=null){
?? ??? ??? ??? ??? ?stmt.close();
?? ??? ??? ??? ?}
?? ??? ??? ??? ?if(con!=null){
?? ??? ??? ??? ??? ?con.close();
?? ??? ??? ??? ?}

?? ??? ??? ?} catch (SQLException e) {
?? ??? ??? ??? ?// TODO Auto-generated catch block
?? ??? ??? ??? ?e.printStackTrace();
?? ??? ??? ?}
?? ??? ?}
?? ??? ?return stuLists;
?? ?}

}

?

MainActivity 并將數據顯示在ListView上

package com.example.jdtsproc;

import java.util.List;

import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.os.Handler;

import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.TextView;


public class MainActivity extends ActionBarActivity {

??? private Button btn_connect;
?? ?private ListView lv_lists;
?? ?
?? ?private List<StuDomain> stuLists;

?? ?private SqlHelper sh=new SqlHelper("xxx.xx.xxx.xx", "MyDb1", "sa", "sa");//第一個參數是訪問的遠程數據庫服務器的ip
?? ?private Handler mHandler=new Handler(){
?? ??? ?public void handleMessage(android.os.Message msg) {
?? ??? ??? ?lv_lists.setAdapter(new StuAdapter());
?? ??? ?};
?? ?};
?? ?@Override
??? protected void onCreate(Bundle savedInstanceState) {
??????? super.onCreate(savedInstanceState);
??????? setContentView(R.layout.activity_main);
?????? ?
??????? initView();
?????? ?
??????? initData();
?????? ?
??? }

?? ?private void initData() {
?? ??? ?btn_connect.setOnClickListener(new OnClickListener() {
?? ??? ??? ?
?? ??? ??? ?@Override
?? ??? ??? ?public void onClick(View v) {
?? ??? ??? ??? ?new Thread(){
?? ??? ??? ??? ??? ?
?? ??? ??? ?

?? ??? ??? ??? ??? ?public void run() {
?? ??? ??? ??? ??? ??? ?String sql="select *from stu";
?? ??? ??? ??? ??? ??? ?stuLists = sh.ExecuteQuery(sql);
?? ??? ??? ??? ??? ??? ?
?? ??? ??? ??? ??? ??? ?mHandler.sendEmptyMessage(0);//發送消息
?? ??? ??? ??? ??? ??? ?//lv_lists.setAdapter(new StuAdapter());
?? ??? ??? ??? ??? ?};
?? ??? ??? ??? ?}.start();
?? ??? ??? ?}
?? ??? ?});
?? ?}

?? ?private void initView() {
?? ??? ?//找到我們所需要的
?? ??? ?btn_connect = (Button) findViewById(R.id.btn_connect);
?? ??? ?lv_lists = (ListView) findViewById(R.id.lv_lists);
?? ?}

?? ?class StuAdapter extends BaseAdapter{

?? ??? ?@Override
?? ??? ?public int getCount() {

?? ??? ??? ?return stuLists.size();
?? ??? ?}

?? ??? ?@Override
?? ??? ?public StuDomain getItem(int position) {

?? ??? ??? ?return stuLists.get(position);
?? ??? ?}

?? ??? ?@Override
?? ??? ?public long getItemId(int position) {
?? ??? ??? ?
?? ??? ??? ?return position;
?? ??? ?}

?? ??? ?@Override
?? ??? ?public View getView(int position, View convertView, ViewGroup parent) {
?? ??? ??? ?StuViewHolder stuHolder;
?? ??? ??? ?if(convertView==null){
?? ??? ??? ??? ?convertView=View.inflate(getApplicationContext(), R.layout.list_main, null);
?? ??? ??? ??? ?stuHolder=new StuViewHolder();
?? ??? ??? ??? ?stuHolder.tv_id=(TextView) convertView.findViewById(R.id.tv_id);
?? ??? ??? ??? ?stuHolder.tv_stuname=(TextView) convertView.findViewById(R.id.tv_stuname);
?? ??? ??? ??? ?stuHolder.iv_photos=(ImageView) convertView.findViewById(R.id.iv_photos);
?? ??? ??? ?}else{
?? ??? ??? ??? ?stuHolder=(StuViewHolder) convertView.getTag();
?? ??? ??? ?}
?? ??? ??? ?stuHolder.tv_id.setText(getItem(position).getId());
?? ??? ??? ?stuHolder.tv_stuname.setText(getItem(position).getStuName());
?? ??? ??? ?stuHolder.iv_photos.setImageResource(R.drawable.photopager);
?? ??? ??? ?return convertView;
?? ??? ?}
?? ??? ?
?? ?}
?? ?
?? ?class StuViewHolder{
?? ??? ?public TextView tv_id;
?? ??? ?public TextView tv_stuname;
?? ??? ?public ImageView iv_photos;
?? ?}
?
}

?

最后奉獻jtds的兩個jar包??? 永久鏈接:https://pan.baidu.com/s/1YBW1I_ddSKe7vcIouDXKrg 密碼:0v95

轉載于:https://www.cnblogs.com/ww7018/p/9484159.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/277469.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/277469.shtml
英文地址,請注明出處:http://en.pswp.cn/news/277469.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

java乘以2的位計算符號_java編程之:按位與運算,等運算規則

按位與運算符(&)參加運算的兩個數據&#xff0c;按二進制位進行“與”運算。運算規則&#xff1a;0&00; 0&10; 1&00; 1&11;即&#xff1a;兩位同時為“1”&#xff0c;結果才為“1”&#xff0c;否則為0例如&#xff1a;3&5 即 0000 0011 &a…

C語言文字加密程序的實現

前言&#xff1a;當今社會是一個信息社會&#xff0c;你的個人信息和聊天記錄極有可能被別有用心的人時時刻刻監視著&#xff0c;那么你想不想實現專屬于兩個人或一個小圈子的人在社交軟件上的交流不被任何其他人讀懂呢&#xff1f;下面就給大家提供一個原理極其簡單程序極其容…

菜鳥-es6

這里就不在嘮叨瀏覽器對es6的支持跟轉碼器了&#xff0c;稍微百度一下就ok let and const 變量 and 常量 什么是變量,什么是常量 - 都是存儲數據的容器, - 變量》即意思就是程序運行中可以發生變化的,- 常量》即程序運行中不可以發生改變&#xff0c;- 注意&#xff1a;常量…

阿帕奇退出java_java+tomcat+apache安裝整合,啟動/關閉,添加開機啟動服務

安裝java1.8#yum update 服務器更新源碼包#rpm -qa |grep -E ^open[jre|jdk]|j[re|dk] 搜索任何版本的已安裝JDK組件java-1.8.0-openjdk-headless-1.8.0.60-2.b27.el7_1.x86_64pygobject2-2.28.6-11.el7.x86_64pygobject3-base-3.8.2-6.el7.x86_64java-1.8.0-openjdk-1.8.0…

Spring Boot中如何干掉if else

Spring Boot中如何干掉if elsehttp://www.ciphermagic.cn/spring-boot-without-if-else.html 轉載于:https://www.cnblogs.com/tyk766564616/p/11089133.html

java 抽象類與接口理解

2019獨角獸企業重金招聘Python工程師標準>>> 在java 中抽象類是implements [等有時間了補充] 轉載于:https://my.oschina.net/kuchawyz/blog/1929094

dreambackend.java_【AndroidTV】如何自定義屏保、更改屏保時長

目錄目錄系統屏保源碼有哪些在設置中顯示的屏保選項有哪些屏保選項是如何獲得的多久出現屏保修改方法我的應用項目需求處理方式遇到一個詭異的問題系統屏保源碼有哪些如果要自定義屏保可以參考這里的源碼&#xff0c;清晰易懂&#xff0c;比網上教程好屏保源碼位置BasicDreampa…

模塊初識

1.模塊 模塊的定義與分類 一個模塊就是一個py文件.這個魔鎧存儲很多相似的功能,相似的函數集合體分類 內置模塊,標準庫,Python自帶的,times,os,sys,等等200多種第三方庫(模塊),各種大神寫的一些模塊,通過pip install....安裝,有6000多種自己寫的模塊,自定義模塊2.import # impo…

算法:把數組排成最小的數

* Description 把數組排成最小的數* 問題&#xff1a;輸入一個正整數數組&#xff0c;把數組里所有數字拼接起來排成一個數&#xff0c;打印能拼接出的所有數字中最小的一個。* 例如輸入數組{3&#xff0c;32&#xff0c;321}&#xff0c;則打印出這三個數字能排成的最小數字為…

牛客網在線編程java_NowCoder

com.adamjwh.pratice.offer.FindInArrays二維數組中的查找com.adamjwh.pratice.offer.ReplaceSpace替換空格com.adamjwh.pratice.offer.PrintList從頭到尾打印鏈表com.adamjwh.pratice.offer.ReConstructTree重建二叉樹com.adamjwh.pratice.offer.MakeQueueWithStack用兩個棧實…

質量大國-學習概要

問題場景&#xff1a;英國 不斷重新定義度量一碼歷史故事&#xff1a;冷兵器 206年 長平之戰 度量衡商鞅統一度量衡 秦國 質量 0.83毫米的箭頭 秦國的統一度量衡帶來的巨大收益。 1&#xff0c;1791 巴黎 法國科學院 科學革命要為完美的社會提供基點 創建計量體系 孔多塞 重新定…

join的簡單總結

BAT面試題&#xff1a;現在有T1、T2、T3三個線程&#xff0c;你怎樣保證T2在T1執行完后執行&#xff0c;T3在T2執行完后執行&#xff1f; 這個線程問題通常會在第一輪或電話面試階段被問到&#xff0c;目的是檢測你對”join”方法是否熟悉。這個多線程問題比較簡單&#xff0c;…

python numpy矩陣索引_python – Numpy中的矩陣索引

索引后查看形狀&#xff1a;In [295]: Anp.matrix([1,2,3])In [296]: A.shapeOut[296]: (1, 3)In [297]: A[0]Out[297]: matrix([[1, 2, 3]])In [298]: A[0].shapeOut[298]: (1, 3)這種行為的關鍵是np.matrix總是2d.所以即使你選擇一行(A [0,&#xff1a;]),結果仍然是2d,形狀(…

Activity的呼叫轉移*(3個Activity之間的跳轉)

Redirection的意思就是“呼叫轉移&#xff0c;重寄”的意思 我們也許會再程序開發中遇到這種情況&#xff0c;需要從一個Activity&#xff08;A&#xff09;跳轉到另一個Activity&#xff08;B&#xff09;&#xff0c;當在這個Activity&#xff08;B&#xff09;中處理完一些操…

深度解析數據分析、大數據工程師和數據科學家的區別

數據越來越多的影響并塑造著那些我們每天都要交互的系統。不管是你使用Siri&#xff0c;google搜索&#xff0c;還是瀏覽facebook的好友動態&#xff0c;你都在消費者數據分析的結果。我們賦予了數據如此大的轉變的能力&#xff0c;也難怪近幾年越來越多的數據相關的角色被創造…

python webservice接口測試傳參數_Python3 webservice接口測試方法是什么

Python3 webservice接口測試方法是什么發布時間&#xff1a;2020-06-23 14:07:46來源&#xff1a;億速云閱讀&#xff1a;92作者&#xff1a;清晨不懂Python3 webservice接口測試方法是什么&#xff1f;其實想解決這個問題也不難&#xff0c;下面讓小編帶著大家一起學習怎么去解…

zabbix4.2 系列(二):agent配置

zabbix-agent&#xff1a; 分為主動模式和被動模式&#xff0c;均在配置文件實現&#xff08;主動模式和被動模式可同時設置&#xff09;&#xff1a; vim /etc/zabbix/zabbix_agentd.conf Server192.168.18.154 &#xff08;用于被動模式&#xff0c;允許哪臺服務器可以…

java form 對象 一對一_java-雙向一對一地“對象引用了一個未保存...

我有一個簡單的一對一關系&#xff1a;>為每個實體單獨的DAO.>事務由Spring管理.PersonDao personDao ctx.getBean(PersonDao.class, "personDaoImpl");VehicleDao vehicleDao ctx.getBean(VehicleDao.class, "vehicleDaoImpl");Vehicle vehicle …

RabbitMQ 入門教程(PHP版) 第三部分:發布/訂閱(Publish/Subscribe)

發布&#xff0f;訂閱 在上篇第二部分教程中&#xff0c;我們搭建了一個工作隊列。每個任務之分發給一個工作者&#xff08;worker&#xff09;。在本篇教程中&#xff0c;我們要做的之前完全不一樣——分發一個消息給多個消費者&#xff08;consumers&#xff09;。這種模式被…

Proxmox VE 安裝、配置、使用之第二章 Proxmox VE 的安全性

第一章 Proxmox VE 的安全性一、 角色及權限圖2-1-1二、 Root 的密碼安全性把 Root 的實際密碼給出去, 在任何系統都是不符合安全規范的!所以在 Linux 里面, 最好把有需要 root 權限的使用者 放到 sudoers 的群組.# sudo usermod -a -G sudo testuserPVE 的權限設定方式 是由 u…