mysql數(shù)據(jù)庫(kù)手機(jī)版怎么使用,手機(jī)mysql數(shù)據(jù)庫(kù)app下載

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

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

創(chuàng)新互聯(lián)建站基于成都重慶香港及美國(guó)等地區(qū)分布式IDC機(jī)房數(shù)據(jù)中心構(gòu)建的電信大帶寬,聯(lián)通大帶寬,移動(dòng)大帶寬,多線(xiàn)BGP大帶寬租用,是為眾多客戶(hù)提供專(zhuān)業(yè)服務(wù)器托管報(bào)價(jià),主機(jī)托管價(jià)格性?xún)r(jià)比高,為金融證券行業(yè)四川綿陽(yáng)服務(wù)器托管,ai人工智能服務(wù)器托管提供bgp線(xiàn)路100M獨(dú)享,G口帶寬及機(jī)柜租用的專(zhuān)業(yè)成都idc公司。

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

android 鏈接mysql數(shù)據(jù)庫(kù)實(shí)例:

package com.hl;

import java.sql.DriverManager;

import java.sql.ResultSet;

import com.mysql.jdbc.Connection;

import com.mysql.jdbc.Statement;

import android.app.Activity;

import android.os.Bundle;

import android.view.View;

import android.view.View.OnClickListener;

import android.widget.Button;

import android.widget.TextView;

public class AndroidMsql extends Activity {

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.main);

Button btn=(Button)findViewById(R.id.btn);

btn.setOnClickListener(new OnClickListener() {

@Override

public void onClick(View v) {

sqlCon();

}

});

}

private void mSetText(String str){

TextView txt=(TextView)findViewById(R.id.txt);

txt.setText(str);

}

private void sqlCon(){

try {

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

} catch (Exception e) {

e.printStackTrace();

}

try {

String url ="jdbc:mysql://192.168.142.128:3306/mysql?user=zzfeihuapassword=12345useUnicode=truecharacterEncoding=UTF-8";//鏈接數(shù)據(jù)庫(kù)語(yǔ)句

Connection conn= (Connection) DriverManager.getConnection(url); //鏈接數(shù)據(jù)庫(kù)

Statement stmt=(Statement) conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);

String sql="select * from user";//查詢(xún)user表語(yǔ)句

ResultSet rs=stmt.executeQuery(sql);//執(zhí)行查詢(xún)

StringBuilder str=new StringBuilder();

while(rs.next()){

str.append(rs.getString(1)+"\n");

}

mSetText(str.toString());

rs.close();

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

有點(diǎn)多請(qǐ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的話(huà),要導(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ù)名稱(chēng),UserName為數(shù)據(jù)庫(kù)登錄賬戶(hù),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"; //查詢(xún)表名為“oner_alarm”的所有內(nèi)容

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

ResultSet rs = stmt.executeQuery(sql); //ResultSet類(lèi)似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之后,不允許在主線(xiàn)程中進(jìn)行比較耗時(shí)的操作(連接數(shù)據(jù)庫(kù)就屬于比較耗時(shí)的操作),需要開(kāi)一個(gè)新的線(xiàn)程來(lái)處理這種耗時(shí)的操作,沒(méi)新線(xiàn)程時(shí),一直就是程序直接退出,開(kāi)了一個(gè)新線(xiàn)程處理直接,就沒(méi)問(wèn)題了。

當(dāng)然,連接數(shù)據(jù)庫(kù)是需要網(wǎng)絡(luò)的,千萬(wàn)別忘了添加訪(fǎng)問(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)啟新線(xiàn)程

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

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

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

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

原文鏈接:

mysql數(shù)據(jù)庫(kù)軟件怎么使用,如何連接數(shù)據(jù)?

可以使用mysql推出的mysqlconnector/net組件,該組件是mysql為ado.net訪(fǎng)問(wèn)mysql數(shù)據(jù)庫(kù)設(shè)計(jì)的.net專(zhuān)用訪(fǎng)問(wèn)組件,完成該組件后,需要在項(xiàng)目中引用這個(gè)組件,之后在程序中引用命名空間mysql.data.mysqlclient,即可開(kāi)始進(jìn)行連接mysql數(shù)據(jù)庫(kù)的操作了,示例如下:

protected

voidmysqlcon()

{

//數(shù)據(jù)庫(kù)連接字符串跟連接sqlserver沒(méi)有區(qū)別

string

constr

=

"server=localhost;userid=root;password=root;database=test";

//下面使用mysql

connector/net提供的專(zhuān)用對(duì)象

mysqlconnection

mycon

=

new

mysqlconnection(constr);

mycon.open();

mysqlcommandmycmd

=

new

mysqlcommand("select

*

from

users",

mycon);

mysqldatareader

myreader

=

mycmd.executereader();

while

(myreader.read())

{

if

(myreader.hasrows)

{

messagebox.show(myreader.getstring("email")

);

}

}

myreader.close();

mycon.close();

如何在iPhone應(yīng)用中使用MySQL數(shù)據(jù)庫(kù)呢?

如果mysql支持iPhone話(huà),當(dāng)然可以,不過(guò)一般是把mysql放在后臺(tái)用吧。iPhone通過(guò)網(wǎng)絡(luò)訪(fǎng)問(wèn)后臺(tái)的接口,讓后臺(tái)來(lái)調(diào)用mysql.

mysql數(shù)據(jù)庫(kù)用怎么操作

1、使用show語(yǔ)句找出在服務(wù)器上當(dāng)前存在什么數(shù)據(jù)庫(kù):

mysql

show

databases;

+----------+

|

database

|

+----------+

|

mysql

|

|

test

|

+----------+

3

rows

in

set

(0.00

sec)

2、創(chuàng)建一個(gè)數(shù)據(jù)庫(kù)abccs

mysql

create

database

abccs;

注意不同操作系統(tǒng)對(duì)大小寫(xiě)的敏感。

3、選擇你所創(chuàng)建的數(shù)據(jù)庫(kù)

mysql

use

abccs

database

changed

此時(shí)你已經(jīng)進(jìn)入你剛才所建立的數(shù)據(jù)庫(kù)abccs.

4、

創(chuàng)建一個(gè)數(shù)據(jù)庫(kù)表

首先看現(xiàn)在你的數(shù)據(jù)庫(kù)中存在什么表:

mysql

show

tables;

empty

set

(0.00

sec)

說(shuō)明剛才建立的數(shù)據(jù)庫(kù)中還沒(méi)有數(shù)據(jù)庫(kù)表。下面來(lái)創(chuàng)建一個(gè)數(shù)據(jù)庫(kù)表mytable:

我們要建立一個(gè)你公司員工的生日表,表的內(nèi)容包含員工姓名、性別、出生日期、出生城市。

mysql

create

table

mytable

(name

varchar(20),

sex

char(1),

-

birth

date,

birthaddr

varchar(20));

query

ok,

rows

affected

(0.00

sec)

由于name、birthadd的列值是變化的,因此選擇varchar,其長(zhǎng)度不一定是20。可以選擇從1到255的任何長(zhǎng)度,如果以后需要改變它的字長(zhǎng),可以使用alter

table語(yǔ)句。);性別只需一個(gè)字符就可以表示:"m"或"f",因此選用char(1);birth列則使用date數(shù)據(jù)類(lèi)型。

創(chuàng)建了一個(gè)表后,我們可以看看剛才做的結(jié)果,用show

tables顯示數(shù)據(jù)庫(kù)中有哪些表:

mysql

show

tables;

+---------------------+

|

tables

in

menagerie

|

+---------------------+

|

mytables

|

+---------------------+

5、顯示表的結(jié)構(gòu):

mysql

describe

mytable;

+-------------+-------------+------+-----+---------+-------+

|

field

|

type

|

null

|

key

|

default

|

extra

|

+-------------+-------------+------+-----+---------+-------+

|

name

|

varchar(20)

|

yes

|

|

null

|

|

|

sex

|

char(1)

|

yes

|

|

null

|

|

|

birth

|

date

|

yes

|

|

null

|

|

|

deathaddr

|

varchar(20)

|

yes

|

|

null

|

|

+-------------+-------------+------+-----+---------+-------+

4

rows

in

set

(0.00

sec)

6、

往表中加入記錄

我們先用select命令來(lái)查看表中的數(shù)據(jù):

mysql

select

*

from

mytable;

empty

set

(0.00

sec)

這說(shuō)明剛才創(chuàng)建的表還沒(méi)有記錄。

加入一條新記錄:

mysql

insert

into

mytable

-

values

(′abccs′,′f′,′1977-07-07′,′china′);

query

ok,

1

row

affected

(0.05

sec)

再用上面的select命令看看發(fā)生了什么變化。我們可以按此方法一條一條地將所有員工的記錄加入到表中。

網(wǎng)頁(yè)題目:mysql數(shù)據(jù)庫(kù)手機(jī)版怎么使用,手機(jī)mysql數(shù)據(jù)庫(kù)app下載
標(biāo)題URL:http://muchs.cn/article10/phijdo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站內(nèi)鏈建站公司、動(dòng)態(tài)網(wǎng)站、Google、軟件開(kāi)發(fā)、搜索引擎優(yōu)化

廣告

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

手機(jī)網(wǎng)站建設(shè)