android可以使用mysql數據庫,android連接數據庫的方式有兩種,分別是:1、通過連接服務器,再由服務器讀取數據庫來實現數據的增刪改查;2、加載外部jar包,直接連接數據庫。
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></uses-permission>
四.bug點
1.導入的jar包一定要正確
2.連接數據庫一定要開啟新線程
3.數據庫的IP一定要是可以ping通的,局域網地址手機是訪問不了的
4.數據庫所在的服務器是否開了防火墻,阻止了訪問