orcacle不同于mysql,可以随意创建数据库,操作数据,orcale中想自己创建一个数据库,首先得创建数据库的数据文件(参考步骤1)和临时文件,其次创建一个用户(参考步骤2),将用户与数据库文件关联,并赋予用户相应权限(参考步骤3)。而在连接数据库时,为了提供统一的连接方式,他们都对应于一个默认的数据库实例XE(对于XE版数据库来说)。
步骤1:
CREATE TABLESPACE monitor LOGGING DATAFILE 'E:\app\owner\oradata\orcl\monitor.dbf'
SIZE 100M AUTOEXTEND ON NEXT 32M MAXSIZE 500M EXTENT MANAGEMENT LOCAL; //创建monitor数据库数据文件
create temporary tablespace monitor_temp tempfile 'E:\app\owner\oradata\orcl\monitor_temp.dbf'
size 100m autoextend on next 32m maxsize 500m extent management local; //创建monitor数据库的临时文件
步骤2:
CREATE USER monitor IDENTIFIED BY monitor DEFAULT TABLESPACE monitor TEMPORARY TABLESPACE monitor_temp;
步骤3:
grant connect,resource,dba to monitor;
grant create session to monitor;
删除数据库;
DROP TABLESPACE monitor INCLUDING CONTENTS AND DATAFILES;
删除用户:
drop user monitor cascade;
查看数据库实力名:(首先切换到与该数据库相关联的用户账户中)
SQL> select instance_name from v$instance;
INSTANCE_NAME
----------------
orcl
切换账户:
切换用户
SQL>conn 用户名/密码
注:conn同connect
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
public class ConnectionToOracle1 {
/**
* 一个非常标准的连接Oracle数据库的示例代码
*/
public static void main(String[] args) {
testOracle();
}
public static void testOracle()
{
Connection con = null;// 创建一个数据库连接
PreparedStatement pre = null;// 创建预编译语句对象,一般都是用这个而不用Statement
ResultSet result = null;// 创建一个结果集对象
try
{
Class.forName("oracle.jdbc.driver.OracleDriver");// 加载Oracle驱动程序
System.out.println("开始尝试连接数据库!");
String url = "jdbc:oracle:" + "thin:@127.0.0.1:1521:xe";// 127.0.0.1是本机地址,XE是精简版Oracle的默认数据库名
String user = "monitor";// 用户名,系统默认的账户名
String password = "monitor";// 你安装时选设置的密码
con = DriverManager.getConnection(url, user, password);// 获取连接
System.out.println("连接成功!");
// String sql = "select * from student where name=?";// 预编译语句,“?”代表参数
// pre = con.prepareStatement(sql);// 实例化预编译语句
// pre.setString(1, "刘显安");// 设置参数,前面的1表示参数的索引,而不是表中列名的索引
// result = pre.executeQuery();// 执行查询,注意括号中不需要再加参数
// while (result.next())
// // 当结果集不为空时
// System.out.println("学号:" + result.getInt("id") + "姓名:"
// + result.getString("name"));
}
catch (Exception e)
{
e.printStackTrace();
}
finally
{
try
{
// 逐一将上面的几个对象关闭,因为不关闭的话会影响性能、并且占用资源
// 注意关闭的顺序,最后使用的最先关闭
if (result != null)
result.close();
if (pre != null)
pre.close();
if (con != null)
con.close();
System.out.println("数据库连接已关闭!");
}
catch (Exception e)
{
e.printStackTrace();
}
}
}
}