成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

安卓怎么安裝mysql 安卓怎么安裝instagram

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

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

成都創(chuàng)新互聯(lián)網(wǎng)站建設(shè)由有經(jīng)驗(yàn)的網(wǎng)站設(shè)計(jì)師、開(kāi)發(fā)人員和項(xiàng)目經(jīng)理組成的專業(yè)建站團(tuán)隊(duì),負(fù)責(zé)網(wǎng)站視覺(jué)設(shè)計(jì)、用戶體驗(yàn)優(yōu)化、交互設(shè)計(jì)和前端開(kāi)發(fā)等方面的工作,以確保網(wǎng)站外觀精美、成都做網(wǎng)站、網(wǎng)站設(shè)計(jì)易于使用并且具有良好的響應(yīng)性。

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

一.前言

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

二.準(zhǔn)備工作

1.加載外部jar包

在Android工程中要使用jdbc的話,要導(dǎo)入jdbc的外部jar包,因?yàn)樵贘ava的jdk中并沒(méi)有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文件中直接添加如下語(yǔ)句導(dǎo)入

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

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

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

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ù)庫(kù)登錄賬戶,Password為數(shù)據(jù)庫(kù)登錄密碼

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ù)庫(kù)連接

} 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ù)庫(kù)就屬于比較耗時(shí)的操作),需要開(kāi)一個(gè)新的線程來(lái)處理這種耗時(shí)的操作,沒(méi)新線程時(shí),一直就是程序直接退出,開(kāi)了一個(gè)新線程處理直接,就沒(méi)問(wèn)題了。

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

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

四.bug點(diǎn)

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

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

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

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

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

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

原文鏈接:

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

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

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

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

(在此之前,首先

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

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

3.在數(shù)據(jù)庫(kù)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

安卓系統(tǒng)怎么裝mysql數(shù)據(jù)庫(kù)

這個(gè),不建議你用Android程序去直連MySQL數(shù)據(jù)庫(kù),不是做不到,而是我覺(jué)得這樣做不好,出于安全等方面考慮,你的數(shù)據(jù)庫(kù)地址,用戶名密碼,查詢SQL什么的都存在程序里,很容易被反編譯等方法看到。

我建議你和你那做網(wǎng)頁(yè)前端的商量一下,讓他們把表示層和數(shù)據(jù)層邏輯分開(kāi),數(shù)據(jù)層對(duì)應(yīng)網(wǎng)頁(yè)的表示層提供接口,同時(shí)在為你的Android手機(jī)端提供一個(gè)接口,簡(jiǎn)介訪問(wèn)數(shù)據(jù)庫(kù),這接口可以2端都保持一致,比如XML+RPC或者json等等,Android端也有現(xiàn)成的東西能直接用,既安全又省事。

新聞標(biāo)題:安卓怎么安裝mysql 安卓怎么安裝instagram
當(dāng)前地址:http://jinyejixie.com/article6/doohpig.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開(kāi)發(fā)、關(guān)鍵詞優(yōu)化、手機(jī)網(wǎng)站建設(shè)營(yíng)銷型網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)公司網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都app開(kāi)發(fā)公司
黄石市| 天津市| 进贤县| 永泰县| 嘉鱼县| 桑日县| 通州市| 南皮县| 宜兰市| 北京市| 潮安县| 高邑县| 武隆县| 右玉县| 屯门区| 湖口县| 赤水市| 兴和县| 商城县| 洛隆县| 无极县| 宁城县| 海城市| 松原市| 阿尔山市| 来凤县| 延长县| 甘德县| 峨山| 和田市| 温宿县| 宝兴县| 乡城县| 罗山县| 汪清县| 四平市| 佛学| 灵山县| 湘乡市| 海盐县| 门源|