数据库(mysql oracle)学习小结

数据库概念
oracle数据库
一组:数据文件、控制文件、日志文件

oracle实例,它与数据库的关系
oracle实例:实例就是数据库启动后分配的内存和建立的后台进程. 数据库关闭后,物理上的文件还存在,但实例(分配的内存和建立的进程)就没有了
数据库:物理操作系统文件或磁盘(disk)的集合。

关系:  实例就是一组操作系统进程(或者是一个多线程的进程)以及一些内存。这些进程可以操作数据库;而数据库只是一个文件集合(包括数据文件、临时文件、重做日志文件和控制文件)。
    在任何时刻,一个实例只能有一组相关的文件(与一个数据库关联)。大多数情况下,反过来也成立:一个数据库上只有一个实例对其进行操作。
    不过,Oracle的真正应用集群(Real Application Clusters,RAC)是一个例外,这是Oracle提供的一个选项,允许在集群环境中的多台计算机上操作,
    这样就可以有多台实例同时装载并打开一个数据库(位于一组共享物理磁盘上)。

数据库中的数据类型:
数字:mysql db2-----short integer long float double
      oracle--------number(30),number(30,3)
字符/字符串:char(10)     varchar2(10)
日期和时间:date(年、月、日、小时、分钟、秒) timestamp()(时间戳)
oracle数据库模式日期格式:03-3月-08   03-Mar-08
大对象(Characterlob/Binary lob)

主键应该具备的特征:
1.不能为null
2.主键必须唯一

where name like '\%' escape '\'

字符:
upper
lower
initcap
substr
replace
instr
length
lpad/rpad
trim
concat--------||

select substr(last_name,1,1)||lpad(last_name,sbustr(last_name,2,length(last_name)-1,'*')

replace(last_name,substr(last_name,2,leghth(last_name)-2),lpad('',length(last_name)-2,'*')

日期:
months_between
add_months()
next_day()
last_day()

数字:
round(2333,2)
trunc
mod

round(sysdate,'month/year')

类型转换的函数
to_char to_date to_number

to_char(数字/日期,'fm')

to_char(sysdate,'fmyyyy-mm-dd "fdfdfdfd" HH24:MI:SS am')

to_char(234567,'fm99,999.00000')

to_date('20-3月-58')
to_date('[2008-02-08]','[yyyy-mm-dd]')

RR
68

通用函数:
nvl(commission_pct,0)----第一个表达式为null,返回第二个表达式的值,否则返回第一个表达式的值
nvl(commission_pct,1,0)--第一个表达式为null,返回第三个表达式的值,否则返回第二个表达式的值
nullif(last_name,first_name)--如果第一个表达式和第二个表达式的值相同,返回null,否则返回第一个表达式的值
decode()

lpad('',round((salary*12+salary*12*nvl(commission_pct,0))/1000),'*')

多表的查询两种方法:
连接查询
内连接:等值连接、非等值连接、自然连接。。。
外连接:左、右、全外连接

笛卡尔集----子集
select * from users u,orders o where u.id=o.user_id and ;
select * from users u join orders o on u.id=o.user_id;

cross join

select a.dd,b.dd,c.dd from A a,B b,c c where a.pk=b.id and b.id=c.fk

employee
1 A  500
2 B 660
3 c 1000
4 d 4000

level
id name minsalary maxsalay
1 A级   5000       10000
2 B级   3000       5000
3 C级   1000       3000
4 D级   400        1000

A  D级
B  D级
C  C级
D  B级

select e.name,l.name from employee e,level l where e.salary between l.minsalary and l.maxsalary;

1 A 500 4 D级   400        1000
2 B 660 4 D级   400        1000
3 C 1000 3 C级   1000       3000
4 d 4000 2 B级   3000       5000

select * from users u left/right/full outer join orders o on u.id=o.user_id;

Oracle写外连接的简便的方式:
select * from users u,orders o where u.id(+)=o.user_id;

select * from departments nature join loctions------两个表的主外键必须同名,同类型
同名,类型不一致
select * from deparments join locations using(location_id);

select * from departments d,locations l where d.location_id=l.locations_id;

select e.last_name,e.job_id,d.department_name,e.salary,jg.grade_level from employees e,departments d,job_grades jg where e.department_id=d.department_id and e.salary between jg.minsalary and jg.maxsalary;

USERS(id,name,birth)

insert into users(id,birth) values(1,to_date('1998-01-01','fmyyyy-mm-dd'));
insert into users values(1,'abc',to_date('1998-01-01','fmyyyy-mm-dd'));

delete users where last_name='zhangsan';

SQL:结构化查询语言,select
DML:数据操纵语言:insert update delete
DCL:数据控制语言:commit rollback。
事务:一组SQL语句的单元(DML语句为主)
DDL:数据定义语言:create table users()

insert into student values(3,'cc',100.99,null);

DDL:数据定义语言
order by
blueuser
blueorder
blue_user
blue_order
oa_user

create table users(
  id number(10),
  name varchar2(40),
  age number(3)
);

alter table users add constaint users_pk primary key (id);

alter table users disable constraint users_pk;
alter table users enable constraint users_pk;

alter table users drop constraint users_pk;

alter table users set unused (name,age);

alter table users et unused column name;
alter table users set unused column age;

alter table users drop unused columns;

drop table users;

rename users to oa_users;

truncate table users;

select e.last_name,e.salary,e.department_id,d.mm from employees e,(select department_id dept_id,max(salary) mm from employees group by department_id) d where e.department_id=d.dept_id;

select dfdfd from A a left outer join (select dfa)

create or relpace view salary_vu
is
select e.last_name,d.department_name,e.salary,j.name from employees e,departments d,job_grades j where e.department_id=d.department_id and e.salary between j.minsalary and j.maxsalary;

 SELECT * FROM ( SELECT A.*, ROWNUM RN FROM (SELECT * FROM TABLE_NAME ) A WHERE ROWNUM <= to ) WHERE RN >= from

时间: 2024-08-29 11:00:20

数据库(mysql oracle)学习小结的相关文章

数据库mysql,oracle,sqlite,mariadb 相关收藏

数据库 mysql MySql动态SQL - 风生水起 - 博客园 MySQL :: MySQL 5.1参考手册 :: B. 错误代码和消息 mysql 表空间及索引的查看 - 爱测试的猫咪 - 博客园 复制 mysql数据库复制_百度文库 mysql数据库'复制'的办法 - wren_blog - 51CTO技术博客 命令 Out of resources when opening file './xxx.MYD' (Errcode: 24) 解决 - MySQL - Database - C

数据库开发:Oracle学习笔记

实例 1.启动Oracle Server. Startup[nomount|mount|open][force][pfile=filename] 参数说明: nomount:只启动实例 mount:启动实例,并装载数据库 open:启动实例,装载并打开数据库. Force:终止实例,并重新启动数据库.(默认选项) Pfile:指定非默认参数文件名. 2.停止Oracle Server Shutdown [normal|transactional|immediate|abort] 参数说明: no

MySql存储过程学习知识小结_Mysql

什么是存储过程: 存储过程可以说是一个记录集吧,它是由一些T-SQL语句组成的代码块,这些T-SQL语句代码像一个方法一样实现一些功能(对单表或多表的增删改查),然后再给这个代码块取一个名字,在用到这个功能的时候调用他就行了. 存储过程的好处: 1.由于数据库执行动作时,是先编译后执行的.然而存储过程是一个编译过的代码块,所以执行效率要比T-SQL语句高. 2.一个存储过程在程序在网络中交互时可以替代大堆的T-SQL语句,所以也能降低网络的通信量,提高通信速率. 3.通过存储过程能够使没有权限的

c#+oracle 11g-用C#,Oracle 11g 怎样建立数据库?怎样学习?

问题描述 用C#,Oracle 11g 怎样建立数据库?怎样学习? 怎样建立用C#建立以Oracle库为来源的数据库?从哪里入手?之前未接触过C#,对C++和C稍了解,但是都用的VC6.0,没用过VS2010,对Oracle不了解,求指导,怎样去完成数据库?学习的步骤怎样安排比较合理? 解决方案 买本ORACLE的教学书籍,安装好ORACLE客户端,多动手练习 解决方案二: http://www.jb51.net/article/37008.htm 先连接上.其余的就好办了

MySql的存储过程学习小结 附pdf文档下载_Mysql

存储过程是一种存储在数据库库中的程序(就像正规语言里的子程序一样),准确的来说,MySql支持的"routine(例程)"有两种:一是我们说的存储过程,二是在其它sql语句中可以返回值的函数(使用起来和mysql预装载的函数一样,如pi()). 一个存储过程包括名字,参数列表,以及可以包括很多sql语句的sql语句集.在这里对局部变量,异常处理,循环控制和if条件语句有新的语法定义. 下面是一个包括存储过程的实例声明: 复制代码 代码如下: CREATE PROCEDURE proce

MySql数据库中Select用法小结_Mysql

一.条件筛选 1.数字筛选:sql = "Select * from [sheet1$] Where 销售单价 > 100" 2.字符条件:sql = "Select * from [sheet1$] Where 物品名称 ='挡泥板'" 3.日期条件:sql = "Select * from [sheet1$] Where 物品名称 ='挡泥板'" 4.区间条件:sql = "Select * from [sheet1$] Wh

LINUX时区设置及与数据库之间(ORACLE MYSQL)的关系

LINUX时区    LINUX 操作系统时区由/etc/localtime设置,其可以是一个指向/usr/share/zoneinfo下文件的软连接, 当然也可以拷贝,在/usr/share/zoneinfo目录下每个文件都包含了特定地区的时区信息,很多都分为 洲目录/地区目录  如: UTC:GMT标准时间+0时区 CET:欧洲中部时间 EST:美国东部标准时间 Asia/Shanghai:中国上海+8时区  (亚洲目录/上海地区) 我们可以简单的建立一个连接 cd /etc ln -s  

学习使用数据库MySQL

mysql|数据|数据库 [摘要]:MySQL是一个遵循GPL的开源软件.在Linux平台底下它是LAMP(LAMP 在英语中是"灯"的意思,但是在 IT 行业当然不是那么简单的一个意思了.这个术语在德国十分流行.代表了 Linux 平台上的 Apache 网站服务器;MySQL 数据库以及 Perl .Python 或者 PHP 编程语言的结合)组合重要组成部分.同时它提供的C API可以结合Glade/GTK+,可以代替Windows平台的VB+ACCESS/MS SQL SERV

MySQL入门学习(一)

mysql MySQL入门学习(一)  安装篇   PHP+MySQL+Linux目前已逐渐成为小型web服务器的一种经典组合.在indows环境下构筑和调试MySQL数据库是许多网站开发者的一种首选.本人在Windows98环境下初学MySQL,现将学习过程与经验总结出来供大家参考. 1.下载mysql-3.23.35-win.zip并解压: 2.运行setup.exe;选择d:\mysql,"tyical install" 3.启动mysql,有如下方法:   方法一:使用winm