android开发中如何使用jdbc连接数据库
程序员文章站
2022-10-30 19:52:11
第一次在android上使用jdbc连接,记录下。最开始写的demo连接的本地电脑的my,只能模拟器访问,有大神知道怎么设置请回复赐教,后来改成外网地址又出现查询不到的情况,后来才发现是字符编码不统...
第一次在android上使用jdbc连接,记录下。最开始写的demo连接的本地电脑的my,只能模拟器访问,有大神知道怎么设置请回复赐教,后来改成外网地址又出现查询不到的情况,后来才发现是字符编码不统一的问题。
jar包:可搜索mysql-connector-java下载最新的,也可从我项目里copy
权限:
注意:查询操作要在子线程中
runnable = new runnable() { private connection con = null; @override public void run() { try { class.forname("com.mysql.jdbc.driver"); //122.112.226.122为ip地址 //3306为端口号,sun_graduation为数据库名称,第二个test为数据库登录账户,密码test1234 con = drivermanager.getconnection("jdbc:mysql://122.112.226.122:3306/sun_graduation?useunicode=true&characterencoding=gbk", "test", "test1234"); } catch (sqlexception e) { e.printstacktrace(); } catch (classnotfoundexception e) { e.printstacktrace(); } try { //搜索 startsearch(con); } catch (final sqlexception e) { e.printstacktrace(); } } public void startsearch(connection con) throws sqlexception { try { //查询表名为“xhzd_surnfu”的列zi值为mresult的列为pinyin的值 string sql = "select * from xhzd_surnfu where zi = '" + edtkey.gettext().tostring() + "'"; // string sql = "select pinyin from xhzd_surnfu where id = 1"; statement stmt = con.createstatement();//创建statement resultset rs = stmt.executequery(sql);//resultset类似cursor stringbuilder sbresult = new stringbuilder(); //resultset最初指向第一行 while (rs.next()) { //rs.getstring("列名")=对应列名的字段值 if (!textutils.isempty(rs.getstring("pinyin"))) { sbresult.append("拼音:").append(rs.getstring("pinyin")).append("\n"); } if (!textutils.isempty(rs.getstring("bushou"))) { sbresult.append("部首:").append(rs.getstring("bushou")).append("\n"); } if (!textutils.isempty(rs.getstring("bihua"))) { sbresult.append("笔画:").append(rs.getstring("bihua")).append("\n"); } if (!textutils.isempty(rs.getstring("xiangjie"))) { sbresult.append("详解:").append(rs.getstring("xiangjie")).append("\n"); } } if (sbresult.length() == 0) { sbresult.append("搜索结果为空"); } bundle bundle = new bundle(); bundle.putstring("result", sbresult.tostring()); message msg = new message(); msg.setdata(bundle); myhandler.sendmessage(msg); rs.close(); stmt.close(); } catch (sqlexception e) { e.printstacktrace(); } finally { if (con != null) try { con.close(); } catch (sqlexception e) { e.printstacktrace(); } } } };
获取数据库连接时遇到查询中文字符就查不到的情况,后来发现是字符编码不统一引起的。ide的默认字符编码时utl-8而数据库的是gbk,就一直搜索不到结果。加上useunicode=true&characterencoding=utf-8 即可
注意:查询完之后关闭资源
if (con != null) try { con.close(); } catch (sqlexception e) { e.printstacktrace(); }
上一篇: 实际开发中的OracleSQL优化建议