1.The server time zone value '�й���׼ʱ��' is unrecognized or represents more than one time zone. You must...

原因: 使用了Mysql Connector/J 6.x以上的版本,然后就报了时区的错误
解决办法: 在配置url的时候不能简单写成 :
jdbc:mysql://localhost:3306/jsp_text
而是要写成 :
jdbc:mysql://localhost:3306/jsp_text?serverTimezone=UTC

2. java.sql.SQLException: No value specified for parameter 1(多人多义,非唯一)
-->

原因: 本人所用的数据库id并没有设置其主键自增功能,导致不能单传其他两个属性

    String sql_insert="";
PreparedStatement pst=conn.prepareStatement("insert into user(title,content) values(?,?)");
pst.setString(1, request.getParameter("title"));
    pst.setString(2, request.getParameter("content"));

解决办法:在mysql数据库中设置此语句将id更改为自增,或者设置属性时选择“AI”(但是下方的auto increase框不能点)

ALTER TABLE `jsp`.`user`
CHANGE COLUMN `id` `id` int NOT NULL AUTO_INCREMENT ;

3. Mysql错误1452 - Cannot add or update a child row: a foreign key constraint fails 原因及解决方法

原因:设置的外键与另一个表中的唯一索引列(一般是主键)中的值不匹配
办法:删除要成为外键的列,再次创建并默认为NULL

坑点:想了半天,明明外键Spno都是NULL,怎么就一直还报这个错,后来才发现,我往NULL加了引号!!!逐渐失去耐心。。。

正解参考:

insert
into course
values('1', '数据库', NULL, 4);

4.  Mysql 插入中文错误:Incorrect string value: '\xE7\xA8\x8B\xE5\xBA\x8F...' for column 'course' at row 1

原因:数据库的编码格式为latin1 而我要将utf8的中文插入到数据库中。

办法:

查看数据表的编码:

 show create table Student; 

修改表的编码方式:

alter table Student default character set utf8;

(该命令用于将表Student的编码方式改为utf8)

修改字段的编码方式:

 alter table Student change Sname Sname varchar(20) character set utf8;

该命令用于将表Student中Sname字段的编码方式改为utf8

坑点:修改字段时注意Sname Sname(与前面字段名称一致)  verchar(20)(必须是在表中定义该字段时的格式)

正解参考:

alter table student default character set utf8;
alter table sc default character set utf8;
alter table course default character set utf8; /*修改字段*/
alter table student change Sname Sname char(20) character set utf8;
alter table student change Ssex Ssex char(1) character set utf8;

5. Error Code: 1175. You are using safe update mode and you tried to update a table without a WHERE tha

原因:mysql在执行删除更新语句时报这种错误,是因为在mysql在safe-updates模式中,如果你where后跟的条件不是主键id,那么就会出现这种错误

解决方法:

1、SET SQL_SAFE_UPDATES = 0;执行该命令更改mysql数据库模式。
2、在where判断条件中跟上主键id    例如:delete from firstmysqldatabase.user where UserName='zhangsan' and ID>=0;

 

6. 怎样解决jsp:include标签在包括html文件时遇到的乱码问题

原因:当jsp在include的时候,被include的内容使用何种编码是由被include页面自身决定的,而决定方式是通过<%@ page lanage="java" pageEncoding="UTF-8" contentType="text/html;UTF-8" %>这种指令来决定的,而html页面中并没有这种指令。

解决方法:

第一种办法:就是不要include html页面,改成include jsp页面

第二种办法:在web.xml中通过配置来告诉web应用,全部html文件输出时都採用UTF-8的编码,配置内容例如以下:

<jsp-config>

<jsp-property-group>

<url-pattern>*.html</url-pattern>

<page-encoding>UTF-8</page-encoding>

</jsp-property-group>

</jsp-config>

7. JavaBean找不到属性值

原因:以为是包路径导错了研究很久,实际是因为JavaBean中对class的属性有规范

在 .class中定义的属性名必须首字母是小写

重点来了,因为老师让我们用名字缩写为前缀,所以忽略了set/ get方法的规范!!!!(谢谢老师让我重新复习)

解决方法:

正解是这样: 例如属性名为zyddd,则正确的set方法名是:setZyddd(即set后面是你定义的属性名且首字母一定要大写)

当jsp文件引用时:

<jsp:useBean id="h" class="test.testbean" scope="page"/>

<jsp:getProperty name="h" property="test"/>

此时javabean映射了getTest方法 返回了Test属性

完成~

8.连接数据库,查询条件为汉字,查询无结果解决办法

开始我直接写好了一个普通查询,一个模糊查询,发现模糊查询数字是可以的,然后查询中文,不出数据,代码也不报错

原因:在mysql数据连接的时候需要指定字符集

解决办法:该问题为编码问题,需要进行参数转码,设置连接为:

  url="jdbc:mysql://localhost:3306/db_pos?useUnicode=true&characterEncoding=utf8"

9. jsp中session.getAttribute()取值为空

经过测试session中的值是可以保存的,这种问题一般就检查下取值的时候是否对象不匹配导致的。

解决办法:

看看有没有调用这句:session.removeAttribute("sessionid");如果调用了就是取消掉了所赋的值,所以会null

response.sendRedirect("forward.jsp");
因为用的是重定向,
重定向是不共享session中的数据的,所以在下一个页面是获取不到session中的东西的。

而 request.getRequestDispatcher("forward.jsp").forward(request, response);
是转向,
转向是共享session中的数据,因此这种方式是可以获取到session中的数据的。

jdbc+mysql常见报错总结的更多相关文章

  1. Mysql常见报错解决方法

    一:登录报错 ERROR 1045 (28000): Access denied for user 'mysql'@'localhost' (using password: NO) mysql日志文件 ...

  2. MySQL常见报错汇总

    1>.ERROR 1290 (HY000): The MySQL server is running with the --secure-file-priv option so it canno ...

  3. Mysql 常见报错和疑问汇总

    1.初始化数据库的时候报错 error while loading shared libraries: libstdc++.so.5: cannot open shared object file:  ...

  4. Django 连接 MySQL 数据库及常见报错解决

    目录 Django 连接 MySQL数据库及常见报错解决 终端或者数据库管理工具连接 MySQL ,并新建项目所需数据库 安装访问 MySQL 的 Python 模块 Django 相关配置 可能会遇 ...

  5. web报表工具FineReport使用中遇到的常见报错及解决办法(二)

    web报表工具FineReport使用中遇到的常见报错及解决办法(二) 这里写点抛砖引玉,希望大家能把自己整理的问题及解决方法晾出来,Mark一下,利人利己. 出现问题先搜一下文档上有没有,再看看度娘 ...

  6. java常见报错及解决

    Java常见报错信息: Java 常见异常种类 Java Exception: 1.Error  2.Runtime Exception 运行时异常 3.Exception  4.throw 用户自定 ...

  7. HDFS集群常见报错汇总

    HDFS集群常见报错汇总 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.DataXceiver error processing WRITE_BLOCK operation 报 ...

  8. 03:git常见报错解决方法

    1.1 git常见报错解决方法 1.warning: LF will be replaced by CRLF in .idea/workspace.xml. 参考博客:https://www.cnbl ...

  9. JavaScript 调试常见报错以及原因

    JavaScript 调试常见报错以及原因 测试环境 chrome 版本 66.0.3359.170(正式版本) (64 位) TypeError 类型错误 不是操作符所接受的数据类型. //---- ...

随机推荐

  1. python之模块、类、对象

    模块就像字典 字典是python中唯一映射关系,它用一个事物对应另外一个事物,也就是所谓的key->value. 模块包含一些变量和函数,可以导入,并且可以用点(·)来操作访问变量和函数. 记住 ...

  2. Java Thread中,run方法和start方法的区别

     两种方法的区别: 1.start方法 用 start方法来启动线程,是真正实现了多线程, 通过调用Thread类的start()方法来启动一个线程,这时此线程处于就绪(可运行)状态,并没有运行,一旦 ...

  3. python字符串str

    字符串str常用操作方法(都会产生新的数据) 1.取值: (1)索引:s[0] (2)切片:s[起始索引:结束索引:步长] 起始索引为0,可以省略 s最后一个索引可以取-1 结束索引省略,默认取到最后 ...

  4. Django中的事务与ajax

    一 事务与锁 1.行级锁 行级锁是由存储引擎实现的.如mysql里默认指定的InnoDB存储引擎,由它实现行级锁.InnoDB的行级锁定同样分为两种类型,共享锁(X)和排他锁(S). 对于UPDATE ...

  5. 201771010128王玉兰《面向对象程序设计(Java)》第十六周学习总结

    第一部分:理论基础 1.线程的概念 进程:进程是程序的一次动态执行,它对应了从代码加 载.执行至执行完毕的一个完整过程.  多线程:多线程是进程执行过程中产生的多条执行线索.  线程:线程是比进程执行 ...

  6. LightOJ1336

    题目大意: 给你一个 n ,求出 1 到 n 中有多少个数的因数和为偶数. 解题思路: 可以先求出因数和为奇数的数字的个数. 由算术基本定理我们可以得到:N=P1a1P2a2P3a3 … Pnan, ...

  7. 用jquery写一个上拉加载

    /*可加载页面吗*/function canLoadMore() { return $('.loadin').length < 1;}/*移除正在加载字样*/function removeMor ...

  8. Java并发编程volatile关键字

    volatile理解 Java语言是支持多线程的,为了解决线程并发的问题,在语言内部引入了 同步块 和volatile 关键字机制.volatile具有synchronized关键字的“可见性”,vo ...

  9. MyBatis通过注解方式批量添加、修改、删除

    唯能极于情,故能极于剑 注: 本文转载于:CodeCow · 程序牛 的个人博客:http://www.codecow.cn/ 一.数据库实体DO public class User implemen ...

  10. .Net Core实现区块链初探

    区块链这么火,咱也跟个风.   一.前言 最近,银行总行关于数字货币即将推出的消息频传,把BTC也带得来了一波反弹. 借着这个风,我们也研究一下区块链.   通常大家说到区块链,实际包括两部分概念: ...