91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

android怎么使用mysql

發布時間:2021-05-12 14:17:05 來源:億速云 閱讀:229 作者:小新 欄目:移動開發

這篇文章主要介紹了android怎么使用mysql,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

android可以使用mysql數據庫,android連接數據庫的方式有兩種。

第一種是通過連接服務器,再由服務器讀取數據庫來實現數據的增刪改查,這也是我們常用的方式。

第二種方式是android直接連接數據庫,這種方式非常耗手機內存,而且容易被反編譯造成安全隱患,所以在實際項目中不推薦使用。

1.加載外部jar包

在Android工程中要使用jdbc的話,要導入jdbc的外部jar包,因為在Java的jdk中并沒有jdbc的api,我使用的jar包是mysql-connector-java-5.1.18-bin.jar包,網絡上有使用mysql-connector-java-5.1.18-bin.jar包的,自己去用的時候發現不兼容,所以下載了比較新版本的,jar包可以去官網下載,也可以去百度,有很多前人們上傳的。

2.導入jar包的方式

方式一:

可以在項目的build.gradle文件中直接添加如下語句導入

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

方式二:下載jar包復制到項目的libs目錄下,然后右鍵復制過來的jar包Add as libs

三.建立數據庫連接

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為數據IP,Port為端口號,DBName為數據名稱,UserName為數據庫登錄賬戶,Password為數據庫登錄密碼

      con =

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

      DriverManager.getConnection("jdbc:mysql://http://192.168.1.100/phpmyadmin/index.php:8086/b2b",

          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);  //測試數據庫連接

    } 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”的所有內容

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

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

      //<code>ResultSet</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之后,不允許在主線程中進行比較耗時的操作(連接數據庫就屬于比較耗時的操作),需要開一個新的線程來處理這種耗時的操作,沒新線程時,一直就是程序直接退出,開了一個新線程處理直接,就沒問題了。

當然,連接數據庫是需要網絡的,千萬別忘了添加訪問網絡權限:

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

四.bug點

1.導入的jar包一定要正確

2.連接數據庫一定要開啟新線程

3.數據庫的IP一定要是可以ping通的,局域網地址手機是訪問不了的

4.數據庫所在的服務器是否開了防火墻,阻止了訪問

Android是什么

Android是一種基于Linux內核的自由及開放源代碼的操作系統,主要使用于移動設備,如智能手機和平板電腦,由美國Google公司和開放手機聯盟領導及開發。

感謝你能夠認真閱讀完這篇文章,希望小編分享的“android怎么使用mysql”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

灵宝市| 克什克腾旗| 沾化县| 嘉义县| 五台县| 开鲁县| 开江县| 漯河市| 富民县| 阳曲县| 宝兴县| 山阳县| 张家港市| 江孜县| 溧阳市| 西安市| 宜川县| 德惠市| 呼伦贝尔市| 和平县| 都匀市| 玛多县| 扎囊县| 巴中市| 什邡市| 焦作市| 凤台县| 金山区| 固原市| 郴州市| 宁武县| 礼泉县| 高淳县| 始兴县| 镇赉县| 达拉特旗| 嘉义县| 上杭县| 谢通门县| 漠河县| 陆河县|