当前位置: 移动技术网 > 移动技术>移动开发>Android > android开发中如何使用jdbc连接数据库

android开发中如何使用jdbc连接数据库

2018年10月27日  | 移动技术网移动技术  | 我要评论

第一次在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();
                        }

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网