1、tomcat启动一直保持在starting状态时,最简单的原因就是时间过短,将时间变长就可以了。
若还不能解决时,还可能就是端口号被占用了。
通过netstat -nao | findstr ""可以看到占用你所使用的端口号的进程id,然后通过tasklist |
findstr "" 命令查看该进程ID对应的进程。
备注:a.toad中f_server(不修改的话,项目启动后,数据刷新不出来)
b.global.properties 中#根地址
rootUrl=http://www.mvc.com:7000修改成对应的端口号
c.tomcat相关端口号
2、连接池耗尽解决办法:
一般来说,在tomcat中配置数据库连接池,而我们不停的建立数据库连接,而没有关闭数据库的连接的
话就会产生这样的异常:Cannot get a connection, pool exhaustedCannot get a connection, pool
exhausted 。其实,这是由于连接池中的连接被消耗殆尽的缘故。我们实际上,在开发中应该养成良好
的开发习惯,就是在用完连接后应该马上关闭Connection,这样就很好的解决了这样的问题。
可能有人会说,那每次用完池的连接都要关闭数据库的连接,那池就不起作用了吗?那不就是用完
一次连接就关闭,然后再次建立连接,这样效率不是依然很低吗?其实不然,这里调用con.close()其
实并没有把这个连接真正的关闭掉,而是容许池把此连接再次放回到池中分配给别的客户端来使用,所
以大可以放心的关闭连接,而不影响连接池的效率。
当然,这不是唯一的解决方案,但是我认为这是最好的解决方案。但是,如果你在编程的时候的确
是忘记关闭数据库的连接,那依然有其他的解决方案:(当然最好是在finally中关闭con)
1). 可以重新启动你的tomcat服务器,这是最灵的解决方案,不过没什么技术含量
2). 在数据源的配置文件中把maxactive属性的值调整到更大,比如100
3、
server.xml配置简介
Logger timestamp 如果为true,则log文件名中要加入时间,如下例:localhost_log.2001-10-04.txt
元素名 属性 解释
server port 指定一个端口,这个端口负责监听关闭tomcat的请求
shutdown 指定向端口发送的命令字符串
service name 指定service的名字
Connector
(表示客户端和service之间的连接) port 指定服务器端要创建的端口号,并在这个断口监听来自客户
端的请求
minProcessors 服务器启动时创建的处理请求的线程数
maxProcessors 最大可以创建的处理请求的线程数
enableLookups 如果为true,则可以通过调用request.getRemoteHost()进行DNS查询来得到远程客户端
的实际主机名,若为false则不进行DNS查询,而是返回其ip地址
redirectPort 指定服务器正在处理http请求时收到了一个SSL传输请求后重定向的端口号
acceptCount 指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超
过这个数的请求将不予处理
connectionTimeout 指定超时的时间数(以毫秒为单位)
Engine
(表示指定service中的请求处理机,接收和处理来自Connector的请求) defaultHost 指定缺省的处理
请求的主机名,它至少与其中的一个host元素的name属性值是一样的
Context
(表示一个web应用程序,通常为WAR文件,关于WAR的具体信息见servlet规范) docBase 应用程序的路
径或者是WAR文件存放的路径
path 表示此web应用程序的url的前缀,这样请求的url为http://localhost:8080/path/****
reloadable 这个属性非常重要,如果为true,则tomcat会自动检测应用程序的/WEB-INF/lib 和/WEB-
INF/classes目录的变化,自动装载新的应用程序,我们可以在不重起tomcat的情况下改变应用程序
host
(表示一个虚拟主机)
name 指定主机名
appBase 应用程序基本目录,即存放应用程序的目录
unpackWARs 如果为true,则tomcat会自动将WAR文件解压,否则不解压,直接从WAR文件中运行应用程
序
--------
4、setInterval(function() {
$("#content").load(location.href+" #content>*","");
}, 5000);5秒刷新
$(document).ready(function() {
});
5、input显示空值的问题在浏览器端有兼容性问题IE(trident核心)会显示'null',火狐(gecko核心)和
谷歌(webkit核心)显示空字符串'', 其它不常用浏览器未测过好的解决办法是在服务器端输出数据时增
加监听将空值幅空字符串, 或在浏览器端增加数据预处理, 将null, undefined等替换为空字符串'';如
果只想在模块级别解决该问题, 像楼上说的设置数据后把input遍历一遍替换掉就行了.
6、对齐方式
AbsBottom 图像的下边缘与同一行中最大元素的下边缘对齐。
AbsMiddle 图像的中间与同一行中最大元素的中间对齐。
Baseline 图像的下边缘与第一行文本的下边缘对齐。
Bottom 图像的下边缘与第一行文本的下边缘对齐。
Left 图像沿网页的左边缘对齐,文字在图像右边换行。
Middle 图像的中间与第一行文本的下边缘对齐。
NotSet 未设定对齐方式。
Right 图像沿网页的右边缘对齐,文字在图像左边换行。
TextTop 图像的上边缘与同一行上最高文本的上边缘对齐。
Top 图像的上边缘与同一行上最高元素的上边缘对齐。
align="";
7、相同ID,用getElementById取,始终只能获取第一个
-----------
8、能用sql处理的不要用java代码。sql处理批量数据更有优势。
在sql这,true or null =>true
false or null=>null
9、建索引的时候应该根据具体的业务SQL来创建,特别是where条件,还有where条件的顺序,尽量将过
滤大范围的放在后面,因为SQL执行是从后往前的.
如何快速新建大数据量表的索引
如果一个表的记录达到100万以上的话,要对其中一个字段建索引可能要花很长的时间,甚至导致服务
器数据库死机,因为在建索引的时候ORACLE要将索引字段所有的内容取出并进行全面排序,数据量大的
话可能导致服务器排序内存不足而引用磁盘交换空间进行,这将严重影响服务器数据库的工作。解决方
法是增大数据库启动初始化中的排序内存参数,如果要进行大量的索引修改可以设置10M以上的排序内
存(ORACLE缺省大小为64K),在索引建立完成后应将参数修改回来,因为在实际OLTP数据库应用中一
般不会用到这么大的排序内存。
基于优化器对SQL语句的优化处理,我们在创建索引时可以遵循下面的一般性原则:
(1)为经常出现在关键字order by、group by、distinct后面的字段,建立索引。
在这些字段上建立索引,可以有效地避免排序操作。如果建立的是复合索引,索引的字段顺序要和这些
关键字后面的字段顺序一致,否则索引不会被使用。
(2)在union等集合操作的结果集字段上,建立索引。其建立索引的目的同上。
(3)为经常用作查询选择的字段,建立索引。
(4)在经常用作表连接的属性上,建立索引。
(5)考虑使用索引覆盖。对数据很少被更新的表,如果用户经常只查询其中的几个字段,可以考虑在
这几个字段上建立索引,从而将表的扫描改变为索引的扫描。
除了以上原则,在创建索引时,我们还应当注意以下的限制:
(1)限制表上的索引数目。
对一个存在大量更新操作的表,所建索引的数目一般不要超过3个,最多不要超过5个。索引虽说提高了
访问速度,但太多索引会影响数据的更新操作。
(2)不要在有大量相同取值的字段上,建立索引。
在这样的字段(例如:性别)上建立索引,字段作为选择条件时将返回大量满足条件的记录,优化器不
会使用该索引作为访问路径。
(3)避免在取值朝一个方向增长的字段(例如:日期类型的字段)上,建立索引;对复合索引,避免
将这种类型的字段放置在最前面。
由于字段的取值总是朝一个方向增长,新记录总是存放在索引的最后一个叶页中,从而不断地引起该叶
页的访问竞争、新叶页的分配、中间分支页的拆分。此外,如果所建索引是聚集索引,表中数据按照索
引的排列顺序存放,所有的插入操作都集中在最后一个数据页上进行,从而引起插入“热点”。
(4)对复合索引,按照字段在查询条件中出现的频度建立索引。
在复合索引中,记录首先按照第一个字段排序。对于在第一个字段上取值相同的记录,系统再按照第二
个字段的取值排序,以此类推。因此只有复合索引的第一个字段出现在查询条件中,该索引才可能被使
用。
因此将应用频度高的字段,放置在复合索引的前面,会使系统最大可能地使用此索引,发挥索引的作用
。
(5)删除不再使用,或者很少被使用的索引。
表中的数据被大量更新,或者数据的使用方式被改变后,原有的一些索引可能不再被需要。数据库管理
员应当定期找出这些索引,将它们删除,从而减少索引对更新操作的影响。
10、sql server不通过create的建表方式:
SELECT INTO FROM语句
语句形式为:SELECT vale1, value2 into Table2 from Table1
要求目标表Table2不存在,因为在插入时会自动创建表Table2,并将Table1中指定字段数据复制到
Table2中
11、将当前时间放入数据库的表字段中的两种方式:
1)建表时设置默认值
create table emp
(location varchar2(5),
description varchar2(35),
type varchar2(20),
rowversion date default sysdate);
2)通过插入语句
insert into emp values(a,b,c,sysdate)
insert into emp values(1145,'ss','dd',12,to_date((select to_char(sysdate,'yyyy-mm-dd')from
dual),'yyyy-mm-dd'),111,123,30);
------------
12、jdk路径配置
D:\oracle\product\10.2.0\db_1\bin;%JAVA_HOME%\bin;%M2_HOME%\bin;F:\oracle\product
\10.2.0\db_1\bin;%SystemRoot%\system32;%SystemRoot%;%SystemRoot%\System32\Wbem;
%SYSTEMROOT%\System32\WindowsPowerShell\v1.0\;
.;%JAVA_HOME%\lib\dt.jar,%JAVA_HOME%\lib\tools.jar;%CATALINA_HOME%\common\lib\servlet-
api.jar;
13、spring顺序:content-param --> listener --> filter --> servlet
14、本位码
86 9 03790 00003 1
药品国别码、药品类别码,药品本体码和校验码