一些要注意的地方

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

药品国别码、药品类别码,药品本体码和校验码

 

你可能感兴趣的:(js,sql,tomcat,qita)