dualsql
⑴ pl-sql中select * from al 这个al是什么
Dual简单的说就是一个空表,Oracle提供的最小的工作表,只有一行一列,具有某些特殊功用。常用来通过select语句计算常数表达式。
特性:
1、Oracle提供的最小的表,不论进行何种操作(不要删除记录),它都只有一条记录——'X'。
例如:执行select * from al,里面只有一条记录;执行insert into al values('Y')后,再次查询al表,仍然显示一条记录。
2、是sys用户下的一张内部表,所有用户都可以使用DUAL名称访问,无论什么时候这个表总是存在
例如:执行一个查看当前日期的语句 select sysdate from al,这条语句在放在放在任何一个oracle数据库当中都不会报错,所以一般做一些特定查询的时候用这个表是最稳妥的。
(1)alsql扩展阅读:
用途
1、select计算常量表达式、伪列等值
oracle内部处理使它只返回一行数据,而使用其它表时可能返回多个数据行。
2、查看当前用户
select user from al;
select count(*) from al;
3、用做计算器
select 7*9*10-10 from al;
4、调用系统函数
(1)获得当前系统时间
select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from al;
(2)获得主机名
select sys_context('userenv','terminal') from al;
(3)获得当前locale
select sys_context('userenv','language') from al;
(4)获得一个随机数
select DBMS_RANDOM.random from al;
5、查看序列值
(1)创建序列aaa 以1开始,每次加1
create sequence aaa increment by 1 start with 1;
(2)获得序列aaa 的下一个序列值
select aaa.nextval from al;
(3)获得序列aaa 的当前序列值
select aaa.currval from al;
⑵ mysql中al是什么意思
mysql中al是虚拟表,select ...from .....;格式:select sysdate from al;
MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于Oracle旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的RDBMS应用软件之一。
MySQL是一种关系数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。
MySQL所使用的 SQL 语言是用于访问数据库的最常用标准化语言。MySQL 软件采用了双授权政策,分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择 MySQL 作为网站数据库。
由于其社区版的性能卓越,搭配PHP和Apache可组成良好的开发环境。
(2)alsql扩展阅读
MyISAMMySQL 5.0 之前的默认数据库引擎,最为常用。拥有较高的插入,查询速度,但不支持事务
InnoDB事务型数据库的首选引擎,支持ACID事务,支持行级锁定, MySQL 5.5 起成为默认数据库引擎
BDB源 自 Berkeley DB,事务型数据库的另一种选择,支持Commit 和Rollback 等其他事务特性
Memory所有数据置于内存的存储引擎,拥有极高的插入,更新和查询效率。但是会占用和数据量成正比的内存空间。并且其内容会在 MySQL 重新启动时丢失
Merge将一定数量的 MyISAM 表联合而成一个整体,在超大规模数据存储时很有用
Archive非常适合存储大量的独立的,作为历史记录的数据。因为它们不经常被读取。Archive 拥有高效的插入速度,但其对查询的支持相对较差
Federated将不同的 MySQL 服务器联合起来,逻辑上组成一个完整的数据库。非常适合分布式应用
Cluster/NDB高冗余的存储引擎,用多台数据机器联合提供服务以提高整体性能和安全性。适合数据量大,安全和性能要求高的应用
CSV: 逻辑上由逗号分割数据的存储引擎。它会在数据库子目录里为每个数据表创建一个 .csv 文件。这是一种普通文本文件,每个数据行占用一个文本行。CSV 存储引擎不支持索引。
⑶ SQL语句中select mmy from al;有什么意义
FORM 后面就是 表名 说的明白一下 select 列名 from 表名 这句话的意思是 从这个表里选择制定的列!
⑷ SQL Server中有没有类似Oracle中 的 DUAL 的表
SQL Server中没有DUAL,要什么就直接SELECT什么。
比如:
Oracle 中 select 999*999 from al;
在SQL Server中:
可以是:select 999*999 ;
或准确点:
select999*999AStRevNumber;--选择999*999的积作为tRevNumber来返回
个人认为,还是MS SQL来得更科学,Or中这是典型的脱了裤子打屁。
(单位有个基于OR的管理系统,用了几年,个人对它吐槽无数)