
navicate连接mysql报错,错误代码1862,这应该是mysql密码改了。
重新修改下密码即可,修改方式如下:
以root权限登录mysql:(这里我的账户是root,密码也是root)
mysql -uroot -proot
然后更改密码:
SET PASSWORD = PASSWORD('root')
MySQL是一个开放源码的小型关联式数据库管理系统,开发者为瑞典MySQL AB公司。目前MySQL被广泛地应用在Internet上的中小型网站中。由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了MySQL作为网站数据库。
title: JSP分页技术实现summary:使用工具类实现通用分页处理
author: evan_zhao
email: evan_zhao@hotmail.com
目前比较广泛使用的分页方式是将查询结果缓存在HttpSession或有状态bean中,翻页的时候从缓存中取出一页数据显示。这种方法有两个主要的缺点:一是用户可能看到的是过期数据;二是如果数据量非常大时第一次查询遍历结果集会耗费很长时间,并且缓存的数据也会占用大量内存,效率明显下降。
其它常见的方法还有每次翻页都查询一次数据库,从ResultSet中只取出一页数据(使用rs.last()rs.getRow()获得总计录条数,使用rs.absolute()定位到本页起始记录)。这种方式在某些数据库(如oracle)的JDBC实现中差不多也是需要遍历所有记录,实验证明在记录数很大时速度非常慢。
至于缓存结果集ResultSet的方法则完全是一种错误的做法。因为ResultSet在Statement或Connection关闭时也会被关闭,如果要使ResultSet有效势必长时间占用数据库连接。
因此比较好的分页做法应该是每次翻页的时候只从数据库里检索页面大小的块区的数据。这样虽然每次翻页都需要查询数据库,但查询出的记录数很少,网络传输数据量不大,如果使用连接池更可以略过最耗时的建立数据库连接过程。而在数据库端有各种成熟的优化技术用于提高查询速度,比在应用服务器层做缓存有效多了。
在oracle数据库中查询结果的行号使用伪列ROWNUM表示(从1开始)。例如select * from employee where rownum<10 返回前10条记录。但因为rownum是在查询之后排序之前赋值的,所以查询employee按birthday排序的第100到120条记录应该这么写:
[pre] select * from (
select my_table.*, rownum as my_rownum from (
select name, birthday from employee order by birthday
) my_table where rownum <120
) where my_rownum>=100
[/pre]
mySQL可以使用LIMIT子句:
select name, birthday from employee order by birthday LIMIT 99,20
DB2有rownumber()函数用于获取当前行数。
SQL Server没研究过,可以参考这篇文章:http://www.csdn.net/develop/article/18/18627.shtm
在Web程序中分页会被频繁使用,但分页的实现细节却是编程过程中比较麻烦的事情。大多分页显示的查询 *** 作都同时需要处理复杂的多重查询条件,sql语句需要动态拼接组成,再加上分页需要的记录定位、总记录条数查询以及查询结果的遍历、封装和显示,程序会变得很复杂并且难以理解。因此需要一些工具类简化分页代码,使程序员专注于业务逻辑部分。下面是我设计的两个工具类:
PagedStatement 封装了数据库连接、总记录数查询、分页查询、结果数据封装和关闭数据库连接等 *** 作,并使用了PreparedStatement支持动态设置参数。
RowSetPage 参考PetStore的page by page iterator模式, 设计RowSetPage用于封装查询结果(使用OracleCachedRowSet缓存查询出的一页数据,关于使用CachedRowSet封装数据库查询结果请参考JSP页面查询显示常用模式)以及当前页码、总记录条数、当前记录数等信息, 并且可以生成简单的HTML分页代码。
PagedStatement 查询的结果封装成RowsetPage。
下面是简单的使用示例:
//DAO查询数据部分代码:
…
public RowSetPage getEmployee(String gender, int pageNo) throws Exception{
String sql="select emp_id, emp_code, user_name, real_name from employee where gender =?"
//使用Oracle数据库的分页查询实现,每页显示5条
PagedStatement pst =new PagedStatementOracleImpl(sql, pageNo, 5)
pst.setString(1, gender)
return pst.executeQuery()
}
//Servlet处理查询请求部分代码:
…
int pageNo
try{
//可以通过参数pageno获得用户选择的页码
pageNo = Integer.parseInt(request.getParameter("pageno") )
}catch(Exception ex){
//默认为第一页
pageNo=1
}
String gender = request.getParameter("gender" )
request.setAttribute("empPage", myBean.getEmployee(gender, pageNo) )
…
//JSP显示部分代码
<%@ page import = "page.RowSetPage"%>
…
<script language="javascript">
function doQuery(){
form1.actionType.value="doQuery"
form1.submit()
}
</script>
…
<form name=form1 method=get>
<input type=hidden name=actionType>
性别:
<input type=text name=gender size=1 value="<%=request.getParameter("gender")%>">
<input type=button value=" 查询 " onclick="doQuery()">
<%
RowSetPage empPage = (RowSetPage)request.getAttribute("empPage")
if (empPage == null ) empPage = RowSetPage.EMPTY_PAGE
%>
…
<table cellspacing="0" width="90%">
<tr><td>ID</td><td>代码</td><td>用户名</td><td>姓名</td></tr>
<%
javax.sql.RowSet empRS = (javax.sql.RowSet) empPage.getRowSet()
if (empRS!=null) while (empRS.next() ) {
%>
<tr>
<td><%= empRS.getString("EMP_ID")%></td>
<td><%= empRS.getString("EMP_CODE")%></td>
<td><%= empRS.getString("USER_NAME")%></td>
<td><%= empRS.getString("REAL_NAME")%></td>
</tr>
<%
}// end while
%>
<tr>
<%
//显示总页数和当前页数(pageno)以及分页代码。
//此处doQuery为页面上提交查询动作的javascript函数名, pageno为标识当前页码的参数名
%>
<td colspan=4><%= empPage .getHTML("doQuery", "pageno")%></td>
</tr>
</table>
</form>
效果如图:
因为分页显示一般都会伴有查询条件和查询动作,页面应已经有校验查询条件和提交查询的javascript方法(如上面的doQuery),所以RowSetPage.getHTML()生成的分页代码在用户选择新页码时直接回调前面的处理提交查询的javascript方法。注意在显示查询结果的时候上次的查询条件也需要保持,如<input type=text name=gender size=1 value="<%=request.getParameter("gender")%>">。同时由于页码的参数名可以指定,因此也支持在同一页面中有多个分页区。
另一种分页代码实现是生成每一页的URL,将查询参数和页码作为QueryString附在URL后面。这种方法的缺陷是在查询条件比较复杂时难以处理,并且需要指定处理查询动作的servlet,可能不适合某些定制的查询 *** 作。
如果对RowSetPage.getHTML()生成的默认分页代码不满意可以编写自己的分页处理代码,RowSetPage提供了很多getter方法用于获取相关信息(如当前页码、总页数、 总记录数和当前记录数等)。
在实际应用中可以将分页查询和显示做成jsp taglib, 进一步简化JSP代码,屏蔽Java Code。
附:分页工具类的源代码, 有注释,应该很容易理解。
1.Page.java
2.RowSetPage.java(RowSetPage继承Page)
3.PagedStatement.java
4.PagedStatementOracleImpl.java(PagedStatementOracleImpl继承PagedStatement)
您可以任意使用这些源代码,但必须保留author evan_zhao@hotmail.com字样
///////////////////////////////////
//
// Page.java
// author: evan_zhao@hotmail.com
//
///////////////////////////////////
package page
import java.util.List
import java.util.ArrayList
import java.util.Collection
import java.util.Collections
/**
* Title: 分页对象<br>
* Description: 用于包含数据及分页信息的对象<br>
* Page类实现了用于显示分页信息的基本方法,但未指定所含数据的类型,
* 可根据需要实现以特定方式组织数据的子类,<br>
* 如RowSetPage以RowSet封装数据,ListPage以List封装数据<br>
* Copyright: Copyright (c) 2002 <br>
* @author evan_zhao@hotmail.com <br>
* @version 1.0
*/
public class Page implements java.io.Serializable {
public static final Page EMPTY_PAGE = new Page()
public static final int DEFAULT_PAGE_SIZE = 20
public static final int MAX_PAGE_SIZE = 9999
private int myPageSize = DEFAULT_PAGE_SIZE
private int start
private int avaCount,totalSize
private Object data
private int currentPageno
private int totalPageCount
/**
* 默认构造方法,只构造空页
*/
protected Page(){
this.init(0,0,0,DEFAULT_PAGE_SIZE,new Object())
}
/**
* 分页数据初始方法,由子类调用
* @param start 本页数据在数据库中的起始位置
* @param avaCount 本页包含的数据条数
* @param totalSize 数据库中总记录条数
* @param pageSize 本页容量
* @param data 本页包含的数据
*/
protected void init(int start, int avaCount, int totalSize, int pageSize, Object data){
this.avaCount =avaCount
this.myPageSize = pageSize
this.start = start
this.totalSize = totalSize
this.data=data
//System.out.println("avaCount:"+avaCount)
//System.out.println("totalSize:"+totalSize)
if (avaCount>totalSize) {
//throw new RuntimeException("记录条数大于总条数?!")
}
this.currentPageno = (start -1)/pageSize +1
this.totalPageCount = (totalSize + pageSize -1) / pageSize
if (totalSize==0 &&avaCount==0){
this.currentPageno = 1
this.totalPageCount = 1
}
//System.out.println("Start Index to Page No: " + start + "-" + currentPageno)
}
public Object getData(){
return this.data
}
/**
* 取本页数据容量(本页能包含的记录数)
* @return 本页能包含的记录数
*/
public int getPageSize(){
return this.myPageSize
}
/**
* 是否有下一页
* @return 是否有下一页
*/
public boolean hasNextPage() {
/*
if (avaCount==0 &&totalSize==0){
return false
}
return (start + avaCount -1) <totalSize
*/
return (this.getCurrentPageNo()<this.getTotalPageCount())
}
/**
* 是否有上一页
* @return 是否有上一页
*/
public boolean hasPreviousPage() {
/*
return start >1
*/
return (this.getCurrentPageNo()>1)
}
/**
* 获取当前页第一条数据在数据库中的位置
* @return
*/
public int getStart(){
return start
}
/**
* 获取当前页最后一条数据在数据库中的位置
* @return
*/
public int getEnd(){
int end = this.getStart() + this.getSize() -1
if (end<0) {
end = 0
}
return end
}
/**
* 获取上一页第一条数据在数据库中的位置
* @return 记录对应的rownum
*/
public int getStartOfPreviousPage() {
return Math.max(start-myPageSize, 1)
}
/**
* 获取下一页第一条数据在数据库中的位置
* @return 记录对应的rownum
*/
public int getStartOfNextPage() {
return start + avaCount
}
/**
* 获取任一页第一条数据在数据库中的位置,每页条数使用默认值
* @param pageNo 页号
* @return 记录对应的rownum
*/
public static int getStartOfAnyPage(int pageNo){
return getStartOfAnyPage(pageNo, DEFAULT_PAGE_SIZE)
}
/**
* 获取任一页第一条数据在数据库中的位置
* @param pageNo 页号
* @param pageSize 每页包含的记录数
* @return 记录对应的rownum
*/
public static int getStartOfAnyPage(int pageNo, int pageSize){
int startIndex = (pageNo-1) * pageSize + 1
if ( startIndex <1) startIndex = 1
//System.out.println("Page No to Start Index: " + pageNo + "-" + startIndex)
return startIndex
}
/**
* 取本页包含的记录数
* @return 本页包含的记录数
*/
public int getSize() {
return avaCount
}
/**
* 取数据库中包含的总记录数
* @return 数据库中包含的总记录数
*/
public int getTotalSize() {
return this.totalSize
}
/**
* 取当前页码
* @return 当前页码
*/
public int getCurrentPageNo(){
return this.currentPageno
}
/**
* 取总页码
* @return 总页码
*/
public int getTotalPageCount(){
return this.totalPageCount
}
/**
*
* @param queryJSFunctionName 实现分页的JS脚本名字,页码变动时会自动回调该方法
* @param pageNoParamName 页码参数名称
* @return
*/
public String getHTML(String queryJSFunctionName, String pageNoParamName){
if (getTotalPageCount()<1){
return "<input type='hidden' name='"+pageNoParamName+"' value='1' >"
}
if (queryJSFunctionName == null || queryJSFunctionName.trim().length()<1) {
queryJSFunctionName = "gotoPage"
}
if (pageNoParamName == null || pageNoParamName.trim().length()<1){
pageNoParamName = "pageno"
}
String gotoPage = "_"+queryJSFunctionName
StringBuffer html = new StringBuffer("\n")
html.append("<script language=\"Javascript1.2\">\n")
.append("function ").append(gotoPage).append("(pageNo){ \n")
.append( " var curPage=1\n")
.append( " try{ curPage = document.all[\"")
.append(pageNoParamName).append("\"].value\n")
.append( " document.all[\"").append(pageNoParamName)
.append("\"].value = pageNo\n")
.append( " ").append(queryJSFunctionName).append("(pageNo)\n")
.append( " return true\n")
.append( " }catch(e){ \n")
// .append( " try{ \n")
// .append( " document.forms[0].submit()\n")
// .append( " }catch(e){ \n")
.append( " alert('尚未定义查询方法:function ")
.append(queryJSFunctionName).append("()')\n")
.append( " document.all[\"").append(pageNoParamName)
.append("\"].value = curPage\n")
.append( " return false\n")
// .append( " } \n")
.append( " } \n")
.append( "}")
.append( "</script>\n")
.append( "")
html.append( "<table border=0 cellspacing=0 cellpadding=0 align=center width=80%>\n")
.append( " <tr>\n")
.append( " <td align=left><br>\n")
html.append( " 共" ).append( getTotalPageCount() ).append( "页")
.append( " [") .append(getStart()).append("..").append(getEnd())
.append("/").append(this.getTotalSize()).append("] \n")
.append( " </td>\n")
.append( " <td align=right>\n")
if (hasPreviousPage()){
html.append( "[<a href='javascript:").append(gotoPage)
.append("(") .append(getCurrentPageNo()-1)
.append( ")'>上一页</a>] \n")
}
html.append( " 第")
.append( " <select name='")
.append(pageNoParamName).append("' onChange='javascript:")
.append(gotoPage).append("(this.value)'>\n")
String selected = "selected"
for(int i=1i<=getTotalPageCount()i++){
if( i == getCurrentPageNo() )
selected = "selected"
else selected = ""
html.append( " <option value='").append(i).append("' ")
.append(selected).append(">").append(i).append("</option>\n")
}
if (getCurrentPageNo()>getTotalPageCount()){
html.append( " <option value='").append(getCurrentPageNo())
.append("' selected>").append(getCurrentPageNo())
.append("</option>\n")
}
html.append( " </select>页 \n")
if (hasNextPage()){
html.append( " [<a href='javascript:").append(gotoPage)
.append("(").append((getCurrentPageNo()+1))
.append( ")'>下一页</a>] \n")
}
html.append( "</td></tr></table>\n")
return html.toString()
}
}
///////////////////////////////////
//
// RowSetPage.java
// author: evan_zhao@hotmail.com
//
///////////////////////////////////
package page
import javax.sql.RowSet
/**
* <p>Title: RowSetPage</p>
* <p>Description: 使用RowSet封装数据的分页对象</p>
* <p>Copyright: Copyright (c) 2003</p>
* @author evan_zhao@hotmail.com
* @version 1.0
*/
public class RowSetPage extends Page {
private javax.sql.RowSet rs
/**
*空页
*/
public static final RowSetPage EMPTY_PAGE = new RowSetPage()
/**
*默认构造方法,创建空页
*/
public RowSetPage(){
this(null, 0,0)
}
/**
*构造分页对象
*@param crs 包含一页数据的OracleCachedRowSet
*@param start 该页数据在数据库中的起始位置
*@param totalSize 数据库中包含的记录总数
*/
public RowSetPage(RowSet crs, int start, int totalSize) {
this(crs,start,totalSize,Page.DEFAULT_PAGE_SIZE)
}
/**
*构造分页对象
*@param crs 包含一页数据的OracleCachedRowSet
*@param start 该页数据在数据库中的起始位置
*@param totalSize 数据库中包含的记录总数
*@pageSize 本页能容纳的记录数
*/
public RowSetPage(RowSet crs, int start, int totalSize, int pageSize) {
try{
int avaCount=0
if (crs!=null) {
crs.beforeFirst()
if (crs.next()){
crs.last()
avaCount = crs.getRow()
}
crs.beforeFirst()
}
rs = crs
super.init(start,avaCount,totalSize,pageSize,rs)
}catch(java.sql.SQLException sqle){
throw new RuntimeException(sqle.toString())
}
}
/**
*取分页对象中的记录数据
*/
public javax.sql.RowSet getRowSet(){
return rs
}
}
///////////////////////////////////
//
// PagedStatement.java
// author: evan_zhao@hotmail.com
//
///////////////////////////////////
package page
import foo.DBUtil
import java.math.BigDecimal
import java.util.List
import java.util.Iterator
import java.util.Collections
import java.sql.Connection
import java.sql.SQLException
import java.sql.ResultSet
import java.sql.Statement
import java.sql.PreparedStatement
import java.sql.Timestamp
import javax.sql.RowSet
/**
* <p>Title: 分页查询</p>
* <p>Description: 根据查询语句和页码查询出当页数据</p>
* <p>Copyright: Copyright (c) 2002</p>
* @author evan_zhao@hotmail.com
* @version 1.0
*/
public abstract class PagedStatement {
public final static int MAX_PAGE_SIZE = Page.MAX_PAGE_SIZE
protected String countSQL, querySQL
protected int pageNo,pageSize,startIndex,totalCount
protected javax.sql.RowSet rowSet
protected RowSetPage rowSetPage
private List boundParams
/**
* 构造一查询出所有数据的PageStatement
* @param sql query sql
*/
public PagedStatement(String sql){
this(sql,1,MAX_PAGE_SIZE)
}
/**
* 构造一查询出当页数据的PageStatement
* @param sql query sql
* @param pageNo 页码
*/
public PagedStatement(String sql, int pageNo){
this(sql, pageNo, Page.DEFAULT_PAGE_SIZE)
}
/**
* 构造一查询出当页数据的PageStatement,并指定每页显示记录条数
* @param sql query sql
* @param pageNo 页码
* @param pageSize 每页容量
*/
public PagedStatement(String sql, int pageNo, int pageSize){
this.pageNo = pageNo
this.pageSize = pageSize
this.startIndex = Page.getStartOfAnyPage(pageNo, pageSize)
this.boundParams = Collections.synchronizedList(new java.util.LinkedList())
this.countSQL = "select count(*) from ( " + sql +") "
this.querySQL = intiQuerySQL(sql, this.startIndex, pageSize)
}
/**
*生成查询一页数据的sql语句
*@param sql 原查询语句
*@startIndex 开始记录位置
*@size 需要获取的记录数
*/
protected abstract String intiQuerySQL(String sql, int startIndex, int size)
/**
*使用给出的对象设置指定参数的值
*@param index 第一个参数为1,第二个为2
位置与规模圆明园坐落在北京西郊海淀区,与颐和园紧相毗邻。它始建于康熙46年(1709年),由圆明、长春、万春三园组成。有园林风景百余处,建筑面积逾16万平方米,是清朝帝王在150余年间创建和经营的一座大型皇家宫苑。清王朝倾全国物力,集无数精工巧匠,填湖堆山,种植奇花异木,集国内外名胜40景,建成大型建筑物145处,内收难以数计的艺术珍品和图书文物。在这些建筑中,除具有中国风格的庭院外,长春园内还有海晏堂、远瀛观等西洋风格的建筑群,被誉为“万园之园”。1860年,英法联军攻入北京,将圆明园烧毁。1900年八国联军入侵北京烧杀掳掠,慈禧太后挟光绪皇帝逃奔西安,八旗兵丁,土匪地痞即趁火打劫把园残存和陆续基本修复的共约近百座建筑物,皆拆抢一空,使圆明园的建筑和古树名木遭到彻底毁灭。其后,圆明园的遗物,又长期遭到官僚、军阀、奸商巧取豪夺,乃至政府当局的有组织地损毁。北洋政府的权贵们包括某些对圆明园遗址负有保护责任者,都倚仗权势,纷纷从圆明园内运走石雕 、太湖石等,以修其园宅。那侵略者不仅抢夺了那珍贵的历史文物,而且毫不留情地把它化成灰烬。圆明园占地350公顷,其中水面面积约140公顷,圆明园的陆上建筑面积比故宫还多一万平方米,水域面积又等于一个颐和园,总面积竟等于8.5个紫禁城!
它继承了中国三千多年的优秀造园传统,既有宫廷建筑的雍容华贵,又有江南水乡园林的委婉多姿,同时,又吸取了欧洲的园林建筑形式,把不同风格的园林建筑融为一体,在整体布局上使人感到和谐完美。真可谓:"虽由人做,宛自天开"。圆明园不仅以园林著称,而且也是一座收藏相当丰富的皇家博物馆。法国大作家雨果曾说:"即使把我国所有博物馆的全部宝物加在一起,也不能同这个规模宏大而富丽堂皇的东方博物馆媲美"。园内各殿堂内装饰有难以计数的紫檀木家具,陈列有许多国内外稀世文物。园中文源阁是全国四大皇家藏书楼之一。园中各处藏有《四库全书》、《古今图书集成》、《四库全书荟要》等珍贵图书文物。
圆明园,曾以其宏大的地域规模、杰出的营造技艺、精美的建筑景群、丰富的文化收藏和博大精深的民族文化内涵而享誉于世,被誉为“一切造园艺术的典范”和“万园之园”。
1860年10月6日英法联军洗劫圆明园,文物被劫掠,17日-19日,园中的建筑被烧毁。曾经奇迹和神话般的圆明园变成一片废墟,只剩断垣残壁,供游人凭吊。
名称由来:
“圆明园”,是由康熙皇帝命名的。玄烨御书三字匾牌,就悬挂在圆明园殿的门楣上方。对这个园名雍正皇帝有个解释,说“圆明”二字的含义是:“圆而入神,君子之时中也;明而普照,达人之睿智也。”意思是说,“圆”是指个人品德圆满无缺,超越常人;“明”是指政治业绩明光普照,完美明智。这可以说是封建时代统治阶级标榜明君贤相的理想标准。
另外,“圆明”是雍正皇帝自皇子时期一直使用的佛号,雍正皇帝崇信佛教,号“圆明居士”,并对佛法有很深的研究。著有《御选语录》19卷和《御制拣魔辨异录》。在清初的佛教宗派格局中,雍正皇帝以禅门宗匠自居,并以“天下主”的身份对佛教施以影响,努力提倡“三教合一”和“禅净合一”,是佛教发展史上非常重要的人物。康熙皇帝在把园林赐给胤禛(后为雍正皇帝)时,亲题园名为“圆明园”正是取意于雍正的佛号“圆明”。
园林建筑特色:
圆明园汇集了当时江南若干名园胜景的特点,融中国古代造园艺术之精华,以园中之园的艺术手法,将诗情画意融化于千变万化的景象之中。圆明园的南部为朝廷区,是皇帝处理公务之所,其中最著名的有上朝听政的正大光明殿。其余地区则分布着40个景区,其中有50多处景点直接模仿外地的名园胜景,如海宁的安澜园.杭州西湖的平湖秋月、雷峰夕照,苏州的狮子林........不仅模仿建筑,连名字也照搬过来。还有祭祀祖先的安佑宫,举行宴会的山高水长楼,模拟《仙山楼阁图》的蓬莱瑶台,再现《桃花源记》境界的武陵春色。更有趣的是,圆明园中还建有西洋式园林景区。最有名的“大水法”,是一座西洋喷泉,还有万花阵迷宫以及海晏堂等,都具有意大利文艺复兴时期的风格。在湖水中还有一个威尼斯城模型,皇帝坐在岸边山上便可欣赏万里之外的“水城风光”。
艺术特色:
圆明园是一座珍宝馆,还是一座当时世界上最大的皇家博物馆、艺术馆,收藏着许多珍宝、图书和艺术杰作。里面藏有名人字画、秘府典籍、钟鼎宝器、金银珠宝等稀世文物,集中了古代文化的精华。圆明园也是一座异木奇花之园,名贵花木多达数百万株。完整目睹过圆明园的西方人把她称为“万园之王”。
此外,圆明园也是除紫禁城外帝王居住过最多的地方。
[编辑本段]【历史发展】
圆明园是清代著名的皇家园林。圆明三园面积五千二百余亩,一百五十余景。圆明园最初是康熙皇帝赐给皇四子胤禛(即后来的雍正皇帝)的花园。在康熙四十六年即公元1707年时,园已初具规模。同年十一月,康熙皇帝曾亲临圆明园游赏。雍正皇帝于1723年即位后,拓展原赐园,并在园南增建了正大光明殿和勤正殿以及内阁、六部、军机处诸值房,御以"避喧听政"。乾隆皇帝在位60年,对圆明园岁岁营构,日日修华,浚水移石,费银千万。他除了对圆明园进行局部增建、改建之外,并在紧东邻新建了长春园,在东南邻并入了绮春园。至乾隆三十五年即1770年,圆明三园的格局基本形成。嘉庆朝,主要对绮春园进行修缮和拓建,使之成为主要园居场所之一。道光朝时,国事日衰,财力不足,但宁撤万寿、香山、玉泉"三山"的陈设,罢热河避暑与木兰狩猎,仍不放弃圆明三园的改建和装饰。
·康熙时期:
康熙四十八年(1709年),康熙帝(即清圣祖玄烨)将北京西北郊畅春园北一里许的一座园林赐给第四子胤禛,并亲题园额“圆明园”。
·雍正时期:
雍正三年(1725年),雍正帝(即清世宗胤禛)在圆明园南面增建宫殿衙署,占地面积由原来的六百余亩扩大到三千余亩。此后,圆明园不仅是清朝皇帝休憩游览的地方,也是他们朝会大臣、接见外国使节、处理日常政务的场所。
·乾隆时期:
乾隆帝(即清高宗弘历)即位后,在圆明园内调整了园林的景观,增添了建筑组群,并在圆明园的东邻和东南邻兴建了长春园和绮春园(同治时改名万春园)。这三座园林,均属于圆明园管理大臣管理,称圆明三园。
·咸丰时期:
咸丰十年(1860年)8月,英法联军攻入北京。10月6日,占领圆明园。从第二天开始,军官和士兵就疯狂地进行抢劫和破坏。为了迫使清政府尽快接受议和条件,英国公使额尔金、英军统帅格兰特以清政府曾将英法被俘人员囚禁在圆明园为借口,命令米切尔中将于10月18日率领侵略军三千五百余人直趋圆明园,纵火焚烧。这场大火持续了三天三夜。
·同治时期以后:
同治年间(1862~1874年),同治帝准备修复圆明园,供慈禧太后居住。后因财政困难,被迫停止,改建其他建筑。1900年,八国联军侵入北京,圆明园又一次遭到破坏。清朝覆灭后,一些军阀、政客、官僚,纷纷从圆明园盗运建筑材料,圆明园遗址遭到进一步破坏。
·中华人民共和国时期:
中华人民共和国成立后,国家十分重视圆明园遗址的保护。1979年,圆明园遗址被列为北京市重点文物保护单位。之后,圆明园遗址的整修工作逐步展开。现被辟为圆明园遗址公园。
[编辑本段]【建造情况】
·历史背景:
满族世代繁衍生息在东北黑龙江流域。17世纪中叶,大举进兵华北,彻底推翻了明王朝,自东北入关定都北京,夺取全国政权,建立了历史上最后一个封建统治王朝——清朝,由于清朝统治者入关以前在东北过着游牧生活,冬季那里是林海雪原,夏季则气候凉爽。入关后,他们对北京盛夏干燥炎热的气候很不适应。紫禁城虽金碧辉煌、宏伟壮丽,但清朝皇帝感到那里呆板憋闷,特别是在康熙初年,紫禁城发生过火灾后,为了防火,也为了防止暴乱,砌了高高的宫墙。皇宫里院院相套,再加上溪沟水流过于平缓,几乎成了死水,当时对皇城曾有“红墙,绿瓦,黑阴沟”之称。这使得皇帝们有些厌倦深囿高墙的宫廷生活,于是,从康熙初年,便开始修建园林,这种修建工程延续了二百多年。
·地形特征及历代建筑对兴建圆明园的影响:
北京的西郊,有连绵不断的西山秀峰:玉泉山、万寿山、万泉庄、北海淀等多种地形,自流泉遍地皆是,在低洼处汇成大大小小的湖泊池沼。玉泉山水自西向东顺山势注入昆明湖,成为西郊最大的水面。这里开垦了大片水稻田,形成了自然风景区。早在辽代,封建帝王就选中这里建造了玉泉山行宫,到了明代,这里的自然景色吸引了更多的游人,于是一些达官贵人就占据田园营建别墅,大片土地被一块块占去。到了明万历年间,明皇亲武清侯李伟在这里大兴土木,首先建造了规模宏伟,号称“京国第一名园”的清华园(故址在今北京大学西墙外)。嗣后米万钟又在清华园东墙外导引湖水,辟治了幽雅秀丽的“勺园”,取“海淀一勺”的意思。空旷郊野,出现了亭台楼榭与湖光山色交相辉映,成为京郊名噪一时的园林荟集之地。到了清朝,皇帝也同样看中了西郊这块绝好的造园之地。开始大规模地兴建园林。
·圆明园建造的实施:
圆明园的位置在挂甲屯的北面,距畅春园约一里多路,即今北京大学的北边,清华大学以西。康熙时代的圆明园,里面有前湖、后湖等水面,其内建有“牡丹台”、“天然图画”等园景。当圆明园还是一座藩赐园的时候,规模是不能超过皇帝的畅春园的,所以建景不多,名声也不大,远远比不上畅春园。可后来随着主人的登基,清王朝的太平盛世到来,在其60多年陆续扩建中,终于建成了中国有史以来最宏伟的皇家园林。
圆明园的总设计师名叫雷金玉,他是在修建紫禁城时被康熙看中但在实际建造中大多还是皇帝的看法,不论是康熙、雍正还是乾隆都亲自指导,因此雷金玉异常欣喜。并创造了“烫板”的模型方法。而却被咸丰毁于一旦。
[编辑本段]【园林结构】
历史上的圆明园,是由圆明园、长春园、绮春园(万春园)组成。三园紧相毗连,通称圆明园。共占地5,200余亩(约350公顷),比颐和园的整个范围还要大出近千亩。是清代封建帝王在150余年间,所创建和经营的一座大型皇家宫苑。雍正、乾隆、嘉庆、道光、咸丰五朝皇帝,都曾长年居住在圆明园优游享乐,并于此举行朝会,处理政事,与紫禁城(故宫)同为当时的全国政治中心,被清帝特称为“御园”。光是悬挂了匾牌的就有600余座。
·圆明园:
主要兴建于康熙末年和雍正朝,至雍正末年,园林风景群已遍及全园三千亩范围。乾隆年间,在园内相继又有多处增建和改建。该园的主要园林风景群,有著名的“圆明园四十景”(即正大光明、勤政亲贤、九洲清晏、缕月开云、天然图画、碧桐书院、慈云普护、上下天光、杏花春馆、坦坦荡荡、茹古涵今、长春仙馆、万方安和、武陵春色、山高水长、月地云居、鸿慈永祜、汇芳书院、日天琳字、澹泊宁静、映水兰香、水木明瑟、濂溪乐处、多稼如云、鱼跃鸢飞、北远山村、西峰秀色、四宜书屋、方壶胜境、澡身浴德、平湖秋月、蓬岛瑶台、接秀山房、别有洞天、夹境鸣琴、涵虚朗鉴、廓然大公、坐石临流、曲院风荷、洞天深处),以及紫碧山房、藻园、若帆之阁、文源阁等处。当时悬挂匾额的主要园林建筑约达600座,实为古今中外皇家园林之冠。
·万春园:
早先原是怡亲王允祥的赐邸,约于康熙末年始建,后曾改赐大学士傅恒,至乾隆三十五年(1770年)正式归入御园,定名绮春园。那时的范围尚不包括其西北部。嘉庆四年和十六年,该园的西部又先后并进来两处赐园,一是成亲王永瑆的西爽村,一是庄敬和硕公主的含晖园,经大规模修缮和改建、增建之后,该园始具千亩规模,成为清帝园居的主要园林之一。至此,圆明三园处于全盛时期。嘉庆先有“绮春园三十景”诗,后又陆续新成20多景,当时比较著名的园林景群有敷春堂、清夏斋、涵秋馆、生冬室、四宜书屋、春泽斋、凤麟洲、蔚藻堂、中和堂、碧享、竹林院、喜雨山房、烟雨楼、含晖楼、澄心堂、畅和堂、湛清轩、招凉榭、凌虚亭等近30处。悬挂匾额的园林建筑有百余座。绮春园宫门,建成于嘉庆十四年(1809年),因它比圆明园大宫门和长春园二宫门晚建半个多世纪,亦称“新宫门”,一直沿用至今。自道光初年起,该园东路的敷春堂一带经改建后,作为奉养皇太后的地方;但园西路诸景,仍一直是道光、咸丰皇帝的园居范围。该园1860年被毁后,在同治年间试图重修时,改称万春园。
洋楼景区,长春园共占地一干亩。悬挂匾额的园林建筑约为200座。
·西洋楼 :
清帝为了追求多方面的乐趣,在长春园北界还引进了一区欧式园林建筑,俗称“西洋楼”,由谐奇趣、线法桥、万花阵、养雀笼、方外观、海晏堂、远瀛观、大水法、观水法、线法山和线法墙等十余个建筑和庭园组成。于乾隆十二年(1747年)开始筹划,至二十四年(1759年)基本建成。由西方传教土郎世宁、蒋友仁、王致诚等设计指导,中国匠师建造。建筑形式是欧洲文艺复兴后期“巴洛克”风格,造园形式为“勒诺特”风格。但在造园和建筑装饰方面也吸取了中国不少传统手法。建筑材料多用汉白玉石,石面精雕细刻,屋顶覆琉璃瓦。西洋楼的主体,其实就是人工喷泉,时称“水法”。特点是数量多、气势大、构思奇恃。主要形成谐奇趣、海晏堂和大水法三处大型喷泉群。
西洋楼景区整个占地面积不起过圆明三园总占地面积的五十分之一,只是一个很小的局部而已。但它却是成片仿建欧式园林的一次成功尝试。这在东西方园林交流史上,占有重要地位。曾在欧洲引起强烈反响。一位目睹过它的西欧传教土赞誉西洋楼:集美景佳趣于一处,凡人们所能幻想到的、宏伟而奇特的喷泉应有尽有,其中最大者,可以与凡尔赛宫及圣克劳教堂的喷泉并驾齐驱。这位传教士的结论是:圆明园者,中国之凡尔赛宫。
[编辑本段]【圆明园主要景致】
【大宫门】 大宫门共5间,南向,门前有大型月台,东、西朝房各5间;房后另有曲尺型拐角朝房各27间;东为宗人府、内阁、礼部、吏部、兵部、都察院、理藩院、翰林院、詹事府、国子监、銮仪卫、东四旗各值房;西为户部、刑部、工部、钦天监、内务府、光禄寺、通政司、大理寺、鸿胪寺、太常寺、太仆寺、御书处、上驷院、武备院、西四旗各值房。
【正大光明殿】 正大光明殿是圆明园的正殿,皇帝每年举行生日受贺、新正曲宴亲藩、小宴廷臣、中元筵宴、观庆龙舞、大考翰詹、散馆乡试及复试的地方。殿上悬雍正手书“正大光明”匾额,殿堂7间,前面有宽大的月台,东、西配殿各5间。
【勤政亲贤殿】 勤政亲贤殿即养心殿西暖阁前室,位于正大光明殿东面,为盛暑时皇帝办公之处,有殿堂5间。北设宝座,南为窗,东有板墙开门,与养心殿明间相通,为皇帝召见大臣之所。窗外抱厦内围有木屏,与明间相隔,较为隐秘。现为宫廷生活原状陈列。
养心殿的西暖阁,是皇帝处理日常政务,单独接见大臣,批阅殿试考卷的地方。暖阁的北墙上悬挂着雍正皇帝题写的匾额:“勤政亲贤”匾下的屏文是乾隆皇帝的诗篇。
一心奚所托,为君止于仁。
二典传家法,敬天及勤民。
三无凛然奉,大公何私亲。
四序协时月,熙绩在抚辰。
五事惟敬用,其要以备身。
六府赖修治,其施均养人。
七情时省察,惧为私欲沦。
八珍有费甘,念彼饥饿伦。
九歌扬政要,郑卫漫亟陈。
十联书屏扆,式听师保谆。
最大的建筑——勤政亲贤殿,位于西面一套院落中,它前面有宫门和垂花门,垂花门内是一个大院落,勤政亲贤殿就居于这座院落的正北。“勤政殿”是一座面阔四间的大殿,里面显得特别宽阔。殿内正中设有皇帝的御座,御座后面是一具高大的屏风,屏风上有乾隆帝弘历手书“无逸”二字。殿内撰满了紫檀雕镂的桌椅,其雕镂的花样有岁寒三友、花卉翎毛、山水人物,割工精巧,造型逼真。椅子和床榻上铺着绣有五爪金龙的黄缎子椅披和垫褥。殿内房间的间隔,全是精雕细镂的紫檀壁板,御座两旁设有书架和存放卷册典藉的书柜。乾隆时期,弘历在这里批阅奏章,召见臣僚。夏天,为避暑热乾隆又把办公和进餐的地方由“勤政殿”搬到殿东的“芳碧丛”,因为芳碧丛前面庭院里奇石林立,翠竹掩吹,凉爽宜人。芳碧丛的北面也是—个大院落,院中假山石、湖石很多,又种有芭蕉,海棠等富有南国情趣的观赏花木。庭院中,常常可看见珍贵的丹顶鹤在石间花术丛中剔翎摆翅,悠然自乐。两边廊屋檐下的精致雀笼里的各种珍禽,不时发出清脆悦耳的鸣声。
【九州清晏】 九州清晏位于前湖北岸与正大光明殿隔湖相望,由三进南向大殿组成,第一进为圆明园殿,中间为奉三无私殿,最北为九州清晏殿;中轴东有"天地一家春",为道光出生处;西有“乐安和”,是乾隆的寝宫;再西有清晖阁,北壁悬挂巨幅圆明园全景图,原图现存法国巴黎博物馆;道光十年又在“怡情书史”附近建起“慎德堂”等殿宇,都是皇帝寝宫;道光十六年,圆明园殿、奉三无私殿、九州清晏殿。同时被火焚烧;雍正帝、道光帝都死在九州清晏殿。
【长春仙馆】 长春仙馆,建于乾隆九年,公元一七四四年。长春仙馆位于前湖西面,乾隆即位前曾居于此,有殿门3间,正殿5间。
【镂月开云】镂月开云原称牡丹亭,位于后湖东南角,建筑木料以捕木为主,殿顶覆二色琉璃瓦;乾隆即位后,改称“镂月开云”,乾隆三十一年,又亲题"纪思堂"匾额;院内植各色牡丹数百株。
【碧桐书院】碧桐书院,建于乾隆九年,公元一七四四年。位于后湖东北角,是一座书房。【上下天光】 上下天光位于后湖西北,为两层楼宇,登楼可尽览湖光水色。
【杏花春馆】 杏花春馆位于上下天光西面,馆舍东西两面临湖,西院有杏花村,馆前有菜圃。
【坦坦荡荡】 坦坦荡荡紧靠后湖西岸,是圆明园中专设的养鱼区,四周建置馆舍,中间开凿大水池。
【万方安和】 万方安和位于杏花春馆西面,建于水上的字形大型殿堂楼宇,有33间。
【山高水长楼】 山高水长楼位于坦坦荡荡西面,为一座西向的两层楼房,上下各9间;前环小溪后拥连岗,中间地势平坦,是专门设宴招待外藩之处,也经常举行比武赛箭。
【同乐园】 同乐园位于后湖东北面,是园中最大的戏台,有清音阁3层,宽10丈,下层设演特技的机轴;南有化妆室5间,北有观戏楼5间;乾隆间每年从正月十三起在此举行酬节会,连日宴赏宗室王公及外藩陪臣并赏听戏,每逢皇帝生日,也在此演戏庆祝数日。
【安佑宫】 安佑宫位于圆明园西北隅,建于乾隆七年,完全仿建故宫太庙,殿内曾陈列康熙、雍正、乾隆遗像。
【水木明瑟】 水木明瑟位于后湖以北小园集聚区中央,仿扬州水竹居,内设水力土风扇,是园中最早的观水法。
【舍卫城】 舍卫城位于水木明瑟东面,是园中专门开辟的一座小城镇,仿照古印度桥萨罗国首都的城池布局而建,是供奉各种佛像和收藏佛经的地方。城廓呈长方形,南北长、东西宽,四周筑有城墙,共辟4门。城内街道呈十字形,内建殿宇、房舍共326间,用游廊相连接;还建有数座金碧辉煌的牌楼。城前专门开设一条贯穿南北的买卖街,称苏州街,由宫中太监扮作商人开市叫卖,法国教士王致诚对买卖街有比较详尽的记载。
【文源阁】 文源阁位于水木明瑟北面,原称四达亭,乾隆南巡浙江后,仿照宁波的明代藏书楼天一阁改建,专门贮藏《四库全书》。
【廓然大公】 廓然大公亦称双鹤斋,位于舍卫城东北面,是园中一组较大的建筑,主体建筑北濒大池,园内景色倒映水中犹然两景;另有诗咏堂、菱荷深处等景点。
【西峰秀色】 西峰秀色号称园中小庐山,仿照江西庐山改建;后垣的花港观鱼,仿照杭州西湖胜景而建。每年七夕,都在此摆设巧宴盛会。
【四宜书屋】 四宜书屋位于廓然大公东北面,有殿堂5间,正殿称安澜园,为乾隆南巡后,仿照杭州湾畔海宁一陈姓隅园改建。
【北远山村】 北远山村位于大北门内偏东,稻田遍布,各房舍名称都与农事有关,呈现浓郁田园景色。
【方壶胜境】 方壶胜境位于福海水面东北隅,为一座巨大的山字形楼宇。
【蓬莱瑶台】 蓬莱瑶台位于福海中央,共有三个岛,结构和布局根据古代画家李思训的“仙山楼阁”画设计;宫门3间,正殿7间,殿前东列畅襟楼,西列神洲三岛,东偏殿为随安室,西偏殿为日日平安报好音;东南面有一渡桥,可通东岛,岛上建有瀛海仙山小亭;西北面有一曲桥,可通北岛,岛上建殿宇3间。
【接秀山房】 接秀山房位于福海东南隅,内部装饰全部采用紫檀木漆器,上面都嵌以金银、宝石、象牙等,这些奇珍异宝上都镂刻着山水、楼阁、人物、花木、虫鸟。这种装饰,从设计到刻技都由明末杭州一周姓工匠所创始,故称周制,在我国雕刻史上占有重要地位。
【平湖秋月】 平湖秋月位于福海西北隅,造型上融汇了杭州西湖平湖秋月和双峰插云的精华。
【曲院风荷】 曲院风荷位于福海西岸同乐园南面,正殿一排5间,仿照杭州西湖曲院改建,跨池还有一座9孔大石桥。
【淳化轩】 淳化轩位居长春园正中的主体建筑,建成时适逢《重刻淳化阁贴》竣工,遂将刻板嵌于左右廊的廊壁上,轩并由此得名。《重刻淳化阁贴》刻板144块,共10卷,汇集历代名家99人的真迹;刻成后又拓400部,分赐皇室宗亲、大臣以及直隶、山东、浙江各行宫和名胜地。淳化轩因此成为北京地区著名碑林。
【海岳开襟】 海岳开襟建于水池中,台基为圆形,上下两层,汉白玉石凭栏围绕。台上建3层楼宇,下层为海岳开襟,南檐题“青瑶屿”3字;中层为得金阁,题“天心水面”4字;最上层题“乘六龙”3字;台的四面各设牌楼一座。在圆明园的所有楼阁中,这组建筑最为豪华。
【狮子林】 狮子林位于长春园东北隅,乾隆皇帝游苏州后,仿建苏州狮子林,先建8景,后续8景,共16景,形成一组别致的小园景区。
【如园】 如园位于长春园东南隅,乾隆三十二年南巡至江宁(今南京市)后,仿照明代大将徐达的瞻园建置。
【谐奇趣】 是乾隆十六年秋建成的第一座建筑,主体为三层,楼南有一大型海堂式喷水池,设有铜鹅、铜羊和西洋翻尾石鱼组成的喷泉。楼左右两侧,从曲廊伸出八角楼厅,是演奏中西音乐的地方。
【海晏堂】 是西洋楼最大的宫殿。主建筑正门向西,阶前有大型水池,池左右呈八字形排引有十二只兽面人身铜像(鼠、牛、虎、兔、龙、蛇、马、羊、猴、鸡、狗、猪,十二个属相),每昼夜依次辍流喷水,各一时辰(2小时),正午时刻,十二生肖一齐喷水,俗称“水力钟”。本来是以欧洲风格的裸体女人像,但乾隆皇帝觉得裸体女人不和中国的风俗就改为十二生肖铜像,用青铜制造。
【大水法】 是西洋楼最壮观的喷泉。建筑造形为石龛式,酷似门洞。下边有一大型狮子头喷水,形成七层水帘。前下方为椭圆菊花式喷水池,池中心有一只铜鹿,从鹿角喷水八道;两佣有十只铜狗,从口中喷出水柱,直射鹿身,溅起层层浪花。俗称“猎狗逐鹿”。大水法的左右前方,各有一座巨大的喷水塔,塔为方形,十三层,顶端喷出水柱,塔四周有八十八根铜管于,也都一齐喷水。当年,皇帝是坐在对面的观水法,观赏这一组喷泉的,英国使臣马戛尔尼、荷兰使臣得胜等,都曾在这里“瞻仰”过水法奇观。据说这处喷泉若全部开放,有如山洪爆发,声闻里许,在近处谈话须打手势,其壮观程度可想而知。
【观水法】 观水法位于远瀛观中轴线南端,主要建筑有安放皇帝宝座的台基,后面立高大的石雕围屏风,两边设巴克鲁门,门两侧各有一座巨型水塔和接收喷水的水池。池旁依势设置各种兽类,呈半圆形,表示兽战和林中逐鹿等游戏;喷水的管口安装有时钟,根据中国传统的计时方法,用12种动物的名字表示一天的12个时辰,每隔1时辰便有1兽的口中向池内喷射水。
【万花阵】 万花阵亦称黄花阵,是仿照欧洲的迷宫而建的花园。用四尺高的字图案的雕花砖墙,分隔成若干道迷阵,因而称作“万花阵”。虽然从入口到中心亭的直径距离不过30余米,但因为此阵易进难出,每当中秋之夜,清帝坐在阵中心的圆亭里,太监、宫女们手持黄色彩绸扎成的莲花灯,寻径飞跑,先到者便可领到皇帝的赏物。所以也叫黄花阵或黄花灯。清帝坐在高处,四望莲花灯东流西奔,引为乐事。
【线法山】 线法山和线法墙之间,有一条方河,在线法墙下设水箱,置威尼斯城的模型于水箱中,皇帝坐在线法山上观望。
[编辑本段]【建筑特色】
圆明园是人工创造的一处规模宏伟、景色秀丽的大型园林。平地叠山理水,精制园林建筑,广植树木花卉。以断续的山丘、曲折的水面及亭台、曲廊、洲岛、桥堤等,将广阔的空间分割成大小百余处山水环抱、意趣各不相同的风景群。园内水面约占三园总面积的十分之四,在平地上人工开凿大中小水面,由回环萦流的河道串联为一个完整的河湖水系。园内又缀叠有大大小小的土山250座,与水系相结合,水随山转,山因水活,构成了山复水转、层层叠叠的园林空间。使整个园林宛如江南水乡般的烟水迷离,虽由人做,宛自天开。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)