ホームページ データベース mysql チュートリアル 在SQL*Plus中启动和关闭Oracle数据库

在SQL*Plus中启动和关闭Oracle数据库

Jun 07, 2016 pm 05:04 PM

关闭数据库 与数据库启动一样,有几个可供选择的选项用于关闭数据库。无论在什么情况下,读者都需要弄清楚这些关闭选项

关闭数据库

        与数据库启动一样,有几个可供选择的选项用于关闭数据库。无论在什么情况下,读者都需要弄清楚这些关闭选项

关闭数据库的语法是:SHUTDOWN [ NORMAL | TRANSACTIONAL | IMMEDIATE | ABORT ]

注意:如果不在windows服务中事先关闭OracleDBControlSID,则使用shutdown或shutdown normal 来关闭数据库时没有相应结果,但其他几个选项有响应结果。

一、 NORMAL(正常)选项

        shutdown 和 shutdown normal 作用相同,使用带有normal选项的shutdown语句将以正常方式关闭数据库。用normal选项时,Oracle将执行如下操作:

        1、 阻止任何用户建立新的连接

        2、 等待当前所有正在建立连接的用户主动断开连接。正在连接的用户能够继续他们当前的工作,甚至能够提交新的事务。

        3、 一旦所有的用户都断开连接,才能进行关闭、卸载数据库,并终止例程。

注意:按这个选项关闭数据库,则在下次启动数据库时不需要进行任何恢复操作。

二、 TRANSACTIONAL(事务处理)选项

        transactional选项比normal选项稍微主动些,,他能在尽可能短的时间内关闭数据库。按transactional选项关闭数据库时,Oracle将等待所有未提交的事务完成后再关闭数据库。用transactional选项关闭数据库时,oracle将执行如下操作:

        1、 阻止任何用户建立新的连接,同时阻止当前连接的用户开始任何新的事务。

        2、 等待所有当前未提交的活动事务提交完毕,然后立即断开用户的连接。

        3、 一旦所有的用户都断开连接,才进行关闭、卸载数据库,并终止例程 。

注意:按这个选项关闭数据库,则在下次启动数据库时不需要进行任何恢复操作。

三、 IMMEDIATE(立即)选项

        通常在以下几种情况下需要使用该选项来关闭数据库

        1、 即将启动自动数据库备份操作

        2、 即将发生电力供应中断

        3、 数据库本身或者某个数据库应用程序发生异常,并且这时候无法通知用户主动断开连接,或者数据库用户本身无法制定断开操作

        使用IMMEDIATE选项关闭数据库时,Oracle将执行如下操作:

        1、 阻止任何用户建立新的连接,同时阻止当前连接的用户开始任何新的事务。

        2、 任何当前未提交的事务均被退回

        3、 Oracle不再等待用户主动断开连接,而是直接关闭、卸载数据库,并终止例程。

注意:按这个选项关闭数据库,则在下次启动数据库时不需要进行任何恢复操作。

四、 ABORT(终止)选项

        通常在以下情况下可以考虑使用abort选项来关闭数据库

        1、 数据库本身或者某个数据库应用程序发生异常,并且使用其他选项均无效

        2、 出现紧急情况,需要立刻关闭数据库

        3、 在启动数据库例程时产生错误

        用abort选项来关闭数据库时,Oracle将执行如下操作:

        1、 阻止任何用户建立新的连接,同时阻止当前连接的用户开始任何新的事务。

        2、 立即结束当前正在执行的SQL语句

        3、 任何未提交的事务均不被回退

        4、 立即断开所有的用户的连接,关闭、卸载数据库,并终止例程

注意:按这个选项来关闭数据库,由于当前未完成的事务并不会回退,所以可能会丢失一部分数据信息,并对数据库的完整性造成损坏,需要在下一次启动数据库的时候进行恢复。


启动数据库

        数据库有三种启动模式,分别代表启动数据库的三个步骤。当数据库管理员使用startup命令时,可以指定不同的选项来决定将数据库的启动推进到哪个启动模式。在进入某个模式后,可以使用alter database命令来将数据库提升到更高的启动模式,但是不能使数据库降低到前面的启动模式。

启动模式

说明

对应的界面提示信息

NOMOUNT

启动例程,但不装载数据库,即只完成启动步骤的第一步

Oracle例程已经启动

MOUNT

启动例程,装载数据库,但不打开数据库,即只完成启动步骤的第一步和第二步

Oracle例程已经启动

数据库装载完毕

OPEN

启动例程,装载数据库,打开数据库,即完成全部的三个步骤

Oracle例程已经启动

数据库装载完毕

数据库已经打开

启动数据库的语法是:STARTUP [ NOMOUNT | MOUNT | OPEN | FORSE ] [ RESTRICT ] [ PFILE = 'PFILE_NAME' ];

一、 NOMOUNT选项

        该选项只创建例程,但不装在数据库。Oracle读取参数文件,仅为例程创建各种内存结构和后台服务进程,用户能够与数据库进行通信,但不能使用数据库中的任何文件。

        如果要执行下列维护工作,就必须使用该选项来启动数据库:

        1、 运行一个创建新数据库的脚本

        2、 重建控制文件

注意:在该启动模式下,只能访问到那些与SGA区相关的数据字典视图,这些视图的信息都是从SGA区获取的,与数据库是否装载,是否打开无关。

二、 MOUNT选项

        该选项不仅创建历程,还装载数据库,但却不打开数据库。Oracle读取控制文件,并从中获取数据库名称、数据文件的位置、名称等数据库物理结构的信息,为下一步打开数据库做好准备。

        在这种模式下,仅数据库管理员可以通过部分命令修改数据库,用户还无法与数据库建立连接或会话。这在进行一些特定的数据库维护工作时是十分必要的。

        如果要执行下列维护工作,就必须使用该选项启动数据库:

        1、 重新命名、增加、删除数据文件和重做日志文件

        2、 执行数据库的完全恢复

        3、 改变数据库的归档模式

注意:在该模式下,除了可以访问那些与SGA区相关的数据字典视图以外,还可以访问到那些与控制文件相关的数据字典视图,这些视图信息都是从控制文件中获取的。 

三、 OPEN选项

        该选项不仅创建例程,还装载数据库,并且打开数据库。这是正常的启动模式。如果startup语句没有指定任何选项,那就是使用该选项进行德启动。

        将数据库设置为打开状态后,任何具有create session权限的用户都能连接到数据库,并且进行常规的数据访问操作。

四、 FORSE选项

        如果在正常方式启动数据库时遇到了困难,则可以使用FORSE选项启动。FORSE选项与正常启动选项之间的差别在于无论数据库处于什么模式,都可以使用该选项,即FORSE选项首先关闭异常数据库,然后在重新启动他,而不需要事先用shutdown语句关闭数据库。 

五、 RESTRICT选项

        用该选项启动数据库时,会将数据库启动到open模式,但此时只有拥有restricted session   权限的用户才能访问数据库。如果需要在数据库处于open模式下执行维护任务,又要保证此时其他用户不能再数据库上建立连接和执行任务,则需要使用restrict 选项来打开数据库,以便完成以下任务:

        1、 执行数据库数据的导入或导出操作

        2、 执行数据库装载操作(用SQL*Loader)

        3、 暂时阻止一般的用户使用数据

        4、 进行数据库移植或升级

        当工作进行完毕后,可以使用 alter system disable restrict session 语句来禁用restricted session,以便一般用户能连接并使用数据库。

六、 PFILE选项

        数据库例程在启动的时候必须读取一个初始化参数文件,oracle必须从初始化参数文件中获得有关例程的参数配置信息。如果在执行startup语句时没有指定pfile 选项,oracle将首先读取默认位置的服务器初始化参数文件(spfile),如果没有找到默认的服务器初始化参数文件,oracle将继续读取默认的文本初始化参数文件(pfile),如果也没有到文本初始化参数文件,启动就会失败。

        使用startup语句时可以通过pfile选项指定一个文本初始化参数文件。

linux

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Alter Tableステートメントを使用してMySQLのテーブルをどのように変更しますか? Alter Tableステートメントを使用してMySQLのテーブルをどのように変更しますか? Mar 19, 2025 pm 03:51 PM

この記事では、MySQLのAlter Tableステートメントを使用して、列の追加/ドロップ、テーブル/列の名前の変更、列データ型の変更など、テーブルを変更することについて説明します。

MySQL接続用のSSL/TLS暗号化を構成するにはどうすればよいですか? MySQL接続用のSSL/TLS暗号化を構成するにはどうすればよいですか? Mar 18, 2025 pm 12:01 PM

記事では、証明書の生成と検証を含むMySQL用のSSL/TLS暗号化の構成について説明します。主な問題は、セルフ署名証明書のセキュリティへの影響を使用することです。[文字カウント:159]

人気のあるMySQL GUIツール(MySQL Workbench、PhpMyAdminなど)は何ですか? 人気のあるMySQL GUIツール(MySQL Workbench、PhpMyAdminなど)は何ですか? Mar 21, 2025 pm 06:28 PM

記事では、MySQLワークベンチやPHPMyAdminなどの人気のあるMySQL GUIツールについて説明し、初心者と上級ユーザーの機能と適合性を比較します。[159文字]

MySQLの大きなデータセットをどのように処理しますか? MySQLの大きなデータセットをどのように処理しますか? Mar 21, 2025 pm 12:15 PM

記事では、MySQLで大規模なデータセットを処理するための戦略について説明します。これには、パーティション化、シャード、インデックス作成、クエリ最適化などがあります。

INNODBフルテキスト検索機能を説明します。 INNODBフルテキスト検索機能を説明します。 Apr 02, 2025 pm 06:09 PM

INNODBのフルテキスト検索機能は非常に強力であり、データベースクエリの効率と大量のテキストデータを処理する能力を大幅に改善できます。 1)INNODBは、倒立インデックスを介してフルテキスト検索を実装し、基本的および高度な検索クエリをサポートします。 2)一致を使用してキーワードを使用して、ブールモードとフレーズ検索を検索、サポートします。 3)最適化方法には、単語セグメンテーションテクノロジーの使用、インデックスの定期的な再構築、およびパフォーマンスと精度を改善するためのキャッシュサイズの調整が含まれます。

ドロップテーブルステートメントを使用してMySQLにテーブルをドロップするにはどうすればよいですか? ドロップテーブルステートメントを使用してMySQLにテーブルをドロップするにはどうすればよいですか? Mar 19, 2025 pm 03:52 PM

この記事では、ドロップテーブルステートメントを使用してMySQLのドロップテーブルについて説明し、予防策とリスクを強調しています。これは、バックアップなしでアクションが不可逆的であることを強調し、回復方法と潜在的な生産環境の危険を詳述しています。

外国の鍵を使用して関係をどのように表現しますか? 外国の鍵を使用して関係をどのように表現しますか? Mar 19, 2025 pm 03:48 PM

記事では、外部キーを使用してデータベース内の関係を表すことで、ベストプラクティス、データの完全性、および避けるべき一般的な落とし穴に焦点を当てています。

JSON列にインデックスを作成するにはどうすればよいですか? JSON列にインデックスを作成するにはどうすればよいですか? Mar 21, 2025 pm 12:13 PM

この記事では、クエリパフォーマンスを強化するために、PostgreSQL、MySQL、MongoDBなどのさまざまなデータベースでJSON列にインデックスの作成について説明します。特定のJSONパスのインデックス作成の構文と利点を説明し、サポートされているデータベースシステムをリストします。

See all articles