jsp页面向mysql数据库更新数据是sql语句没错 出现异常更失败

插入信息的时候没问题 但是修改的时候异常报的是什么意思图片说明

1个回答

sql 错了,update user set xing='xxx',ming='xxx' where id=xxx;

qq_23126581
渊渟无迹静涛君 回复qq_37244098: 细心点就行
大约 2 年之前 回复
qq_37244098
qq_37244098 我去,就是落下了逗号呗 行了,,谢谢了 真会服了我自己
大约 2 年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
如何从jsp页面向mysql按条件更新数据
代码如下 ``` <% String ID = new String(request.getParameter("dId").getBytes("ISO8859_1"),"UTF-8"); String AIS = new String(request.getParameter("AIS").getBytes("ISO8859_1"),"UTF-8"); try{ Class.forName("com.mysql.jdbc.Driver"); String url = "XXXXXXXXX"; String username = "XXXXXXX"; String password = "XXXXXXX"; Connection conn = DriverManager.getConnection(url,username,password); String isExist = "select * from newshipinfo where newshipinfo.AIS = '"+AIS+"'"; PreparedStatement pstmt = conn.prepareStatement(isExist); ResultSet rs = pstmt.executeQuery(); if(rs.next()){ out.print("该数据已存在,请不要重复添加!"); }else{ String sql = "insert into newshipinfo(AIS) values (?) where ID = '"+ID+"'"; PreparedStatement ps = conn.prepareStatement(sql); ps.setString(1,AIS); int row = ps.executeUpdate(); if(row >0){ out.print("数据添加成功"); } ps.close(); conn.close(); } }catch(Exception e){ out.print("数据添加失败!"); e.printStackTrace(); } %> ``` 这个页面的目的是将前一个页面所提交的数据(ID号与AIS的值)填写到数据库里进行数据更新,数据库里AIS的初始值均为0,现在把页面的值传进去变成1或者2。传之前会判断数据库里AIS的值是不是1或者2,若是则提示不要重复输入。 现在值可以传到这个页面没有问题,就是无法传入数据库,老是报这个错 ``` You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'where ID = '12259'' at line 1 ``` 是sql语句的错误吗,想请教下怎么修改代码。
jsp页面关于数据库多对多查询的sql语句应该怎么写?
我是用的mysql数据库 这是一张用户表 ![图片说明](https://img-ask.csdn.net/upload/201805/25/1527233285_785386.png) 这是项目表 ![图片说明](https://img-ask.csdn.net/upload/201805/25/1527233313_473649.png) 现在我想根据用户表里的“DetectID”对应项目表里的“id”进行关联查询其项目名称,“DetectID”里有几个数据,就查出项目表里的几个名称。这条SQL语句该怎么写,我老是查询到第一条数据就结束了。
急急急,请教JSP如何调用数据库mysql的java文件。
各位好,我实在是菜鸟,在网上找个JAVA文件,连接mysql数据库,经过测试,已经成功,现在用JSP页面来调用,就是不通过,真心请各位指点,急急急,下面把JAVA文件和JSP页面发出来,小弟谢过! JAVA文件 import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Connection; import java.sql.Statement; public class DB { public static void main(String[] args) throws Exception { Connection conn = null; String sql; // MySQL的JDBC URL编写方式:jdbc:mysql://主机名称:连接端口/数据库的名称?参数=值 // 避免中文乱码要指定useUnicode和characterEncoding // 执行数据库操作之前要在数据库管理系统上创建一个数据库,名字自己定, // 下面语句之前就要先创建javademo数据库 String url = "jdbc:mysql://localhost:3306/数据库名字?" + "user=数据库用户名&password=数据库密码&useUnicode=true&characterEncoding=UTF8"; try { // 之所以要使用下面这条语句,是因为要使用MySQL的驱动,所以我们要把它驱动起来, // 可以通过Class.forName把它加载进去,也可以通过初始化来驱动起来,下面三种形式都可以 Class.forName("com.mysql.jdbc.Driver");// 动态加载mysql驱动 // or: // com.mysql.jdbc.Driver driver = new com.mysql.jdbc.Driver(); // or: // new com.mysql.jdbc.Driver(); System.out.println("成功加载MySQL驱动程序"); // 一个Connection代表一个数据库连接 conn = DriverManager.getConnection(url); // Statement里面带有很多方法,比如executeUpdate可以实现插入,更新和删除等 Statement stmt = conn.createStatement(); sql = "create table student(NO char(20),name varchar(20),primary key(NO))"; int result = stmt.executeUpdate(sql);// executeUpdate语句会返回一个受影响的行数,如果返回-1就没有成功 if (result != -1) { System.out.println("创建数据表成功"); sql = "insert into student(NO,name) values('2012001','陶伟基')"; result = stmt.executeUpdate(sql); sql = "insert into student(NO,name) values('2012002','周小俊')"; result = stmt.executeUpdate(sql); sql = "select * from student"; ResultSet rs = stmt.executeQuery(sql);// executeQuery会返回结果的集合,否则返回空值 System.out.println("学号\t姓名"); while (rs.next()) { System.out .println(rs.getString(1) + "\t" + rs.getString(2));// 入如果返回的是int类型可以用getInt() } } } catch (SQLException e) { System.out.println("MySQL操作错误"); e.printStackTrace(); } catch (Exception e) { e.printStackTrace(); } finally { conn.close(); } } } JSP页面 <%@ page contentType="text/html;charset=gb2312" %> <%@ page import="java.sql.*" %> <%@ page import="java.util.*"%> <%@ page import="org.cmcc.databaseconnection.*"%> <% request.setCharacterEncoding("utf-8"); %> <% DB conn=new DB(); Statement stmt = conn.createStatement(); String str1 = "select * from yh"; ResultSet result=stmt.executeQuery(str1); if(result.next()) { %> <%=result.getString(2)%>; <% } else { %> <script language="javascript"> alert("XX"); history.back(); </script> <% } %>
多选题数据库设计,jsp页面编写
![图片说明](https://img-ask.csdn.net/upload/201607/05/1467686717_173473.jpg) 求教我想要在数据库的一个字段里向图片里那样存入多个答案,jsp页面的表单一个怎么写? 或者是mysql 的sql语句该怎么写?
jsp 链接MySQL数据库使用excuteUpdate()方法出错
<%@ page language="java" import="java.sql.*,java.io.*" pageEncoding="UTF-8"%> <% String driverNmae="com.mysql.jdbc.Driver"; String username="root"; String password="123456"; String dbName="book"; String tableNmae="bookinfo"; String url="jdbc:mysql://localhost:3306/"+dbName+"?user="+username+"&password="+password; Class.forName("com.mysql.jdbc.Driver").newInstance(); Connection conn=DriverManager.getConnection(url); Statement stmt=conn.createStatement();//执行 SQL语句并返回它所生成结果的对象 //定义变量接收数据 String bookname=request.getParameter("name"); String publisher=request.getParameter("publisher"); String price=request.getParameter("price"); bookname=new String(bookname.getBytes("iso-8859-1"));//对输入的数据进行编码 publisher=new String(publisher.getBytes("iso-8859-1")); price=new String(price.getBytes("iso-8859-1")); if(bookname.equals("")|publisher.equals("")|price.equals("")){ response.sendRedirect("index.jsp"); }else{ String sql="insert into bookinfo(bookname,publisher,price) values("+bookname+","+publisher+","+price+")"; stmt.executeUpdate(sql);//**就是这句老是报错** out.print("数据添加成功"); } stmt.close(); conn.close(); %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>连接数据库测试</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css"> --> </head> <body> </body> </html> 错误如下: HTTP Status 500 - -------------------------------------------------------------------------------- type Exception report message description The server encountered an internal error () that prevented it from fulfilling this request. exception org.apache.jasper.JasperException: An exception occurred processing JSP page /MyJsp.jsp at line 23 20: response.sendRedirect("index.jsp"); 21: }else{ 22: String sql="insert into bookinfo(bookname,publisher,price) values("+bookname+","+publisher+","+price+")"; 23: stmt.executeUpdate(sql);**** 24: out.print("鏁版嵁娣诲姞鎴愬姛"); 25: } 26: stmt.close(); Stacktrace: org.apache.jasper.servlet.JspServletWrapper.handleJspException(JspServletWrapper.java:524) org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:417) org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:320) org.apache.jasper.servlet.JspServlet.service(JspServlet.java:266) javax.servlet.http.HttpServlet.service(HttpServlet.java:803) root cause javax.servlet.ServletException: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '?,清å�Žå¤§å­¦å‡ºç‰ˆç¤?,12.00)' at line 1 org.apache.jasper.runtime.PageContextImpl.doHandlePageException(PageContextImpl.java:850) org.apache.jasper.runtime.PageContextImpl.handlePageException(PageContextImpl.java:779) org.apache.jsp.MyJsp_jsp._jspService(MyJsp_jsp.java:109) org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70) javax.servlet.http.HttpServlet.service(HttpServlet.java:803) org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:393) org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:320) org.apache.jasper.servlet.JspServlet.service(JspServlet.java:266) javax.servlet.http.HttpServlet.service(HttpServlet.java:803) root cause com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '?,清å�Žå¤§å­¦å‡ºç‰ˆç¤?,12.00)' at line 1 sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39) sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27) java.lang.reflect.Constructor.newInstance(Constructor.java:513) com.mysql.jdbc.Util.handleNewInstance(Util.java:406) com.mysql.jdbc.Util.getInstance(Util.java:381) com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1030) com.mysql.jdbc.SQLError.createSQLException(SQLError.java:956) com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3491) com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3423) com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1936) com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2060) com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2536) com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1564) com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1485) org.apache.jsp.MyJsp_jsp._jspService(MyJsp_jsp.java:78) org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70) javax.servlet.http.HttpServlet.service(HttpServlet.java:803) org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:393) org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:320) org.apache.jasper.servlet.JspServlet.service(JspServlet.java:266) javax.servlet.http.HttpServlet.service(HttpServlet.java:803) note The full stack trace of the root cause is available in the Apache Tomcat/6.0.13 logs. -------------------------------------------------------------------------------- Apache Tomcat/6.0.13
jsp连接mysql时运行sql语句失败
四月 01, 2016 12:51:30 下午 org.apache.catalina.core.StandardWrapperValve invoke 严重: Servlet.service() for servlet [jsp] in context with path [/Test] threw exception [An exception occurred processing JSP page /register.jsp at line 49 46: 47: Connection conn = DriverManager.getConnection(url); 48: Statement stmt = conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE); 49: ResultSet rs = stmt.executeQuery(sql); 50: 51: out.print("房间号"); 52: out.print("|"); Stacktrace:] with root cause com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '???' at line 1 at sun.reflect.GeneratedConstructorAccessor13.newInstance(Unknown Source) at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) at java.lang.reflect.Constructor.newInstance(Constructor.java:422) at com.mysql.jdbc.Util.handleNewInstance(Util.java:404) at com.mysql.jdbc.Util.getInstance(Util.java:387) at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:939) at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3878) at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3814) at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:2478) at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2625) at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2547) at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2505) at com.mysql.jdbc.StatementImpl.executeQuery(StatementImpl.java:1370) at org.apache.jsp.register_jsp._jspService(register_jsp.java:132) at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70) at javax.servlet.http.HttpServlet.service(HttpServlet.java:731) at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:439) at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:395) at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:339) at javax.servlet.http.HttpServlet.service(HttpServlet.java:731) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:220) at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:122) at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:505) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:169) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103) at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:956) at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:436) at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1078) at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:625) at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:316) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) at java.lang.Thread.run(Thread.java:745)
请问个jsp交互数据库插入数据失败问题
如标题,插入数据失败,但是代码没错,运行页面也不报错,网上似乎也有类似问题,但都没有明确的解答。 我不会sevlet和断点测试。通过打印语句显示测试,发现在----红色剪头处-----,一直卡在这条代码处。请大家指教。 之前用Oracle数据库也是这样的问题,然后换成MySQL还是这样。 ![图片说明](https://img-ask.csdn.net/upload/201911/25/1574664478_653711.png)![图片说明](https://img-ask.csdn.net/upload/201911/25/1574664488_254897.png)![图片说明](https://img-ask.csdn.net/upload/201911/25/1574664492_799943.png)![图片说明](https://img-ask.csdn.net/upload/201911/25/1574664500_483284.png)![图片说明](https://img-ask.csdn.net/upload/201911/25/1574664507_465447.png) 找到问题原因了,之前测试数据库连接成功没有写了个查询语句,一直没关闭,导致进程一直存在,把表锁住了,现在有了新问题:这个进程我杀不掉,重启服务器也没用,页面已经关闭了,进程还在。 ![图片说明](https://img-ask.csdn.net/upload/201911/25/1574694940_343815.png)![图片说明](https://img-ask.csdn.net/upload/201911/25/1574694947_39389.png)
JSP操作mysql的SQL语句
...................... try{ Statement st=getStatement(); String name=request.getParameter("name"); String sex=request.getParameter("sex"); String age=request.getParameter("age"); switch(type){ case 0: rs=st.executeQuery("select * from t1"); break; ...................... case 4: name=new String(name.getBytes("ISO-8859-1")); sex=new String(sex.getBytes("ISO-8859-1")); String sql="update t1 set sex='"+sex+"',age='"+age+"' where name='"+name+"'"; st.executeQuery(sql); response.sendRedirect("friend.jsp"); break; ....................... 这一条语句不能实现:String sql="update t1 set sex='"+sex+"',age='"+age+"' where name='"+name+"'"; 即修改功能不能实现!报错为:java.sql.SQLException: Can not issue data manipulation statements with executeQuery().
用javabean向数据库添加数据,请问为什么DoInsert.jsp一直报错
package com.javabean.user; //用于封装用户信息 public class User { private int id; private String username; private String password; private String type; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } public String getType() { return type; } public void setType(String type) { this.type = type; } } ---------------------------------------------------------------------------------------- package com.javabean.user; //用户连接数据库------获得特定数据库的连接对象,使以后可以调查此方法来访问数据库 import java.sql.*; public class Conn { public static final String DBDRIVER="com.mysql.jdbc.Driver"; //包加类名 public static final String DBURL="jdbc:mysql://localhost:3306/test"; public static final String DBUSER="root"; public static final String DBPASS="123456"; public Connection getConn() { Connection conn=null; try { Class.forName(DBDRIVER); conn=DriverManager.getConnection(DBURL,DBUSER,DBPASS); }catch(Exception e) { e.printStackTrace(); } return conn; } } --------------------------------------------------------------------------------------------- package com.javabean.user; //对数据库的增删改查操作 import com.javabean.user.Conn; import java.sql.*; import java.util.ArrayList; import java.util.List; import com.javabean.user.User; public class Userdao { //添加数据 public int InsertUser(User usera) { int rs=0; try { //驱动连接了数据库 Conn conn=new Conn(); Connection dbc=conn.getConn(); //插入语句 String sql_insert="insert into user(username,password,type) values(?,?,?)"; //将SQl语句预编译保存在pst中 PreparedStatement pst=dbc.prepareStatement(sql_insert); //为sql语句中的属性赋值 pst.setString(1,usera.getUsername()); pst.setString(2,usera.getPassword()); pst.setString(3,usera.getType()); //执行sql语句,将结果放在rs中 rs=pst.executeUpdate(); }catch(Exception e) { e.printStackTrace(); } return rs; } public List<User> SelectUser() { ResultSet rs=null; List<User> list=new ArrayList<User>(); try { Conn conn=new Conn(); Connection dbc=conn.getConn(); String sql_select="select * from user"; PreparedStatement pst=dbc.prepareStatement(sql_select); rs=pst.executeQuery(); while(rs.next()) { User user=new User(); user.setId(rs.getInt(1)); user.setUsername(rs.getString(2)); user.setPassword(rs.getString(3)); user.setType(rs.getString(4)); list.add(user); } }catch(Exception e) { e.printStackTrace(); } return list; } } ------------------------------------------------------------------------------------------------- <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ page import="com.javabean.user.Conn"%> <%@ page import="com.javabean.user.Userdao" %> <%@ page import="com.javabean.user.User" %> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>DoInsert</title> </head> <body> <%--对Inser.jsp页面中表单的提交请求进行处理,该页面将获取表单提交的所有信息,然后将信息添加到数据库--%> <%request.setCharacterEncoding("utf-8"); %> <jsp:useBean id="user" class="com.javabean.user.User"> <jsp:setProperty name="user" property="*"/> </jsp:useBean> <% Userdao userdaoa=new Userdao(); userdaoa.InsertUser(user); %> </body> </html>
无法更新数据到MySQL。
management.jsp(用post传到mcheckreview.jsp处理) ``` <form method="post" action="mcheckreview.jsp" > <div style="overflow-y:scroll; position:relative; right:100px; overflow-x:none; height:180px;"> <table border="0" width="100%"> <tr> <td width="10%" style="text-align:center">编号</td> <td width="20%" style="text-align:center">电话</td> <td width="60%" style="text-align:center">评论</td> <td width="10%" style="text-align:center">回复</td> </tr> <% while(rs.next()) { String id=rs.getString(1); String number=rs.getString(2); String content=rs.getString(3); %> <tr> <td style="text-align:center" name="id"><input name="id" value='<%=id %>' style="background:grey; border:none; outline:none; text-align:center;"> </td> <td style="text-align:center" ><%=number %> </td> <td style="text-align:center"><%=content %> </td> <td><input type="submit" value="回复" ></td> </tr> <% } %> </table> </div> <input type="text" name="back"> </form> `````` mcheckreview.jsp ``` <% Connection conn = null; PreparedStatement ps = null; Class.forName("com.mysql.jdbc.Driver"); String url = "jdbc:mysql://localhost:3306/wutourism?&useUnicode=true&characterEncoding=UTF-8"; String username = "root"; String password = "imissyou15"; conn = DriverManager.getConnection(url, username, password); request.setCharacterEncoding("utf-8");//设置编码方式,防止中文乱码 String id = request.getParameter("id"); String back = request.getParameter("back");//insert into review(id,back) values(?,?) String sql = "update review set back=? where id=?"; ps = conn.prepareStatement(sql); ps.setString(1, id); ps.setString(2,back); int row = ps.executeUpdate(); if(row>0){ System.out.print(request.getParameter("id")); System.out.print(request.getParameter("back"));//测试是否取到上个页面的值 out.println("<script language='javascript'>alert('成功!');window.location.href='./management.jsp';</script>"); } ps.close(); conn.close(); %> ``` 问题:1: System.out.print(request.getParameter("id")); System.out.print(request.getParameter("back")); 把这两行代码放在if外面,命令行就可以输出取到的值;但放在if里面就取不到,是这里出错了吧?可是我注册语句这样写就没问题欸。 2: 取出来的数据id总是1,但我提交的时候点的并不是id=1那一行。 尝试:我觉得可能我sql语句有错,就从insert改到update,然后set back=?(set back='"+back+"') ,where id=?(where id='"+id+"')我都写过,但还是不对,改的时候也出现报错说 int row=ps.executeUpdate();那一句 说明:现在这样的代码问题在于 ,数据传不到数据库,但也不输出报错,也不会重定向到management.jsp(也就是上面那个页面)
JSP连接数据库插入数据相关问题?
``` <%@ page contentType="text/html; charset=utf-8" %> <%@ page language="java" %> <%@ page import="com.mysql.jdbc.Driver" %> <%@ page import="java.sql.*" %> <html> <head> </head> <% //request.setCharacterEncoding("utf-8"); //String text = request.getParameter("text"); //加载驱动程序 String driverName="com.mysql.jdbc.Driver"; //数据库信息 String USER = "root"; //密码 String PASS = "sq123456"; String DB_URL="jdbc:mysql://localhost/official_website"; Connection conn = null; Statement stmt = null; out.print("连接中......"); try{ // 注册 JDBC 驱动 Class.forName("com.mysql.jdbc.Driver"); out.print("连接成功......"); // 打开链接 conn = DriverManager.getConnection(DB_URL,USER,PASS); out.print("打开连接......"); stmt = conn.createStatement(); String sql; sql = "INSERT INTO test_table (context) VALUES('I'm a saver!testing!testing!')"; out.print("读取SQL语句中......."); stmt.executeUpdate(sql); out.print("执行完成......."); out.print("Success!"); out.print(sql); // 完成后关闭 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(); } } %> <body> </body> </html> ``` 这个段代码的stmt.executeUpdate(sql);这个段语句不执行也不报错到这就停了。这是为什么?
用hibernate等实现:从一数据库复制一条记录,然后修改该记录的某一列,再插入原数据库
目前该功能(简称copyinsert)可以在mysql数据库里用sql语句实现,我想用hibernate实现,大部分都已经完成,感觉在dao层有一些错误,希望大佬帮忙解惑,能够解决者,还可以另外给C币。 例子如下:(ID为自增,非数据库定义内容) ![图片说明](https://img-ask.csdn.net/upload/201808/22/1534872743_640656.png) 数据库原来有三条记录,然后在mysql中输入查询语句: INSERT INTO t_test(NO,NAME,SEX) SELECT REPLACE (NO,'XS1','XS4'),NAME,SEX FROM t_test WHERE NO='XS1'; ![图片说明](https://img-ask.csdn.net/upload/201808/22/1534872784_814889.png) 可以成功在mysql数据库中实现,结果如下: ![图片说明](https://img-ask.csdn.net/upload/201808/22/1534872803_898787.png) (从上面看,在数据库中直接操作是可以的,但是我想用框架实现)我用了hibernate,struts2,Jeasyui框架(基本都不熟练),目前能确定的是dao层的拼接的sql语句是正确的,但是不能实现插入数据库的功能。 系统主界面如下: ![图片说明](https://img-ask.csdn.net/upload/201808/22/1534873318_873663.png) 点击datagrids上面的“复制并插入“按钮,期望实现**复制某一条信息,修改其中一列后再插入数据库中**(例子是,复制XS1信息,将XS1修改为XS99后,再插入原数据库)。主界面jsp关键代码如下: //1."复制并插入信息"按钮作用 $("#deriveBtn").click(function(){ var no1="XS1"; var no2="XS99"; $.post("test_copyinsert.action",{"no1":no1,"no2":no2},function(data){ if(data.success){ //刷新datagrid $("#list").datagrid("load"); //提示 $.messager.show({ title:"提示", msg:"insertcopy成功" }); }else{ $.messager.alert("提示","检索失败:"+data.msg,"error"); } },"json"); }); }); 下面是TestAction部分代码(主要体现copyinsert): package test.action; //copyinsert实现 private String no1; public void setNo1(String no1) {//普通属性驱动,提供set方法进行接收 this.no1 = no1; } private String no2; public void setNo2(String no2) {//普通属性驱动,提供set方法进行接收 this.no2 = no2; } public void copyinsert(){ service.copyinsert(no1,no2); } } 下面是TestServiceImpl部分代码(主要体现copyinsert): package test.service.impl; @Override public void copyinsert(String no1, String no2){ dao.copyinsert(no1,no2); } } 下面是TestDaoImpl部分主要代码(主要体现copyinsert功能): @Override public void copyinsert(String no1, String no2) { // 获取Session Session session = HibernateUtils.getSession(); try { Transaction tx = session.beginTransaction(); String sql="INSERT INTO t_test (NO,NAME,SEX) SELECT REPLACE (NO,"+"'"+no1+"'"+","+"'"+no2+"'"+"),NAME,SEX FROM t_test WHERE NO="+"'"+no1+"'"+";"; SQLQuery sqlQuery = session.createSQLQuery(sql); List list=sqlQuery.list();//就是这一行!!!!! tx.commit(); } catch (Exception e) { e.printStackTrace(); throw new RuntimeException(e); } finally { // 释放session session.close(); } 其中,在上述TestDaoImpl代码中,我不太清楚“List list=sqlQuery.list();”的作用,但是如果没有添加这一行代码,运行程序(即点击主界面“复制并插入”按钮)后,数据库没有插入值,myeclipse的Console也没有输出任何新的查询语句; 当在上述TestDaoImpl代码中添加“List list = sqlQuery.list(); ”这一行代码后,再点击按钮运行,数据库仍然没有插入值,但是Console输出了查询语句,但是紧接着会报错,mysql数据库也没有成功插进数据,如图: ![图片说明](https://img-ask.csdn.net/upload/201808/22/1534873763_176501.png) ![图片说明](https://img-ask.csdn.net/upload/201808/22/1534873821_414105.png)
在jsp中使用jxl.jar包来将mysql搜索语句sql结果集导出到excel文件
整体构思是:连接数据库由DBManager.java,创建excel样式由Excel.java;最后在excel.jsp实现!但现在数据库数据并不能显示,求指教,我是java小白! Excel.java代码 package com; import java.io.*; import java.sql.*; import javax.sql.rowset.CachedRowSet; import com.sun.rowset.CachedRowSetImpl; import jxl.Workbook; import jxl.write.Label; import jxl.write.WritableWorkbook; import jxl.write.WriteException; public class Excel { private static Connection conn=null; private static PreparedStatement pstmt=null; private static ResultSet rs=null; private static CachedRowSet crs; @SuppressWarnings("static-access") public CachedRowSet GetResult(String sql)throws SQLException{ try { conn=DBManager.getDBManager().connection; pstmt=conn.prepareStatement(sql); rs=pstmt.executeQuery(); crs=new CachedRowSetImpl(); crs.populate(rs); System.out.println(null==crs); return crs; } catch (Exception e) { // TODO: handle exception return null; } } public void getExcelResult(String sql, OutputStream os) throws SQLException, IOException, WriteException { // 首先获取结果集 // 这里获取RowSet的方法 CachedRowSet crs = this.GetResult(sql); // 然后将结果集转化为Excel输出 // 初始化工作 System.out.println(null==crs); WritableWorkbook wwb = null; try { wwb = Workbook.createWorkbook(os); // 创建工作表 jxl.write.WritableSheet ws = wwb.createSheet("Sheet1", 0); // 逐行添加数据 Label l1=new Label(0,0,"开始时间"); Label l2=new Label(1,0,"时间"); Label l3=new Label(2,0,"最高电压1"); Label l4=new Label(3,0,"电池号"); Label l5=new Label(4,0,"最高电压2"); Label l6=new Label(5,0,"电池号"); Label l7=new Label(6,0,"最高电压3"); Label l8=new Label(7,0,"电池号"); ws.addCell(l1); ws.addCell(l2); ws.addCell(l3); ws.addCell(l4); ws.addCell(l5); ws.addCell(l6); ws.addCell(l7); ws.addCell(l8); int i = 1; while (crs.next()) { for (int j = 1; j <= crs.getMetaData().getColumnCount(); j++) { String s = crs.getString(j); Label labelC = new Label(j-1, i, s); ws.addCell(labelC); } i++; } } catch (Exception e) { //logger.error("export excel error:" + e); e.printStackTrace(); } finally { if (wwb != null) { wwb.write(); wwb.close(); } } } } DBManager.java代码 package com; import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException; public class DBManager { private String driver="com.mysql.jdbc.Driver"; private String url="jdbc:mysql://localhost:3306/hwglxt?useUnicode=true&amp;characterEncoding=gb2312"; private String username="root"; private String password="root"; public static Connection connection =null; private static DBManager dbManager=null; private DBManager() { try { Class.forName(driver); connection=DriverManager.getConnection(url, username, password); } catch (ClassNotFoundException e) { System.out.println("1"); } catch (SQLException e) { System.out.println("2"); } } public static DBManager getDBManager() { if (null==dbManager) { dbManager=new DBManager(); } return dbManager; } } jsp页面文件 <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@page import="com.util.Excel" %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Insert title here</title> </head> <body> <% out.print(request.getParameter("sql")); Excel excel=new Excel(); response.reset(); response.setContentType("application/vnd.ms-excel"); // String sql="select * from tbit_links "; String sql=request.getParameter("sql"); excel.getExcelResult(sql,response.getOutputStream()); %> </body> </html>
关于jsp无法连接mysql的问题
前几天用jsp连接数据库时可以正常连接数据库输出查询内容,前天忽然输出不出来了,我重启了电脑之后,又可以正常输出了,可今天忽然又不能输出查询内容 这是我编写的数据库通用类,链接数据库的通用类我就不贴上来了,已经确认过可以连接成功 ``` package dbutil; import java.sql.Connection; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; public class Conndb { //执行select语句 //@param sql //@return //@throws Exception public ResultSet executeQuery(String sql) throws Exception{ System.out.println("conn00"); ResultSet rs=null; Connection con=null; Statement st=null; try { con=conn.getConnection(); System.out.println("conn11"); st=con.createStatement(); System.out.println("conn12"); rs=st.executeQuery(sql); } catch (SQLException e) { throw e; } finally{ DBclose.close(rs,st,con); } return rs; } //执行insert,update,delete语句 //@param sq; //@throw Exception public void executeUpdate(String sql) throws Exception{ Connection con=null; Statement st=null; try { con=conn.getConnection(); st=con.createStatement(); st.executeUpdate(sql); } catch (SQLException ex) { ex.printStackTrace(); System.out.println("执行SQL语句出错:"+ex.getMessage()); } finally{ DBclose.close(st,con); } } } ``` 这是要执行的jsp语句,可以确定if(rs!=null){开始不执行的,控制台也没有报错 ``` <body> <%@page import="dbutil.Conndb" %> <%@page import="dbutil.DBclose" %> <% request.setCharacterEncoding("utf8"); // String cla=request.getParameter("cla"); String cla="软件技术四班"; int id; String s_name; String t_name; String sql=null; Connection con=null; Statement st=null; ResultSet rs=null; StringBuffer buffer = new StringBuffer(); try { sql="select student.s_id,s_name,t_name from ts,student,team where student.s_id=ts.s_id and team.t_id=ts.t_id and ts.s_id in (select s_id from student where c_id in(select c_id from class where c_name='"+cla+"'))"; Conndb Conndb=new Conndb(); rs=Conndb.executeQuery(sql); System.out.println("conn"); if(rs!=null){ buffer.append("<table width=100% height=15% border=2 cellspacing=0>"); buffer.append("<tr><td>学生id</td><td>学生姓名</td><td>加入社团</td></tr>"); while(rs.next()){ System.out.println("conn2"); id=rs.getInt("s_id"); s_name=rs.getString("s_name"); t_name=rs.getString("t_name"); buffer.append("<tr><td>"+id+"</td>"); buffer.append("<td>"+s_name+"</td>"); buffer.append("<td>"+t_name+"</td></tr>"); } buffer.append("</table>"); } } catch (Exception e) { %> <script type="text/javascript"> alert("出现问题,请重新输入"); </script> <% } finally{ DBclose.close(rs,st,con); } ``` 而另一个原来能正常运行的jsp页面报错"java.sql.SQLException: Operation not allowed after ResultSet closed" ``` String sql="select*from team where t_id='"+id+"'"; Conndb Conndb=new Conndb(); rs=Conndb.executeQuery(sql); if(rs!=null){ while(rs.next()){ id=rs.getString("t_id"); name=rs.getString("t_name"); teacher=rs.getString("t_teacher"); time=rs.getString("t_time"); office=rs.getString("t_office"); } } ```
sql语句update+set+select求助
jsp数据库处理中 String sql=“ ``` update buffers set lastSuccess='1' where customMoney=(select currentMoney from clothes where cloId=?) and b.cloId=? pstmt.setString(1,cloId); pstmt.setString(2,cloId); pstmt.executeUpdate(); ``` "; 此语句报错,到update()那就通不过了 ``` com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'lastSuccess='1' where b.customMoney=(select currentMoney from clothes where cloI' at line 1 ```
JSP+servlet实现网页数据插入mysql问题求解
本意是将网页上表格数据插入到mysql的表中 数据获取和类的构造 L_datainsert.java package a; import java.io.IOException; import java.util.Date; import javax.servlet.ServletConfig; import javax.servlet.ServletException; import javax.servlet.ServletRequest; import javax.servlet.ServletResponse; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; public abstract class L_datainsert implements javax.servlet.Servlet { public void doPost(HttpServletRequest request,HttpServletResponse response) throws ServletException,IOException{ response.setContentType("text/html"); request.setCharacterEncoding("UTF-8"); String[] thi=request.getParameterValues("thi"); String[] the=request.getParameterValues("the"); String[] fl=request.getParameterValues("fl"); String[] chu=request.getParameterValues("chu"); String[] hh=request.getParameterValues("hh"); for(int n=0;n<10;n++){ Hs hs = new Hs(); hs.setThi(Double.parseDouble(thi[n])); hs.setThe(Double.parseDouble(the[n])); hs.setFl(Double.parseDouble(fl[n])); hs.setChu(Double.parseDouble(chu[n])); hs.setHh(Double.parseDouble(hh[n])); Hsinsert db = new Hsinsert(); boolean canLogin = db.addHs(hs);} } } class Hs { private double thi; private double the; private double fl; private double chu; private double hh; public Hs(double i, double e, double l,double u, double h) { thi = i; the = e; fl = l; chu = u; hh = h; } public Hs() { } public void setThi(double thi){ this.thi = thi; } public double getThi(){ return thi; } public void setThe(double the){ this.the = the; } public double getThe(){ return the; } public void setFl(double fl){ this.fl = fl; } public double getFl(){ return fl; } public void setChu(double chu){ this.chu = chu; } public double getChu(){ return chu; } public void setHh(double hh){ this.hh = hh; } public double getHh(){ return hh; } } 插入方法实现:Hsinsert.java package a; import java.sql.*; public class Hsinsert { boolean bInited = false; //加载驱动 public void initJDBC() throws ClassNotFoundException { //加载MYSQL JDBC驱动程序 Class.forName("com.mysql.jdbc.Driver"); bInited = true; System.out.println("Success loading Mysql Driver!"); } public Connection getConnection() throws ClassNotFoundException, SQLException{ if(!bInited){ initJDBC(); } //连接URL为 jdbc:mysql//服务器地址/数据库名 //后面的2个参数分别是登陆用户名和密码 Connection conn = DriverManager.getConnection( "jdbc:mysql://localhost:3306/login?characterEncoding=utf8&useSSL=true","root",""); return conn; } public boolean addHs(Hs hs){ boolean returnValue = false; try{ Class.forName("com.mysql.jdbc.Driver");//加载数据库驱动,注册到驱动管理器 Connection conn = DriverManager.getConnection( "jdbc:mysql://localhost:3306/login?characterEncoding=utf8&useSSL=true","root",""); //创建connection连接, String sql="insert into hs(thi,the,fl,chu,hh) values(?,?,?,?,?)"; //添加图书信息的sql语句 PreparedStatement ps=conn.prepareStatement(sql); //获取PreparedStatement ps.setDouble(2,hs.getThi());//对sql语句中的第1个参数赋值 ps.setDouble(3,hs.getThe());//对sql语句中的第2个参数赋值 ps.setDouble(4,hs.getFl());//对sql语句中的第3个参数赋值 ps.setDouble(5,hs.getChu());//对sql语句中的第4个参数赋值 ps.setDouble(6,hs.getHh()); int row=ps.executeUpdate();//执行更新操作,返回所影响的行数 if(row>0){ returnValue = true; } ps.close(); conn.close(); }catch (ClassNotFoundException e) { e.printStackTrace(); }catch (SQLException e) { e.printStackTrace(); } return returnValue; } } 但是运行没办法实现 弹出![图片说明](https://img-ask.csdn.net/upload/201706/01/1496308529_290964.png) 是因为我没有设置好xml文件吗 还是别的原因?我的xml文件内容如下:![图片说明](https://img-ask.csdn.net/upload/201706/01/1496312692_144002.png) 工程内容截图为:![图片说明](https://img-ask.csdn.net/upload/201706/01/1496312785_296623.png) 我重新配置了xml文件:![图片说明](https://img-ask.csdn.net/upload/201706/02/1496367553_524699.png) 但还是没好,运行错误为![图片说明](https://img-ask.csdn.net/upload/201706/02/1496367922_913258.png) ![图片说明](https://img-ask.csdn.net/upload/201706/02/1496367937_625333.png)
基于servlet jsp页面查询条件回显及分页
在公司之前的老项目上完善新功能,纯servlet jsp页面, 做条件查询时不能回显查询条件,我在后台把前台数据接收后存在session中,然后从jsp页面直接取,但是结果每次回显的是我上一次的查询,也就是我查询"2"的时候,回显的是"1",大神给看看是 另外就是目前条件查询后点击下一页,又把所有的数据查出来了.![图片说明](https://img-ask.csdn.net/upload/201905/11/1557566762_480988.png) action 是执行当前页面,页面中有个方法查询数据库![图片说明](https://img-ask.csdn.net/upload/201905/11/1557566978_215553.png) ![图片说明](https://img-ask.csdn.net/upload/201905/11/1557567021_9586.png)![图片说明](https://img-ask.csdn.net/upload/201905/11/1557567095_290470.png) 最后一张图是后台代码.搞了一下午,我感觉条件查询后分页就办法实现,不知道大佬们有什么解决思路 后台没有按照dao service action分开写,所有的业务都写在一个class里,包括sql语句
关于如何获取数据库的提示信息
我想要在执行一条SQL语句后获得数据库的执行和的提示信息,比如:命令执行成功,影响记录数 1 ;又如:共发现 99801 条记录。 或者该SQL执行失败后的错误提示信息,如:“XXX”字段不存在,位置 10... 我想要在JSP上显示这个信息,请问应该怎么实现?
JSP+SERVLET+MYSQL问题
com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Not unique table/alias: 'emp' 这个要怎么解决,我的sql语句没有问题,求指教
动态规划入门到熟悉,看不懂来打我啊
持续更新。。。。。。 2.1斐波那契系列问题 2.2矩阵系列问题 2.3跳跃系列问题 3.1 01背包 3.2 完全背包 3.3多重背包 3.4 一些变形选讲 2.1斐波那契系列问题 在数学上,斐波纳契数列以如下被以递归的方法定义:F(0)=0,F(1)=1, F(n)=F(n-1)+F(n-2)(n&gt;=2,n∈N*)根据定义,前十项为1, 1, 2, 3...
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私...
对计算机专业来说学历真的重要吗?
我本科学校是渣渣二本,研究生学校是985,现在毕业五年,校招笔试、面试,社招面试参加了两年了,就我个人的经历来说下这个问题。 这篇文章很长,但绝对是精华,相信我,读完以后,你会知道学历不好的解决方案,记得帮我点赞哦。 先说结论,无论赞不赞同,它本质就是这样:对于技术类工作而言,学历五年以内非常重要,但有办法弥补。五年以后,不重要。 目录: 张雪峰讲述的事实 我看到的事实 为什么会这样 ...
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
防劝退!数据结构和算法难理解?可视化动画带你轻松透彻理解!
大家好,我是 Rocky0429,一个连数据结构和算法都不会的蒟蒻… 学过数据结构和算法的都知道这玩意儿不好学,没学过的经常听到这样的说法还没学就觉得难,其实难吗?真难! 难在哪呢?当年我还是个小蒟蒻,初学数据结构和算法的时候,在忍着枯燥看完定义原理,之后想实现的时候,觉得它们的过程真的是七拐八绕,及其难受。 在简单的链表、栈和队列这些我还能靠着在草稿上写写画画理解过程,但是到了数论、图...
【搞定 Java 并发面试】面试最常问的 Java 并发基础常见面试题总结!
本文为 SnailClimb 的原创,目前已经收录自我开源的 JavaGuide 中(61.5 k Star!【Java学习 面试指南】 一份涵盖大部分Java程序员所需要掌握的核心知识。欢迎 Star!)。 另外推荐一篇原创:终极推荐!可能是最适合你的Java学习路线 方法 网站 书籍推荐! Java 并发基础常见面试题总结 1. 什么是线程和进程? 1.1. 何为进程? 进程是程...
西游记团队中如果需要裁掉一个人,会先裁掉谁?
2019年互联网寒冬,大批企业开始裁员,下图是网上流传的一张截图: 裁员不可避免,那如何才能做到不管大环境如何变化,自身不受影响呢? 我们先来看一个有意思的故事,如果西游记取经团队需要裁员一名,会裁掉谁呢,为什么? 西游记团队组成: 1.唐僧 作为团队teamleader,有很坚韧的品性和极高的原则性,不达目的不罢休,遇到任何问题,都没有退缩过,又很得上司支持和赏识(直接得到唐太宗的任命,既给
shell脚本:备份数据库、代码上线
备份MySQL数据库 场景: 一台MySQL服务器,跑着5个数据库,在没有做主从的情况下,需要对这5个库进行备份 需求: 1)每天备份一次,需要备份所有的库 2)把备份数据存放到/data/backup/下 3)备份文件名称格式示例:dbname-2019-11-23.sql 4)需要对1天以前的所有sql文件压缩,格式为gzip 5)本地数据保留1周 6)需要把备份的数据同步到远程备份中心,假如...
iOS Bug 太多,苹果终于坐不住了!
开源的 Android 和闭源的 iOS,作为用户的你,更偏向哪一个呢? 整理 | 屠敏 出品 | CSDN(ID:CSDNnews) 毋庸置疑,当前移动设备操作系统市场中,Android 和 iOS 作为两大阵营,在相互竞争的同时不断演进。不过一直以来,开源的 Android 吸引了无数的手机厂商涌入其中,为其生态带来了百花齐放的盛景,但和神秘且闭源的 iOS 系统相比,不少网友...
神经⽹络可以计算任何函数的可视化证明
《Neural Networks and Deep Learning》读书笔记第四篇本章其实和前面章节的关联性不大,所以大可将本章作为小短文来阅读,当然基本的深度学习基础还是要有的。主要介绍了神经⽹络拥有的⼀种普遍性,比如说不管目标函数是怎样的,神经网络总是能够对任何可能的输入,其值(或者说近似值)是网络的输出,哪怕是多输入和多输出也是如此,我们大可直接得出一个结论:不论我们想要计算什么样的函数,...
聊聊C语言和指针的本质
坐着绿皮车上海到杭州,24块钱,很宽敞,在火车上非正式地聊几句。 很多编程语言都以 “没有指针” 作为自己的优势来宣传,然而,对于C语言,指针却是与生俱来的。 那么,什么是指针,为什么大家都想避开指针。 很简单, 指针就是地址,当一个地址作为一个变量存在时,它就被叫做指针,该变量的类型,自然就是指针类型。 指针的作用就是,给出一个指针,取出该指针指向地址处的值。为了理解本质,我们从计算机模型说起...
为什么你学不过动态规划?告别动态规划,谈谈我的经验
动态规划难吗?说实话,我觉得很难,特别是对于初学者来说,我当时入门动态规划的时候,是看 0-1 背包问题,当时真的是一脸懵逼。后来,我遇到动态规划的题,看的懂答案,但就是自己不会做,不知道怎么下手。就像做递归的题,看的懂答案,但下不了手,关于递归的,我之前也写过一篇套路的文章,如果对递归不大懂的,强烈建议看一看:为什么你学不会递归,告别递归,谈谈我的经验 对于动态规划,春招秋招时好多题都会用到动态...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
如何安装 IntelliJ IDEA 最新版本——详细教程
IntelliJ IDEA 简称 IDEA,被业界公认为最好的 Java 集成开发工具,尤其在智能代码助手、代码自动提示、代码重构、代码版本管理(Git、SVN、Maven)、单元测试、代码分析等方面有着亮眼的发挥。IDEA 产于捷克,开发人员以严谨著称的东欧程序员为主。IDEA 分为社区版和付费版两个版本。 我呢,一直是 Eclipse 的忠实粉丝,差不多十年的老用户了。很早就接触到了 IDEA...
面试还搞不懂redis,快看看这40道面试题(含答案和思维导图)
Redis 面试题 1、什么是 Redis?. 2、Redis 的数据类型? 3、使用 Redis 有哪些好处? 4、Redis 相比 Memcached 有哪些优势? 5、Memcache 与 Redis 的区别都有哪些? 6、Redis 是单进程单线程的? 7、一个字符串类型的值能存储最大容量是多少? 8、Redis 的持久化机制是什么?各自的优缺点? 9、Redis 常见性...
大学四年自学走来,这些珍藏的「实用工具/学习网站」我全贡献出来了
知乎高赞:文中列举了互联网一线大厂程序员都在用的工具集合,涉及面非常广,小白和老手都可以进来看看,或许有新收获。
为什么要推荐大家学习字节码?
配套视频: 为什么推荐大家学习Java字节码 https://www.bilibili.com/video/av77600176/ 一、背景 本文主要探讨:为什么要学习 JVM 字节码? 可能很多人会觉得没必要,因为平时开发用不到,而且不学这个也没耽误学习。 但是这里分享一点感悟,即人总是根据自己已经掌握的知识和技能来解决问题的。 这里有个悖论,有时候你觉得有些技术没用恰恰是...
互联网公司的裁员,能玩出多少种花样?
裁员,也是一门学问,可谓博大精深!以下,是互联网公司的裁员的多种方法:-正文开始-135岁+不予续签的理由:千禧一代网感更强。95后不予通过试用期的理由:已婚已育员工更有责任心。2通知接下来要过苦日子,让一部分不肯同甘共苦的员工自己走人,以“兄弟”和“非兄弟”来区别员工。3强制996。员工如果平衡不了工作和家庭,可在离婚或离职里二选一。4不布置任何工作,但下班前必须提交千字工作日报。5不给活干+...
【超详细分析】关于三次握手与四次挥手面试官想考我们什么?
在面试中,三次握手和四次挥手可以说是问的最频繁的一个知识点了,我相信大家也都看过很多关于三次握手与四次挥手的文章,今天的这篇文章,重点是围绕着面试,我们应该掌握哪些比较重要的点,哪些是比较被面试官给问到的,我觉得如果你能把我下面列举的一些点都记住、理解,我想就差不多了。 三次握手 当面试官问你为什么需要有三次握手、三次握手的作用、讲讲三次三次握手的时候,我想很多人会这样回答: 首先很多人会先讲下握...
新程序员七宗罪
当我发表这篇文章《为什么每个工程师都应该开始考虑开发中的分析和编程技能呢?》时,我从未想到它会对读者产生如此积极的影响。那些想要开始探索编程和数据科学领域的人向我寻求建议;还有一些人问我下一篇文章的发布日期;还有许多人询问如何顺利过渡到这个职业。我非常鼓励大家继续分享我在这个旅程的经验,学习,成功和失败,以帮助尽可能多的人过渡到一个充满无数好处和机会的职业生涯。亲爱的读者,谢谢你。 -罗伯特。 ...
活到老,学到老,程序员也该如此
全文共2763字,预计学习时长8分钟 图片来源:Pixabay 此前,“网传阿里巴巴要求尽快实现P8全员35周岁以内”的消息闹得沸沸扬扬。虽然很快被阿里辟谣,但苍蝇不叮无缝的蛋,无蜜不招彩蝶蜂。消息从何而来?真相究竟怎样?我们无从而知。我们只知道一个事实:不知从何时开始,程序猿也被划在了“吃青春饭”行业之列。 饱受“996ICU”摧残后,好不容易“头秃了变强了”,即将步入为“高...
Vue快速实现通用表单验证
本文开篇第一句话,想引用鲁迅先生《祝福》里的一句话,那便是:“我真傻,真的,我单单知道后端整天都是CRUD,我没想到前端整天都是Form表单”。这句话要从哪里说起呢?大概要从最近半个月的“全栈工程师”说起。项目上需要做一个城市配载的功能,顾名思义,就是通过框选和拖拽的方式在地图上完成配载。博主选择了前后端分离的方式,在这个过程中发现:首先,只要有依赖jQuery的组件,譬如Kendoui,即使使用...
2019年Spring Boot面试都问了什么?快看看这22道面试题!
Spring Boot 面试题 1、什么是 Spring Boot? 2、Spring Boot 有哪些优点? 3、什么是 JavaConfig? 4、如何重新加载 Spring Boot 上的更改,而无需重新启动服务器? 5、Spring Boot 中的监视器是什么? 6、如何在 Spring Boot 中禁用 Actuator 端点安全性? 7、如何在自定义端口上运行 Sprin...
【图解】记一次手撕算法面试:字节跳动的面试官把我四连击了
字节跳动这家公司,应该是所有秋招的公司中,对算法最重视的一个了,每次面试基本都会让你手撕算法,今天这篇文章就记录下当时被问到的几个算法题,并且每个算法题我都详细着给出了最优解,下面再现当时的面试场景。看完一定让你有所收获 一、小牛试刀:有效括号 大部分情况下,面试官都会问一个不怎么难的问题,不过你千万别太开心,因为这道题往往可以拓展出更多有难度的问题,或者一道题看起来很简单,但是给出最优解,确实很...
关于裁员几点看法及建议
最近网易裁员事件引起广泛关注,昨天网易针对此事,也发了声明,到底谁对谁错,孰是孰非?我们作为吃瓜观众实在是知之甚少,所以不敢妄下定论。身处软件开发这个行业,近一两年来,对...
面试官:关于Java性能优化,你有什么技巧
通过使用一些辅助性工具来找到程序中的瓶颈,然后就可以对瓶颈部分的代码进行优化。 一般有两种方案:即优化代码或更改设计方法。我们一般会选择后者,因为不去调用以下代码要比调用一些优化的代码更能提高程序的性能。而一个设计良好的程序能够精简代码,从而提高性能。 下面将提供一些在JAVA程序的设计和编码中,为了能够提高JAVA程序的性能,而经常采用的一些方法和技巧。 1.对象的生成和大小的调整。 J...
相关热词 c# 时间比天数 c# oracle查询 c# 主动推送 事件 c# java 属性 c# 控制台 窗体 c# 静态类存值 c#矢量作图 c#窗体调用外部程式 c# enum是否合法 c# 如何卸载引用
立即提问