Android用jdbc直接连接MySQL,连接失败,求大神们救救

这是加载驱动和连接MySQL那部分代码代码():
try {
Class.forName("com.mysql.jdbc.Driver");
Log.d("加载驱动", "完成");
Connection conn=(Connection) DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/park", "root", "957558");
Log.d("数据库连接", "完成");
}
这个是logcat打印的日记:
图片说明
求大神们解救一下

3个回答

android是客户端系统,不应该直接连mysql,应该使用本地的sqlite数据库,或者通过web service访问服务器上的数据。

u010261462
Vincent徐 回复flydragon111: jdbc连接mysql
大约一年之前 回复
flydragon111
flydragon111 真的就不能用jdbc直接连接MySQL???可网上还是有不少文章关于直接连接MySQL的
3 年多之前 回复

android不应该直接连接数据库,而且地址也不对,127.0.0.1是指的本机,模拟器上的话也应该用10.0.2.2访问电脑

连接数据库是服务端和数据库之间要做的事情,你一个客户端连数据库不是抢饭碗吗、、?你手机上也不可能有mysql的。那些教程应该都是针对安卓服务端的。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
【求解】android利用JDBC直接调用MYSQL问题
最近正在忙活着毕业设计,关于android上的图书管理系统。系统大概是编写一个android的手机客户端,然后利用JDBC直接连接同一局域网的mysql数据库服务器来访问数据。 现在客户端做好了,后台数据库也运行了并且在eclipse上面测试过,利用一个JAVA测试通过JDBC访问mysql成功,但在客户端运行的时候就是死活无法连接。。。附上客户端的连接代码: public class DBUtil { public static Connection getConnection() { Connection con=null; try { Class.forName("com.mysql.jdbc.Driver"); con=DriverManager.getConnection("jdbc:mysql://172.71.103.44:3306/test?useUnicode=true&characterEncoding=UTF-8","root","1234"); } catch(Exception e) { e.printStackTrace(); } return con; } androidmysql连接JDBC
android利用JDBC连接服务器mysql失败
加载的mysql驱动是mysql-connector-java-5.1.30-bin.jar 服务器是腾讯云服务器 代码: ``` try { Class.forName("com.mysql.jdbc.Driver").newInstance(); con = (Connection) DriverManager.getConnection( "jdbc:mysql://118.89.232.64:3306/info_file","name","password"); Log.i("mysqltest","Success connect Mysql server!"); }catch( SQLException ee) { Log.i("mysqltest","Error loading Mysql Driver!ee"); ee.printStackTrace(); } catch (Exception e) { Log.i("mysqltest","Error loading Mysql Driver!e"); e.printStackTrace(); } ``` 程序能打开,但是不能与数据库建立连接,log信息: 05-30 20:04:35.614 8362-8362/? W/System.err: com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure 05-30 20:04:35.614 8362-8362/? W/System.err: The last packet sent successfully to the server was 0 milliseconds ago. The driver has not received any packets from the server. 而且就算乱改url或者断网出现的都是同样的信息,求帮助
Android开发用jdbc 连接MySQL失败
failed to connect to /127.0.0.1 (port 3306): conne网上都查不到解决办法,有点急,在线等大神们帮帮忙 这是logcat打印的日记: ![图片说明](https://img-ask.csdn.net/upload/201608/02/1470123940_715927.png) 尝试很多办法都是连接失败
在Android Studio使用jdbc连接MySQL遇到java.lang.ExceptionInInitializerError
使用jdbc的方法在安卓项目中连接MySQL数据库,在getConnection()时出现java.lang.ExceptionInInitializerError,实在不懂错在哪了... ![图片说明](https://img-ask.csdn.net/upload/201910/21/1571662749_861983.png)
jdbc连接MySQL连接失败问题
连接失败 com.mysql.jdbc.CommunicationsException: Communications link failure due to underlying exception ![图片说明](https://img-ask.csdn.net/upload/201607/30/1469885794_292133.png) 上面的图片是logcat打印的日志; 下面是我加载驱动的代码: Class.forName("com.mysql.jdbc.Driver"); conn=DriverManager.getConnection("jdbc:mysql://localhost:3306/park", "root", "root"); //PreparedStatement pst=conn.prepareStatement(sql); //pst.setString(1, myCity); //ResultSet rs=pst.executeQuery(); Log.d("加载驱动", "完成"); Statement st=conn.createStatement(); Log.d("查询语句", "开始"); ResultSet rs=st.executeQuery(sql); 大神们,这是在哪错了啊......
android通过jdbc连接数据库问题
需要通过jdbc连接访问数据库,目前我是通过需要访问数据库的时候建立于数据库的连接,得到需要的结果后就断开与数据库的连接。但是由于工作需要,现在需要android应用程序在登陆界面输入账号密码后就持续连接数据库,只有当app退出后才会断开与数据库的连接,请问是否可行,该如何操作,望大神指点一二,感激不尽!
Eclipse用JDBC连接不上MySql,求解决办法
**使用JDBC的方法连接不上MySQL,我的网络是校园网,登陆后IP会变化,不知道这个对连接有没有什么影响,用的是mysql 5.6 以前用JDBC连接上过的,但是现在就不行了,不清楚原因,也在网上找过,但是找不到解决的办法,连接的JAR包是mysql-connector-java-5.1.26-bin.jar,请知道的大神解答一下小弟,还有就是使用Oracle用JDBC是连接得上的,使用的地址也是localhost,但是在用JDBC连接数据库查看的时候,在使用preparedStatement返回的genernatekeys无法使用getInt这个方法,所以想用mysql,因为视频教程中也是用MySQL的,并且是能用getInt这是方法的,所以想用mysql,麻烦各位大哥帮帮忙** 出现的错误如下: import java.sql.*; public class TestMysqlConnection { public static void main (String[] args) { Connection conn = null; try { Class.forName("com.mysql.jdbc.Driver"); conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/bbs","root","123456"); } catch (ClassNotFoundException e) { e.printStackTrace(); } catch (SQLException e) { e.printStackTrace(); } finally { try { if(conn != null) { conn.close(); conn = null; } } catch (SQLException e) { e.printStackTrace(); } } } 错误如下: com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: Communication link failure, message from server: "Can't get hostname for your address" at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source) at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source) at java.lang.reflect.Constructor.newInstance(Unknown Source) at com.mysql.jdbc.Util.handleNewInstance(Util.java:411) at com.mysql.jdbc.Util.getInstance(Util.java:386) at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1015) at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:989) at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:975) at com.mysql.jdbc.MysqlIO.doHandshake(MysqlIO.java:1112) at com.mysql.jdbc.ConnectionImpl.coreConnect(ConnectionImpl.java:2486) at com.mysql.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:2519) at com.mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2304) at com.mysql.jdbc.ConnectionImpl.(ConnectionImpl.java:834) at com.mysql.jdbc.JDBC4Connection.(JDBC4Connection.java:47) at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source) at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source) at java.lang.reflect.Constructor.newInstance(Unknown Source) at com.mysql.jdbc.Util.handleNewInstance(Util.java:411) at com.mysql.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:416) at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:346) at java.sql.DriverManager.getConnection(Unknown Source) at java.sql.DriverManager.getConnection(Unknown Source) at TestMysqlConnection.main(TestMysqlConnection.java:8)
jdbc 跟mysql 的连接是 基于tcp协议吗
jdbc 跟mysql 的连接是 基于tcp协议吗,求大神讲解
安卓新手用JDBC连接mysql时一直报错
抛出异常在logcat提示:驱动连接成功,数据库连接失败Could not find class 'javax.naming.StringRefAddr', referenced from method com.mysql.jdbc.ConnectionPropertiesImpl$ConnectionProperty.storeTo。求大神帮忙,错误围绕好长时间了 连接代码 ``` //连接数据库 public static Connection getCon() { Connection conn = null; try { Class.forName("org.gjt.mm.mysql.Driver"); System.out.println("驱动连接成功"); } catch (ClassNotFoundException e1) { // TODO Auto-generated catch block System.out.println("驱动连接失败"); } String dbUrl = "jdbc:mysql://localhost:3306/student"; String username = "root"; String psw = "1234"; try { conn = DriverManager.getConnection(dbUrl,username,psw); } catch (SQLException e) { // TODO Auto-generated catch block System.out.println("数据库连接失败"+e); } return conn; } ```
在Android Studio中,用jdbc连接MySQL连不上
网上的很多方法都试过,还是不行,各位大神帮我看下什么原因。 目前排除的原因: 1.在单元测试中可以连接成功,并获得数据。所以数据库、连接格式应该没问题。 2.connect-java包试了好几个版本都不行。 3.在Activity中连接不上,但我已经放在新的线程中了,而且用好几种开启新线程的方式试过。 以下是代码 ``` public class MainActivity extends AppCompatActivity { private Connection conn; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); new Thread(){ @Override public void run() { try { Class.forName("com.mysql.jdbc.Driver"); conn = DriverManager.getConnection("jdbc:mysql://rm-bp1p408m8ey1z7ndv4o.mysql.rds.aliyuncs.com/mysql_data", "myroot", "Kwkx12345678"); System.err.println(conn); } catch (ClassNotFoundException e) { e.printStackTrace(); } catch (SQLException e) { e.printStackTrace(); } } }.start(); } } ``` Locat输出: ![图片说明](https://img-ask.csdn.net/upload/201811/28/1543372019_611452.png) 错误提示,百度上搜了一下也没有 Caused by: java.lang.ClassNotFoundException: Didn't find class "java.sql.SQLType" on path: DexPathList[[zip file "/data/app/com.example.administrator.
jdbc连接MySQL报错, 有没有大神帮忙解决一下
![代码](https://img-ask.csdn.net/upload/201812/08/1544267773_298311.png) 报错如下: ![图片说明](https://img-ask.csdn.net/upload/201812/08/1544269249_3555.png) 这是日志: ![rizhi](https://img-ask.csdn.net/upload/201812/08/1544267922_658274.png) 小白用JDBC连接MySQL数据库, 向数据表里面插入数据, 报错, 大神可不可以帮忙看看
jdbc无法连接MySQL数据库
报错信息:No suitable driver found for jdbc:mysql://localhost:3306/utf-8?useUnicode=true&characterEncoding=utf-8 我写的url:url="jdbc:mysql://localhost:3306/utf-8?useUnicode=true&characterEncoding=utf-8"; 直接用main方法调用连接可以正常查询,但是从action中调用就会报错 这是采用main方法调用 ``` public static void main(String[] args) { UserBiz ubiz=new UserBizImpl(); String username="张三"; String password="123"; Users user=ubiz.getUser(username, password); System.out.println(user); } ``` 这是在action中调用 ``` protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String username=request.getParameter("username"); System.out.println(username); String password=request.getParameter("password"); System.out.println(password); UserBiz ubiz=new UserBizImpl(); Users user=ubiz.getUser(username, password); ```
Eclipse用JDBC连接不上MYSQL
使用JDBC的方法连接不上MySQL,我的网络是校园网,登陆后IP会变化,不知道这个对连接有没有什么影响,用的是mysql 5.6 以前用JDBC连接上过的,但是现在就不行了,不清楚原因,也在网上找过,但是找不到解决的办法,连接的JAR包是mysql-connector-java-5.1.26-bin.jar,提示错误Communication link failure, message from server: "Can't get hostname for your address" at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source) at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source) at java.lang.reflect.Constructor.newInstance(Unknown Source) at com.mysql.jdbc.Util.handleNewInstance(Util.java:408) at com.mysql.jdbc.Util.getInstance(Util.java:383) at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1023) at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:997) at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:983) at com.mysql.jdbc.MysqlIO.doHandshake(MysqlIO.java:1111) at com.mysql.jdbc.ConnectionImpl.coreConnect(ConnectionImpl.java:2494) at com.mysql.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:2527) at com.mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2309) at com.mysql.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:834) at com.mysql.jdbc.JDBC4Connection.<init>(JDBC4Connection.java:46) at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source) at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source) at java.lang.reflect.Constructor.newInstance(Unknown Source) at com.mysql.jdbc.Util.handleNewInstance(Util.java:408) at com.mysql.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:419) at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:344) at java.sql.DriverManager.getConnection(Unknown Source) at java.sql.DriverManager.getConnection(Unknown Source)请知道的大神解答一下小弟
通过eclipse用jdbc连接MySQL时出现问题
求大神帮我解答,运行后出现错误是怎么回事? ![图片说明](https://img-ask.csdn.net/upload/201912/18/1576638062_771148.jpg) ![图片说明](https://img-ask.csdn.net/upload/201912/18/1576637772_468360.jpg) ``` package com.main.JH; import java.sql.*; public class PutinStorage { // JDBC 驱动名及数据库 URL static final String JDBC_DRIVER = "com.mysql.jdbc.Driver"; static final String DB_URL = "jdbc:mysql://localhost:3306/mysql"; // 数据库的用户名与密码,需要根据自己的设置 static final String USER = "root"; static final String PASS = "123456"; public static void main(String[] args) { Connection conn = null; Statement stmt = null; try{ // 注册 JDBC 驱动 Class.forName("com.mysql.jdbc.Driver"); // 打开链接 System.out.println("连接数据库..."); conn = DriverManager.getConnection(DB_URL,USER,PASS); // 执行查询 System.out.println(" 实例化Statement对象..."); stmt = conn.createStatement(); String sql; sql = "SELECT name,code,score FROM test"; ResultSet rs = stmt.executeQuery(sql); // 展开结果集数据库 while(rs.next()){ // 通过字段检索 String name = rs.getString("name"); String code = rs.getString("code"); int score = rs.getInt("score"); // 输出数据 System.out.print("用户名: " + name); System.out.print(", 密码: " + code); System.out.print(", 分数: " + score); System.out.print("\n"); } // 完成后关闭 rs.close(); stmt.close(); conn.close(); }catch(SQLException se){ // 处理 JDBC 错误 se.printStackTrace(); }catch(Exception e){ // 处理 Class.forName 错误 e.printStackTrace(); }finally{ // 关闭资源 try{ if(stmt!=null) stmt.close(); }catch(SQLException se2){ }// 什么都不做 try{ if(conn!=null) conn.close(); }catch(SQLException se){ se.printStackTrace(); } } System.out.println("Goodbye!"); } } ```
Android studio JDBC
Android studio JDBC 数据库连接开发。。。。。。Android studio JDBC
jdbc连接mysql数据库查询语句
用jdbc连接mysql数据库,使用的查询语句是SELECT MAX(call_start_time) FROM a,如何 在后台显示这个最大时间
Android直接连接mysql,并将数据用listview显示出来,代码一直有问题,求大神解决
这是代码 package com.example.wcms; import android.os.Bundle; import android.app.Activity; import android.view.Menu; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.GridView; import android.widget.ListView; import android.widget.SimpleAdapter; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; //import com.example.girdviewtext.R; public class MainActivity extends Activity { private Connection con; private Statement stat; private ResultSet rs; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Button btn=(Button)findViewById(R.id.button1); btn.setOnClickListener(new OnClickListener(){ @Override public void onClick(View arg0) { sqlCon(); sqlList(); } private void sqlList() { // TODO 自动生成的方法存根 ListView lv=(ListView)findViewById(R.id.lsit); List<Map<String,Object>> listItems= new ArrayList<Map<String,Object>>(); try { while(rs.next()) { //System.out.println(rs.getString(1) + "\t" + rs.getString(2) + "\t" + rs.getString(3)); Map<String,Object> listItem=new HashMap<String,Object>(); listItem.put("mac",rs.getString(1)); listItem.put("pcname", rs.getString(2)); listItem.put("username", rs.getString(3)); listItems.add(listItem); } rs.close(); stat.close(); con.close(); } catch (SQLException e) { // TODO 自动生成的 catch 块 e.printStackTrace(); } SimpleAdapter simpleAdapter=new SimpleAdapter(MainActivity.this,listItems, R.layout.list_item, new String[] {"mac","pcname","username"}, new int[]{R.id.mac,R.id.pcname,R.id.username}); lv.setAdapter(simpleAdapter); } private void sqlCon() { // TODO 自动生成的方法存根 try{ //加载驱动程序 Class.forName("com.mysql.jdbc.Driver").newInstance(); }catch (Exception ex){ //无法加载驱动,则给出错误信息 System.out.println("无法加载驱动程序" + ex.getMessage()); return; } String url="jdbc:mysql://120.24.59.103:3306/xhw"; String user="root"; String password="huwei1221"; //建立数据库连接,获得连接对象con try { con = DriverManager.getConnection(url, user, password); //建立Statement对象,即是像数据库发送SQL语句的对象 stat=con.createStatement(); //建立 结果集,暂时存放执行SQL语句后产生的结果集合 rs=stat.executeQuery("select * from PCInfo"); } catch (SQLException e1) { // TODO 自动生成的 catch 块 e1.printStackTrace(); } } }); } } 这是activity.xml <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:paddingBottom="@dimen/activity_vertical_margin" android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingTop="@dimen/activity_vertical_margin" tools:context=".MainActivity" > <Button android:id="@+id/button1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_below="@+id/textView1" android:layout_centerHorizontal="true" android:text="连接数据库" /> <LinearLayout android:id="@+id/ll" android:layout_width="match_parent" android:layout_height="20dp" android:orientation="horizontal" android:layout_below="@+id/button1"> <TextView android:id="@+id/MAC" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_weight="1" android:text="Mac" /> <TextView android:id="@+id/PCname" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_weight="1" android:text="PCname" /> <TextView android:id="@+id/UserName" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_weight="1" android:text="Username"/> </LinearLayout> <ListView android:id="@+id/lsit" android:layout_below="@+id/ll" android:layout_width="fill_parent" android:layout_height="wrap_content" /> </RelativeLayout> 这是list_item.xml <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:paddingBottom="@dimen/activity_vertical_margin" android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingTop="@dimen/activity_vertical_margin" tools:context=".MainActivity" > <Button android:id="@+id/button1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_below="@+id/textView1" android:layout_centerHorizontal="true" android:text="连接数据库" /> <LinearLayout android:id="@+id/ll" android:layout_width="match_parent" android:layout_height="20dp" android:orientation="horizontal" android:layout_below="@+id/button1"> <TextView android:id="@+id/MAC" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_weight="1" android:text="Mac" /> <TextView android:id="@+id/PCname" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_weight="1" android:text="PCname" /> <TextView android:id="@+id/UserName" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_weight="1" android:text="Username"/> </LinearLayout> <ListView android:id="@+id/lsit" android:layout_below="@+id/ll" android:layout_width="fill_parent" android:layout_height="wrap_content" /> </RelativeLayout> 1. 求解答
jdbc 连接mysql 首次成功,之后连接就报错
在系统中使用jdbc 连接mysql, 首次成功,之后连接就报错,驱动用的是mysql-connector-java-5.1.15-bin.jar 连接代码 ``` Connection conn = null; Statement stat = null; ResultSet rs = null; String url = "jdbc:mysql://*********:3306/*******?useUnicode=true&characterEncoding=GBK"; String sql = null; String tableName = "***"; List<ClockBO> clock = new ArrayList<ClockBO>(); sql = "select * from " + tableName + " where timevalue between '" + startTime + "' and '" + endTime + "' and doorName='" + doorName.substring(2) + "'"; System.out.println(sql); Class.forName("com.mysql.jdbc.Driver"); conn = DriverManager.getConnection(url, "root", "****"); stat = conn.createStatement(); rs = stat.executeQuery(sql); while (rs.next()) { ClockBO bo = new ClockBO(); ClockPKBO pkbo = new ClockPKBO(); pkbo.setCardNo1(rs.getString(1)); pkbo.setCardNo2(rs.getString(2)); pkbo.setTimeValue(ft.format(rs.getTimestamp(6))); bo.setPersonNo(rs.getString(3)); bo.setPersonName(rs.getString(4)); bo.setDepartment(rs.getString(5)); bo.setCtlIp(rs.getString(7)); bo.setDoorNo(rs.getString(8)); bo.setDoorName(rs.getString(9)); bo.setStateId(rs.getString(10)); bo.setRptState(rs.getString(11)); bo.setStateStr(rs.getString(12)); bo.setClockPK(pkbo); clock.add(bo); System.out.println(rs.getString(4)); System.out.println(bo.toString()); } } catch (Exception e) { e.printStackTrace(); }finally{ try{ if(null!=rs){ rs.close(); } if(null!=stat){ stat.close(); } if(null!=conn){ conn.commit(); conn.close(); } }catch(SQLException e){ e.printStackTrace(); } } ``` 首次连接可以查出数据,再次调用就在连接的时候就抛出异常了,异常信息如下 java.sql.SQLException: ResultSet is from UPDATE. No Data. at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1078) at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:989) at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:975) at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:920) at com.mysql.jdbc.ResultSetImpl.next(ResultSetImpl.java:6999) at com.mysql.jdbc.ConnectionImpl.loadServerVariables(ConnectionImpl.java:4184) at com.mysql.jdbc.ConnectionImpl.initializePropsFromServer(ConnectionImpl.java:3585) at com.mysql.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:2534) at com.mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2304) at com.mysql.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:834) at com.mysql.jdbc.JDBC4Connection.<init>(JDBC4Connection.java:47) at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source) at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source) at java.lang.reflect.Constructor.newInstance(Unknown Source) at com.mysql.jdbc.Util.handleNewInstance(Util.java:411) at com.mysql.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:416) at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:346) 为什么会出现这种情况呢?
Android 通过jdbc 直连MySql 连不上
本人新手,找了好多资源,测试直连的问题,这些代码也是本网站找的,自己稍微改了一下,为何死活连不上去,conn返回都是空的,大神帮我看看。 public class MainActivity extends Activity { private static final String URL = "jdbc:mysql://www.luhef.cn:3306/xh"; private static final String USER = "*******"; private static final String PASSWORD = "*****"; private Connection conn; private Button onConn; private Button onInsert; private Button onDelete; private Button onUpdate; private Button onQuery; private Handler handler = new Handler() { public void handleMessage(Message msg) { String str = (String) msg.obj; Toast.makeText(MainActivity.this, str, Toast.LENGTH_SHORT).show(); }; }; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); onConn = (Button) findViewById(R.id.onConn); onInsert = (Button) findViewById(R.id.onInsert); } @Override protected void onDestroy() { super.onDestroy(); if (conn != null) { try { conn.close(); } catch (SQLException e) { conn = null; } finally { conn = null; } } } public void onConn(View view) { new Thread(new Runnable() { @Override public void run() { conn = Util.openConnection(URL, USER, PASSWORD); Message msg = new Message(); msg.obj = conn; handler.sendMessage(msg); } }).start(); } public void onInsert(View view) { new Thread(new Runnable() { @Override public void run() { String sql = "insert into users values(15, 'xiaoming')"; Util.execSQL(conn, sql); Log.i("onInsert", "onInsert"); } }).start(); } } package com.lyz.learning.mysqlandandroid; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; public class Util { final static String DRIVER_NAME = "com.mysql.jdbc.Driver"; public static Connection openConnection(String url, String user, String password) { Connection conn = null; try { Class.forName(DRIVER_NAME); conn = DriverManager.getConnection(url, user, password); } catch (ClassNotFoundException e) { conn = null; } catch (SQLException e) { conn = null; } System.out.println(conn); return conn; } public static void query(Connection conn, String sql) { if (conn == null) { return; } Statement statement = null; ResultSet result = null; try { statement = conn.createStatement(); result = statement.executeQuery(sql); System.out.println(result); if (result != null && result.first()) { int idColumnIndex = result.findColumn("id"); int nameColumnIndex = result.findColumn("name"); System.out.println("id\t\t" + "name"); while (!result.isAfterLast()) { System.out.print(result.getString(idColumnIndex) + "\t\t"); System.out.println(result.getString(nameColumnIndex)); result.next(); } } } catch (SQLException e) { e.printStackTrace(); } finally { try { if (result != null) { result.close(); result = null; } if (statement != null) { statement.close(); statement = null; }} catch (SQLException sqle) { sqle.printStackTrace(); } } } public static boolean execSQL(Connection conn, String sql) { boolean execResult = false; if (conn == null) { return execResult; } Statement statement = null; try { statement = conn.createStatement(); if (statement != null) { execResult = statement.execute(sql); } } catch (SQLException e) { execResult = false; } return execResult; } }
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、PDF搜索网站推荐 对于大部
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 顺便拉下票,我在参加csdn博客之星竞选,欢迎投票支持,每个QQ或者微信每天都可以投5票,扫二维码即可,http://m234140.nofollow.ax.
Vue + Spring Boot 项目实战(十四):用户认证方案与完善的访问拦截
本篇文章主要讲解 token、session 等用户认证方案的区别并分析常见误区,以及如何通过前后端的配合实现完善的访问拦截,为下一步权限控制的实现打下基础。
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入  假设现有4个人
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 欢迎 改进 留言。 演示地点跳到演示地点 html代码如下`&lt;!DOCTYPE html&gt; &lt;html&gt; &lt;head&gt; &lt;title&gt;music&lt;/title&gt; &lt;meta charset="utf-8"&gt
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。 1. for - else 什么?不是 if 和 else 才
数据库优化 - SQL优化
前面一篇文章从实例的角度进行数据库优化,通过配置一些参数让数据库性能达到最优。但是一些“不好”的SQL也会导致数据库查询变慢,影响业务流程。本文从SQL角度进行数据库优化,提升SQL运行效率。 判断问题SQL 判断SQL是否有问题时可以通过两个表象进行判断: 系统级别表象 CPU消耗严重 IO等待严重 页面响应时间过长
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 c/c++ 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7
通俗易懂地给女朋友讲:线程池的内部原理
餐厅的约会 餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”我楞了一下,心里想女朋友今天是怎么了,怎么突然问出这么专业的问题,但做为一个专业人士在女朋友面前也不能露怯啊,想了一下便说:“我先给你讲讲我前同事老王的故事吧!” 大龄程序员老王 老王是一个已经北漂十多年的程序员,岁数大了,加班加不动了,升迁也无望,于是拿着手里
经典算法(5)杨辉三角
写在前面: 我是 扬帆向海,这个昵称来源于我的名字以及女朋友的名字。我热爱技术、热爱开源、热爱编程。技术是开源的、知识是共享的。 这博客是对自己学习的一点点总结及记录,如果您对 Java、算法 感兴趣,可以关注我的动态,我们一起学习。 用知识改变命运,让我们的家人过上更好的生活。 目录一、杨辉三角的介绍二、杨辉三角的算法思想三、代码实现1.第一种写法2.第二种写法 一、杨辉三角的介绍 百度
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹
面试官:你连RESTful都不知道我怎么敢要你?
面试官:了解RESTful吗? 我:听说过。 面试官:那什么是RESTful? 我:就是用起来很规范,挺好的 面试官:是RESTful挺好的,还是自我感觉挺好的 我:都挺好的。 面试官:… 把门关上。 我:… 要干嘛?先关上再说。 面试官:我说出去把门关上。 我:what ?,夺门而去 文章目录01 前言02 RESTful的来源03 RESTful6大原则1. C-S架构2. 无状态3.统一的接
SQL-小白最佳入门sql查询一
一 说明 如果是初学者,建议去网上寻找安装Mysql的文章安装,以及使用navicat连接数据库,以后的示例基本是使用mysql数据库管理系统; 二 准备前提 需要建立一张学生表,列分别是id,名称,年龄,学生信息;本示例中文章篇幅原因SQL注释略; 建表语句: CREATE TABLE `student` ( `id` int(11) NOT NULL AUTO_INCREMENT, `
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // dosho
漫话:什么是平衡(AVL)树?这应该是把AVL树讲的最好的文章了
这篇文章通过对话的形式,由浅入深带你读懂 AVL 树,看完让你保证理解 AVL 树的各种操作,如果觉得不错,别吝啬你的赞哦。 1、若它的左子树不为空,则左子树上所有的节点值都小于它的根节点值。 2、若它的右子树不为空,则右子树上所有的节点值均大于它的根节点值。 3、它的左右子树也分别可以充当为二叉查找树。 例如: 例如,我现在想要查找数值为14的节点。由于二叉查找树的特性,我们可...
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,
程序员:我终于知道post和get的区别
IT界知名的程序员曾说:对于那些月薪三万以下,自称IT工程师的码农们,其实我们从来没有把他们归为我们IT工程师的队伍。他们虽然总是以IT工程师自居,但只是他们一厢情愿罢了。 此话一出,不知激起了多少(码农)程序员的愤怒,却又无可奈何,于是码农问程序员。 码农:你知道get和post请求到底有什么区别? 程序员:你看这篇就知道了。 码农:你月薪三万了? 程序员:嗯。 码农:你是怎么做到的? 程序员:
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU
开源并不是你认为的那些事
点击上方蓝字 关注我们开源之道导读所以 ————想要理清开源是什么?先要厘清开源不是什么,名正言顺是句中国的古代成语,概念本身的理解非常之重要。大部分生物多样性的起源,...
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
      11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1
程序员把地府后台管理系统做出来了,还有3.0版本!12月7号最新消息:已在开发中有github地址
第一幕:缘起 听说阎王爷要做个生死簿后台管理系统,我们派去了一个程序员…… 996程序员做的梦: 第一场:团队招募 为了应对地府管理危机,阎王打算找“人”开发一套地府后台管理系统,于是就在地府总经办群中发了项目需求。 话说还是中国电信的信号好,地府都是满格,哈哈!!! 经常会有外行朋友问:看某网站做的不错,功能也简单,你帮忙做一下? 而这次,面对这样的需求,这个程序员
网易云6亿用户音乐推荐算法
网易云音乐是音乐爱好者的集聚地,云音乐推荐系统致力于通过 AI 算法的落地,实现用户千人千面的个性化推荐,为用户带来不一样的听歌体验。 本次分享重点介绍 AI 算法在音乐推荐中的应用实践,以及在算法落地过程中遇到的挑战和解决方案。 将从如下两个部分展开: AI 算法在音乐推荐中的应用 音乐场景下的 AI 思考 从 2013 年 4 月正式上线至今,网易云音乐平台持续提供着:乐屏社区、UGC
【技巧总结】位运算装逼指南
位算法的效率有多快我就不说,不信你可以去用 10 亿个数据模拟一下,今天给大家讲一讲位运算的一些经典例子。不过,最重要的不是看懂了这些例子就好,而是要在以后多去运用位运算这些技巧,当然,采用位运算,也是可以装逼的,不信,你往下看。我会从最简单的讲起,一道比一道难度递增,不过居然是讲技巧,那么也不会太难,相信你分分钟看懂。 判断奇偶数 判断一个数是基于还是偶数,相信很多人都做过,一般的做法的代码如下
《C++ Primer》学习笔记(六):C++模块设计——函数
专栏C++学习笔记 《C++ Primer》学习笔记/习题答案 总目录 https://blog.csdn.net/TeFuirnever/article/details/100700212 —————————————————————————————————————————————————————— 《C++ Primer》习题参考答案:第6章 - C++模块设计——函数 文章目录专栏C+...
8年经验面试官详解 Java 面试秘诀
    作者 | 胡书敏 责编 | 刘静 出品 | CSDN(ID:CSDNnews) 本人目前在一家知名外企担任架构师,而且最近八年来,在多家外企和互联网公司担任Java技术面试官,前后累计面试了有两三百位候选人。在本文里,就将结合本人的面试经验,针对Java初学者、Java初级开发和Java开发,给出若干准备简历和准备面试的建议。   Java程序员准备和投递简历的实
面试官如何考察你的思维方式?
1.两种思维方式在求职面试中,经常会考察这种问题:北京有多少量特斯拉汽车? 某胡同口的煎饼摊一年能卖出多少个煎饼? 深圳有多少个产品经理? 一辆公交车里能装下多少个乒乓球? 一
so easy! 10行代码写个"狗屁不通"文章生成器
前几天,GitHub 有个开源项目特别火,只要输入标题就可以生成一篇长长的文章。背后实现代码一定很复杂吧,里面一定有很多高深莫测的机器学习等复杂算法不过,当我看了源代码之后这程序不到50
知乎高赞:中国有什么拿得出手的开源软件产品?(整理自本人原创回答)
知乎高赞:中国有什么拿得出手的开源软件产品? 在知乎上,有个问题问“中国有什么拿得出手的开源软件产品(在 GitHub 等社区受欢迎度较好的)?” 事实上,还不少呢~ 本人于2019.7.6进行了较为全面的 回答 - Bravo Yeung,获得该问题下回答中得最高赞(236赞和1枚专业勋章),对这些受欢迎的 Github 开源项目分类整理如下: 分布式计算、云平台相关工具类 1.SkyWalk
相关热词 c# 输入ip c# 乱码 报表 c#选择结构应用基本算法 c# 收到udp包后回包 c#oracle 头文件 c# 序列化对象 自定义 c# tcp 心跳 c# ice连接服务端 c# md5 解密 c# 文字导航控件
立即提问