① sql如何查询派生出一个结果表
select * into new_table from table
要求new_table表不存在,会把查询结果放入这个表中,* 是所有字段,可以为你的字段列表
② sql语句创建表
创建新表的程序功能为:
create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..)
具体为:
创建之前判断该数据库是否存在
if exists (select * from sysdatabases where name='databaseName')
drop database databaseName
go
Create DATABASE databasename
on primary-- 默认就属于primary文件组,可省略
(
/*--数据文件的具体描述--*/
name=‘databasename_data’,-- 主数据文件的逻辑名称
filename=‘'所存位置:databasename_data.mdf’, -- 主数据文件的物理名称
size=数值mb, --主数据文件的初始大小
maxsize=数值mb, -- 主数据文件增长的最大值
filegrowth=数值%--主数据文件的增长率
)
log on
(
/*--日志文件的具体描述,各参数含义同上--*/
name='databasename_log', -- 日志文件的逻辑名称
filename='所存目录:databasename_log.ldf', -- 日志文件的物理名称
size=数值mb, --日志文件的初始大小
filegrowth=数值%--日志文件的增长值
)
结构化查询语言(Structured Query Language)简称SQL,结构化查询语言是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统;
sql 语句就是对数据库进行操作的一种语言。
(2)sql如何命名派生表扩展阅读
1、常见语句
更新:update table1 set field1=value1 where 范围
查找:select * from table1 where field1 like ’%value1%’ (所有包含‘value1’这个模式的字符串)
排序:select * from table1 order by field1,field2 [desc]
求和:select sum(field1) as sumvalue from table1
平均:select avg(field1) as avgvalue from table1
最大:select max(field1) as maxvalue from table1
最小:select min(field1) as minvalue from table1[separator]
2、高级查询
A:UNION运算符
UNION 运算符通过组合其他两个结果表(例如TABLE1 和TABLE2)并消去表中任何重复行而派生出一个结果表。当 ALL 随UNION 一起使用时(即UNION ALL),不消除重复行。两种情况下,派生表的每一行不是来自TABLE1 就是来自TABLE2。
B: EXCEPT运算符
EXCEPT 运算符通过包括所有在TABLE1 中但不在TABLE2 中的行并消除所有重复行而派生出一个结果表。当ALL 随EXCEPT 一起使用时(EXCEPT ALL),不消除重复行。
C:INTERSECT运算符
INTERSECT 运算符通过只包括TABLE1 和TABLE2 中都有的行并消除所有重复行而派生出一个结果表。当ALL 随INTERSECT 一起使用时(INTERSECT ALL),不消除重复行。
注:使用运算词的几个查询结果行必须是一致的。
③ 求大神,告诉我SQL中的派生表有什么用,用白话说下,谢谢详细一些!我非常不明白,还有相关子查询,跪
派生表:比如要查找一个叫张铁牛的人的信息,我们知道他是男性,为了缩小查找范围我把所有的男性都找出来,然后从这些男性中里面再去找张铁牛。这里男性的集合就相当于派生表,转成sql语句是这样select 姓名,住址,身份证 from (select * from 表名 where 性别='男性') t where 姓名='张铁牛'(这里只是为了举例子),这里的t这个数据集就是派生表,它是虚表,在数据库中不存在的,是我们构建的,在这里的目的是为了缩小数据的查找范围。
相关子查询:子查询的执行依赖于外部查询的数据,外部查询执行一行,子查询就执行一次。比如:select * from 外表 where 姓名 in (select 姓名 from 内表 where 外表.姓名=内表.姓名),你看在括号里的sql语句,是与外表关联的。这里顺便说一下非相关子查询,还是以上面为例,如:select * from 外表 where 姓名 in (select 姓名 from 内表 where 外表.姓名='张铁牛'),你看这个语句中括号里的sql语句,它是单独执行的,与外表没有任何关联,它只执行一次,执行完后将结果集传递给外部查询使用。
这里只是表面上描述了一下,内部还有其他区别,lz需要通过联系体会,有问题再追问,望采纳。
④ sql 两个派生表可以用一样的别名吗
只要不在一起用是可以的
⑤ sql'x%'处理和 '%x%'有啥区别,派生表是什么意思
'x%'是查询匹配以'x'开头的字符串
'%x%'是查询匹配字符串中有'x'字符的字符串
例如:'x%'能够匹配上'xa'
'%x%'能匹配上'axa','x%'就不行了
在多表查询的时候,用到的子查询就是派生表,就是把一个select 语句看作是一个表来进行操作
⑥ 有谁知道SQL server中的派生表怎么建立吗
派生表是一种从查询表达式派生出虚拟结果表的表表达式.派生表与其他表一样出现在查询的FROM子句中.派生表仅存在于外部查询中.
使用派生一的一般形式如下:
FROM (SELECT * FROM TA WHERE ...) AS T
派生出来的表必须要是一个有效的表.因此,它必须遵守以下几条规则:
1. 所有列必须要有名称
2. 列名称必须是要唯一
3. 不允许使用ORDER BY(除非指定了TOP)
⑦ sqlserver中的as是什么意思
这是sql server的一个规则所决定的.
sql server中派生表是不能单独作为表名的 一定要给它个别名当做表名
这里你的派生表就是 (select Classification from NewsInfo) 如果不加 as a 就不能直接用在 from后面。
⑧ 派生表是什么意思
派生表是Microsoft公司新推出的SQL2005数据库的一个增强功能。它将子查询做为一个表来处理,这个由子查询得出的新表就是我们说的“派生表”。
⑨ sql 表的别名到底要怎么定义
表名、列明后面接as xx,xx就是表/列的别名,as可省略
别名通常有两个作用,1是缩短对象的长度,方便书写,使名称语句简洁
2是区别同名对象,如自连接查询,同一个表要连接查询自身,那么一定要用别名来区分表名及列名
还有一点需要注意的是,如遇到引用派生表的情况,也一定要加表别名,如你的where 数量汇总这句前面的from(select)内部的select语句即是派生表,在查询分析器看来,这只是一个没有命名的数据集合,所以要想用from引用它需要给它加一个表别名来标识这个集合是个可用表