真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

手機(jī)怎么連接mysql服務(wù)器 手機(jī)連MySQL

android怎么鏈接數(shù)據(jù)庫mysql

有點(diǎn)多請(qǐng)耐心看完。

成都創(chuàng)新互聯(lián)是一家專業(yè)提供同安企業(yè)網(wǎng)站建設(shè),專注與成都網(wǎng)站建設(shè)、做網(wǎng)站、H5技術(shù)、小程序制作等業(yè)務(wù)。10年已為同安眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)的建站公司優(yōu)惠進(jìn)行中。

希望能幫助你,還請(qǐng)及時(shí)采納謝謝。

一.前言

android連接數(shù)據(jù)庫的方式有兩種,第一種是通過連接服務(wù)器,再由服務(wù)器讀取數(shù)據(jù)庫來實(shí)現(xiàn)數(shù)據(jù)的增刪改查,這也是我們常用的方式。第二種方式是android直接連接數(shù)據(jù)庫,這種方式非常耗手機(jī)內(nèi)存,而且容易被反編譯造成安全隱患,所以在實(shí)際項(xiàng)目中不推薦使用。

二.準(zhǔn)備工作

1.加載外部jar包

在Android工程中要使用jdbc的話,要導(dǎo)入jdbc的外部jar包,因?yàn)樵贘ava的jdk中并沒有jdbc的api,我使用的jar包是mysql-connector-java-5.1.18-bin.jar包,網(wǎng)絡(luò)上有使用mysql-connector-java-5.1.18-bin.jar包的,自己去用的時(shí)候發(fā)現(xiàn)不兼容,所以下載了比較新版本的,jar包可以去官網(wǎng)下載,也可以去百度,有很多前人們上傳的。

2.導(dǎo)入jar包的方式

方式一:

可以在項(xiàng)目的build.gradle文件中直接添加如下語句導(dǎo)入

compile files('libs/mysql-connector-java-5.1.18-bin.jar')

方式二:下載jar包復(fù)制到項(xiàng)目的libs目錄下,然后右鍵復(fù)制過來的jar包Add as libs

三.建立數(shù)據(jù)庫連接

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_jdbc);

new Thread(runnable).start();

}

Handler myHandler=new Handler(){

public void handleMessage(Message msg) {

// TODO Auto-generated method stub

super.handleMessage(msg);

Bundle data=new Bundle();

data=msg.getData();

//System.out.println("id:"+data.get("id").toString()); //輸出第n行,列名為“id”的值

Log.e("TAG","id:"+data.get("id").toString());

TextView tv= (TextView) findViewById(R.id.jdbc);

//System.out.println("content:"+data.get("content").toString());

}

};

Runnable runnable=new Runnable() {

private Connection con = null;

@Override

public void run() {

// TODO Auto-generated method stub

try {

Class.forName("com.mysql.jdbc.Driver");

//引用代碼此處需要修改,address為數(shù)據(jù)IP,Port為端口號(hào),DBName為數(shù)據(jù)名稱,UserName為數(shù)據(jù)庫登錄賬戶,Password為數(shù)據(jù)庫登錄密碼

con =

//DriverManager.getConnection("jdbc:mysql://192.168.1.202:3306/b2b", "root", "");

DriverManager.getConnection("jdbc:mysql://",

UserName,Password);

} catch (SQLException e) {

// TODO Auto-generated catch block

e.printStackTrace();

} catch (ClassNotFoundException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

try {

testConnection(con); //測(cè)試數(shù)據(jù)庫連接

} catch (java.sql.SQLException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

public void testConnection(Connection con1) throws java.sql.SQLException {

try {

String sql = "select * from ecs_users"; //查詢表名為“oner_alarm”的所有內(nèi)容

Statement stmt = con1.createStatement(); //創(chuàng)建Statement

ResultSet rs = stmt.executeQuery(sql); //ResultSet類似Cursor

//codeResultSet/code最初指向第一行

Bundle bundle=new Bundle();

while (rs.next()) {

bundle.clear();

bundle.putString("id",rs.getString("userid"));

//bundle.putString("content",rs.getString("content"));

Message msg=new Message();

msg.setData(bundle);

myHandler.sendMessage(msg);

}

rs.close();

stmt.close();

} catch (SQLException e) {

} finally {

if (con1 != null)

try {

con1.close();

} catch (SQLException e) {}

}

}

};

注意:

在Android4.0之后,不允許在主線程中進(jìn)行比較耗時(shí)的操作(連接數(shù)據(jù)庫就屬于比較耗時(shí)的操作),需要開一個(gè)新的線程來處理這種耗時(shí)的操作,沒新線程時(shí),一直就是程序直接退出,開了一個(gè)新線程處理直接,就沒問題了。

當(dāng)然,連接數(shù)據(jù)庫是需要網(wǎng)絡(luò)的,千萬別忘了添加訪問網(wǎng)絡(luò)權(quán)限:

uses-permission android:name=”android.permission.INTERNET”/

四.bug點(diǎn)

1.導(dǎo)入的jar包一定要正確

2.連接數(shù)據(jù)庫一定要開啟新線程

3.數(shù)據(jù)庫的IP一定要是可以ping通的,局域網(wǎng)地址手機(jī)是訪問不了的

4.數(shù)據(jù)庫所在的服務(wù)器是否開了防火墻,阻止了訪問

————————————————

版權(quán)聲明:本文為CSDN博主「shuaiyou_comon」的原創(chuàng)文章,遵循CC 4.0 BY-SA版權(quán)協(xié)議,轉(zhuǎn)載請(qǐng)附上原文出處鏈接及本聲明。

原文鏈接:

android手機(jī)軟件開發(fā)中 怎么連接Mysql數(shù)據(jù)庫

一、首先要加載JDBC驅(qū)動(dòng)包。

步驟:右擊項(xiàng)目找到build path-configure build path-libraries——add External JARs添加驅(qū)動(dòng)包

二、寫測(cè)試類:TestCon.java

(在此之前,首先

1.在自己的電腦上Mysql下確定賬戶是"root",密碼是"123456";

2.進(jìn)入賬戶,創(chuàng)建數(shù)據(jù)庫cui;

3.在數(shù)據(jù)庫cui下面,創(chuàng)建表test1 包含_id(int 類型自動(dòng)增加) username(String 類型)、password(String 類型);

4.在表中插入數(shù)據(jù),以便顯示

1 package com.test.an;

2

3 import java.sql.Connection;

4 import java.sql.DriverManager;

5 import java.sql.PreparedStatement;

6 import java.sql.ResultSet;

7 import java.sql.SQLException;

8

9

10 public class TestCon1{

11 public static void main(String[] args)

12 {

13 Connection con = null;

14 String sql;

15 PreparedStatement pre;

16 ResultSet rs;

17

18 try {

19 String driver="com.mysql.jdbc.Driver";

20 Class.forName(driver);

21

22 String url="jdbc:mysql://localhost:3306/cuiuseUnicode=truecharacterEncoding=latin1";//utf-8也行

23 con = DriverManager.getConnection(url, "root", "123456");

24

25 sql = "select _id,username,password from test1" ;

26 pre = con.prepareStatement(sql);

27

28 rs = pre.executeQuery();

29 while(rs.next()){

30 int id = rs.getInt(1);

31 String username = rs.getString(2);

32 String password = rs.getString(3);

33

34 System.out.println("id="+id+";username="+username+";password="+password);

35 }

36 con.close();

37 } catch (SQLException e) {

38 e.printStackTrace();

39 } catch (ClassNotFoundException e) {

40 e.printStackTrace();

41 }

42

43 }

44

45 }

運(yùn)行結(jié)果:

id=1;username=ccc;password=123456

id=2;username=xxx;password=654321

id=3;username=ddd;password=123456

id=4;username=ddf÷;password=yyt

id=5;username=cuixiaodong;password=cxd

id=6;username=vv;password=cxd

請(qǐng)問Android怎樣連接遠(yuǎn)程MySQL數(shù)據(jù)庫?

Android客戶端直接連接遠(yuǎn)程MySQL數(shù)據(jù)庫的方法如下:

String result = "";

//首先使用NameValuePair封裝將要查詢的年數(shù)和關(guān)鍵字綁定

ArrayListNameValuePair nameValuePairs = new ArrayListNameValuePair();

nameValuePairs.add(new BasicNameValuePair("year","1980"));

//使用HttpPost封裝整個(gè)SQL語句

//使用HttpClient發(fā)送HttpPost對(duì)象

try{

HttpClient httpclient = new DefaultHttpClient();

HttpPost httppost = new HttpPost("");

httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));

HttpResponse response = httpclient.execute(httppost);

HttpEntity entity = response.getEntity();

InputStream is = entity.getContent();

}catch(Exception e){

Log.e("log_tag", "Error in http connection "+e.toString());

}

//將HttpEntity轉(zhuǎn)化為String

try{

BufferedReader reader = new BufferedReader(new InputStreamReader(is,"iso-8859-1"),8);

StringBuilder sb = new StringBuilder();

String line = null;

while ((line = reader.readLine()) != null) {

sb.append(line + "\n");

}

is.close();

result=sb.toString();

}catch(Exception e){

Log.e("log_tag", "Error converting result "+e.toString());

}

//將String通過JSONArray解析成最終結(jié)果

try{

JSONArray jArray = new JSONArray(result);

for(int i=0;ijArray.length();i++){

JSONObject json_data = jArray.getJSONObject(i);

Log.i("log_tag","id: "+json_data.getInt("id")+

", name: "+json_data.getString("name")+

", sex: "+json_data.getInt("sex")+

", birthyear: "+json_data.getInt("birthyear")

);

}

}

}catch(JSONException e){

Log.e("log_tag", "Error parsing data "+e.toString());

}

雖然Android開發(fā)中可以直接連接數(shù)據(jù)庫,但是實(shí)際中卻不建議這么做,應(yīng)該使用服務(wù)器端中轉(zhuǎn)下完成。


文章名稱:手機(jī)怎么連接mysql服務(wù)器 手機(jī)連MySQL
本文地址:http://weahome.cn/article/hjhsoh.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部