总结sql
1. sql中join的几种常见用法总结
JOIN连接组合两个表中的字段记录,包括三种:
INNERJOIN运算式:连接组合两个表中的字段记录。
LEFTJOIN运算式:连接组合两个表中的字段记录,并将包含了LEFTJOIN左边表中的全部记录。
RIGHTJOIN运算式:连接组合两个表中的字段记录,并将包含了RIGHTJOIN右边表中的全部记录。
INNERJOIN设定两个表相关连的运算式,以连接组合两个表中的字段记录。
INNERJOIN语法如下:
FROM表1INNERJOIN表2ON表1.字段1比较运算子表2.字段2
两个表连接的字段,譬如[表1.字段1=表2.字段2],必须具有相同的字段类型,但是字段名称不需要相同。
例如,自动编号字段类型可以连接Long的字段类型,但是单精整数字段类型不能连接双精整数的字段类型。
比较运算子可为=、<、>、<=、>=、或<>。
JOIN连接的字段,不可以包含MEMO字段类型或OLE对象类型,否则会发生错误。
在一个JOIN表达式中,可以连结多个ON子句:
SELECTfields
FROM表1INNERJOIN表2
ON表1.字段1比较运算子表2.字段1AND
ON表1.字段2比较运算子表2.字段2)OR
ON表1.字段3比较运算子表2.字段3)
JOIN表达式中,可以为巢状式:
SELECTfields
FROM表1INNERJOIN
(表2INNERJOIN[(]表3
[INNERJOIN[(]表x[INNERJOIN...)]
ON表3.字段3比较运算子表x.字段x)]
ON表2.字段2比较运算子表3.字段3)
ON表1.字段1比较运算子表2.字段2
在一个INNERJOIN中,可以包括巢状式的LEFTJOIN或RIGHTJOIN,但是在一个LEFTJOIN或RIGHTJOIN中不能包括巢状式的INNERJOIN。
2. MySQL中SQL模式的特点总结
前言
SQL模式影响MySQL支持的SQL语法和执行的数据验证检查。
MySQL服务器可以在不同的SQL模式下运行,并且可以针对不同的客户端以不同的方式应用这些模式,具体取决于sql_mode系统变量的值。DBA可以设置全局SQL模式以匹配站点服务器操作要求,并且每个应用程序可以将其会话SQL模式设置为其自己的要求。
模式会影响MySQL支持的SQL语法以及它执行的数据验证检查。这使得在不同环境中使用MySQL以及将MySQL与其他数据库服务器一起使用变得更加容易。
下面话不多说了,来一起看看详细的介绍吧
设置SQL模式
要在运行时更改SQL模式,请sql_mode使用以下SET
语句设置全局或会话
系统变量
SET
GLOBAL
sql_mode
=
'modes';
SET
SESSION
sql_mode
=
'modes';
模式列表
模式
注释
ALLOW_INVALID_DATES
无效日期会生成错误
ERROR_FOR_DIVISION_BY_ZERO
除0错误
NO_BACKSLASH_ESCAPES
禁止使用反斜杠字符(\)作为字符串中的转义字符。启用此模式后,反斜杠就像其他任何一个普通字符一样。
NO_UNSIGNED_SUBTRACTION
在整数值之间减去(其中一个是类型)
UNSIGNED,默认情况下会产生无符号结果。如果结果否则为负,则会导致错误
NO_ZERO_IN_DATE
'0000-00-00'
则允许并且插入产生警告
ONLY_FULL_GROUP_BY
select
内指定字段必须出现在
groupby
中,否则错误
STRICT_TRANS_TABLES
为事务存储引擎启用严格的SQL模式,并在可能的情况下为非事务性存储引擎启用。
STRICT_ALL_TABLES
为所有存储引擎启用严格SQL模式。无效的数据值被拒绝。
详情请参考
https://dev.mysql.com/doc/ref...
严格SQL模式
MySQL服务器可以在不同的SQL模式下运行,并且可以针对不同的客户端以不同的方式应用这些模式,具体取决于sql_mode系统变量的值。在严格SQL模式下,服务器会将某些警告升级为错误。
严格SQL模式适用于以下语句
ALTER
TABLE
CREATE
TABLE
CREATE
TABLE
...
SELECT
DELETE
INSERT
LOAD
DATA
LOAD
XML
SELECT
SLEEP()
UPDATE
在存储的程序中,如果在严格模式生效时定义了程序,则列出的类型的单个语句将以严格的SQL模式执行。
严格的SQL模式适用于以下错误,表示输入值无效或缺失的一类错误。如果值具有错误的列数据类型或可能超出范围,则该值无效。如果要插入的新行不包含其定义中NOT
NULL没有显式DEFAULT子句的列的值,则缺少值。
ER_BAD_NULL_ERROR
ER_CUT_VALUE_GROUP_CONCAT
ER_DATA_TOO_LONG
ER_DATETIME_FUNCTION_OVERFLOW
ER_DIVISION_BY_ZERO
ER_INVALID_ARGUMENT_FOR_LOGARITHM
ER_NO_DEFAULT_FOR_FIELD
ER_NO_DEFAULT_FOR_VIEW_FIELD
ER_TOO_LONG_KEY
ER_TRUNCATED_WRONG_VALUE
ER_TRUNCATED_WRONG_VALUE_FOR_FIELD
ER_WARN_DATA_OUT_OF_RANGE
ER_WARN_NULL_TO_NOTNULL
ER_WARN_TOO_FEW_RECORDS
ER_WRONG_ARGUMENTS
ER_WRONG_VALUE_FOR_TYPE
WARN_DATA_TRUNCATED
致谢
感谢你看到这里,希望本篇文章可以帮到你,谢谢。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。
您可能感兴趣的文章:如何开启mysql中的严格模式学习SQL语句(强大的group
by与select
from模式)老生常谈MYSQL模式匹配
REGEXP和like的用法Mysql
SQL服务器模式介绍PHP基于单例模式实现的mysql类NoSQL反模式
-
文档数据库篇mysql中binlog_format模式与配置详细分析mysql启用skip-name-resolve模式时出现Warning的处理办法
3. SQL语言学习总结
SQL语言学习总结
总结就是把一个时间段取得的成绩、存在的问题及得到的经验和教训进行一次全面系统的总结的书面材料,它能够给人努力工作的动力,让我们来为自己写一份总结吧。总结你想好怎么写了吗?下面是我为大家整理的SQL语言学习总结,供大家参考借鉴,希望可以帮助到有需要的朋友。
暑假过的真快总感觉昨天才刚放假,还想着这个暑假怎么过时,暑假就已经去了。
这个暑假一开始我们看了浙大的sql的视频,老师给我们的要求是只要看一遍就行。刚开始看的时候还能听懂一些,看到后面的时候基本就听不懂了,幸好老师对我们的要求不高,于时只好硬着头皮继续。
sql的视频其实总的说来无非讲的是对数据库、表、字段等的创建、修改和删除。我们不懂的也就是怎样使用代码来实现这些操作。我们现在只要对这些有了解就够了,以后还会有锻炼机会的。
之后我们参照着原代码做了《学生信息管理系统》,大概用了七天的`时间。刚开始做的时候,觉得这个工程肯定会挺复杂的。但是做着做着感觉也就是那么回事。无非就是对几张表的操作。做这个工程最大的收获就是对刚学的sql知识有了一次熟练的机会,巩固了刚学的知识。也可以说是趁热打铁吧。
然后米老师给了我们更大的考验,让我们做《机房收费系统》,而且这次和上一次的《学生信息管理系统》不同的是,这次我们除了只有一个程序和数据库外,没有一个字的原码。
在得知我们可以把这次的工程做成任何样子时,我打算做一个类似于网吧那样的收费系统。也是一个cs系统。在网上查了一些主机如何与客户端通信的资料后,就开工了。虽然遇到了一些困难,但是到最后都一一解决了
这三次的学习困难程度可以说是一次比一次高,米老师也是用心良苦呀。
经过这个暑假,对sql已经有了深一步的了解,还有就是将米老师的学习方法又应用了一次。可谓是受益匪浅。
现在软件工程的学习已经开始,我会继续努力的。
;4. sql语言的分类有
SQL语句分类
如大家所知 sql语句被分为四大类:
数据定义语言DDL
数据查询语言DQL
数据操纵语言DML
数据控制功能DCL
相信大多数人都对SQL有一定的了解 我这里就不细讲具体内容 简单介绍一下具体内容 方便理解
数据定义语言DDL(Data Definition Language)
CREATE,DROP,ALTER
主要为以上操作 即对逻辑结构等有操作的,其中包括表结构,视图和索引。
数据查询语言DQL(Data Query Language)
SELECT
这个较为好理解 即查询操作,以select关键字。各种简单查询,连接查询等 都属于DQL。
数据操纵语言DML(Data Manipulation Language)
INSERT,UPDATE,DELETE
主要为以上操作 即对数据进行操作的,对应上面所说的查询操作 DQL与DML共同构建了多数初级程序员常用的增删改查操作。而查询是较为特殊的一种 被划分到DQL中。
数据控制功能DCL(Data Control Language)
GRANT,REVOKE,COMMIT,ROLLBACK
主要为以上操作 即对数据库安全性完整性等有操作的,可以简单的理解为权限控制等。
以上即为简单总结SQL的语句分类,希望对您有所帮助!~
更多学习视频可以在B站搜索“前端爱好者联盟”,或者直接点我。
5. SQL 日常工作总结
1.如何找出第二名?
#偏移法 limit offset(快)
#排除法 先找到最大值,再找小于最大值的数据中的最大值(慢)
2.日常固定搭配
#group by + having聚合函数做筛选只能用 having(快)
#group by + Where 做嵌套模式(慢)
3.#删除表 用delete
4.#求气温比昨天高的日期
5.#mod 余数为1是基数,为0是偶数
6#求年龄
7#求本周过生日的学生
日期的运算
1、现有日期进行偏移(推荐)
date_sub(日期 ,要减少偏移的间隔)
date_sub(date,INTERVAL expr type)
date_add(日期 ,要增加偏移的间隔)
date_add(date,INTERVAL expr type)
expr 是要偏移的数值
type 是要偏移的方式
时间格式的转换
1、字符串转换为日期格式
str_to_date (时间字符串,字符串日期格式) :能够把字符串转换为标准日期格式
日期的格式
格式描述
%Y 年,4 位
%y年,2 位
%M英文名称的月名(一月为January,二月为February)
%m 数值月份 (00-12)
%D带有英文后缀的天(不太直观)
%d 数值天 (00-31)
%H 小时 (00-23)
%h小时 (01-12)
%I小时 (01-12)
%i 分钟,数值(00-59)
%S秒(00-59)
%s 秒(00-59)
%a英文缩写星期名
%b英文缩写月名
%c月,数值
%f微秒
%p显示是 AM 还是 PM
%r显示时分秒时间,12小时制(hh:mm:ss AM 或 PM)
%T显示时分秒时间, 24小时制 (hh:mm:ss)
%j显示当前日期是今年的第几天 (001-366)
eg:
select str_to_date('08/09/2008', '%m/%d/%Y'); -- 2008-08-09
select str_to_date('08/09/08' , '%m/%d/%y'); -- 2008-08-09
select str_to_date('08.09.2008', '%m.%d.%Y'); -- 2008-08-09
select str_to_date('08:09:30', '%h:%i:%s'); -- 08:09:30
select str_to_date('08.09.2008 08:09:30', '%m.%d.%Y %h:%i:%s'); --2008-08-09 08:09:30
2、日期转换为特殊字符串形式
date_format (日期,字符串格式):能够把一个日期转换为各种样式的字符串
eg:
select date_format(now(),'%Y-%M-%d %H') ; -- 2020-May-23 17
select date_format('2020-02-03 13:45:06.676','%Y-%M-%D %I:%i:%S-%T') ; --2020-February-3rd 01:45:06-13:45:06
获取当前时间
1、获取年月日时分秒
now 函数:获取当前时间信息
eg:select now();
sysdate 函数:
eg:select sysdate();
区别:
now() 在执行开始时值就得到了;
sysdate() 在函数执行时动态得到值。
eg:
select now(), sleep(3),now();
select sysdate(), sleep(3) , sysdate();
2、获取年月日
current_date 函数
eg:
select current_date();
select curdate();
3、获取时分秒
current_time 函数
eg:
select current_time();
select curtime();
日常工作需要用到Mysql数据分析的案例:
涉及表:
orderinfo 订单详情表
| orderid 订单id
| userid 用户id
| isPaid 是否支付
| price 付款价格
| paidTime 付款时间
userinfo 用户信息表
| userid 用户id
| sex 用户性别
| birth 用户出生日期
1、统计不同月份的下单人数
2、统计用户三月份的回购率和复购率
复购率:当月购买了多次的用户占当月用户的比例
回购率:上月购买用户中有多少用户本月又再次购买
a、先筛选出3月份的消费情况
b、统计一下每个用户在3月份消费了多少次
c、对购买次数做一个判断,统计出来那些消费了多次(大于1次)的用户数
本月回购率:本月购买用户中有多少用户下个月又再次购买
3月份的回购率= 3月用户中4月又再次购买的人数 / 3月的用户总数
a、统计每年每月的一个用户消费情况
b、相邻月份进行关联,能关联上的用户说明就是回购
c、统计每个月份的消费人数情况及格得到回购率
3、统计男女用户消费频次是否有差异
1、统计每个用户的消费次数,注意要带性别
2、对性别做一个消费次数平均计算
4、统计多次消费的用户,第一次和最后一次消费间隔是多少天
1、取出多次消费的用户
2、取出第一次和最后一次的时间
5、统计不同年龄段,用户的消费金额是否有差异
a、计算每个用户的年龄,并对年龄进行分层:0-10:1,11-20:2,21-30:3
b、关联订单信息,获取不同年龄段的一个消费频次和消费金额
c、再对年龄分层进行聚合,得到不同年龄层的消费情况
6、统计消费的二八法则,消费的top20%用户,贡献了多少消费额
1、统计每个用户的消费金额,并进行一个降序排序
2、统计一下一共有多少用户,以及总消费金额是多少
3、取出前20%的用户进行金额统计
6. 总结了几个常用的sql server系统表的使用
1 sysobjects 表:包含数据有表对象、约束、聚集索引、主键、外键、存储过程、函数等的相关信息
2.sysfiles:主要反应指定数据库物理文件的占用空间大小及文件增长率的相关设置情况
3.sys.sysprocesses 是mssql数据库中一个非常重要的视图,主要用于返回当前db服务器中的运行中的进程ID
4.sys.stats简介
sys.stats主要用于存放MSSQL数据库中统计信息的统计,每条统计信息在sys.stats中都对应一行记录
5.sys.dm_exec_procere_stats 主要用于获取mssql自重新启动以来,缓存中存储过程中的运行情况
(
存储过程自启动以来执行涉及的逻辑读次数
存储过程自启动以来平均逻辑读次数
存储过程自启动以来执行次数
存储过程自启动以来运行耗时总时间
存储过程自启动以来平均运行耗时时间
存储过程自启动以来首次缓存时间
)
6.sys.proceres 表中记载指定数据库所涉及的全部存储过程,通过查询此系统表可以获取当前账户拥有查看权限的存储过程,
7.sys.messages 是系统表,里面存储过系统已经规划好的错误信息列表
请看一看,如有疑问,及时沟通!
7. SQL多表查询总结
连接查询包括合并、内连接、外连接和交叉连接,如果涉及多表查询,了解这些连接的特点很重要。
只有真正了解它们之间的区别,才能正确使用。
UNION 操作符用于合并两个或多个 SELECT 语句的结果集。
UNION 运算符通过组合其他两个结果表(例如 TABLE1 和 TABLE2)并消去表中任何重复行而派生出一个结果表。
当 ALL 随 UNION 一起使用时(即 UNION ALL),不消除重复行。两种情况下,派生表的每一行不是来自 TABLE1 就是来自 TABLE2。
注意:使用UNION时,两张表查询的结果有相同数量的列、列类型相似。
学生表信息(Students):
教师表信息(Teachers):
1)基本UNION查询,查询学校教师、学生的总的信息表,包括ID和姓名
查询结果:
2)查询教师学生全部姓名
因为UNION只会选择不同的值,如果学生中和教师中有重名的情况,这就需要UNION ALL
查询结果:
INNER JOIN(内连接),也成为自然连接
作用:根据两个或多个表中的列之间的关系,从这些表中查询数据。
注意⚠️: 内连接是从结果中删除其他被连接表中没有匹配行的所有行,所以内连接可能会丢失信息。
重点:内连接,只查匹配行。
语法:(INNER可省略)
学生表信息(Students):
专业信息表(Majors):
实例:查询学生信息,包括ID,姓名、专业名称
查询结果:
根据结果可以清晰看到,确实只有匹配的行。学生Lucy的信息丢失了。
与内连接相比,即使没有匹配行,也会返回一个表的全集。
外连接分为三种:左外连接,右外连接,全外连接。
对应SQL:LEFT/RIGHT/FULL OUTER JOIN。
通常我们省略outer 这个关键字。写成:LEFT/RIGHT/FULL JOIN。
重点:至少有一方保留全集,没有匹配行用NULL代替。
1、LEFT JOIN (左连接)
结果集保留左表的所有行,但只包含第二个表与第一表匹配的行。第二个表相应的空行被放入NULL值。
依然沿用内链接的例子:
(1)使用左连接查询学生的信息,其中包括学生ID,学生姓名和专业名称。
查询结果:
通过结果,我们可以看到左连接包含了第一张表的所有信息,在第二张表中如果没有匹配项,则用NULL代替。
2、RIGHT JOIN (右连接)
右外连接保留了第二个表的所有行,但只包含第一个表与第二个表匹配的行。第一个表相应空行被入NULL值。
右连接与左连接思想类似。只是第二张保留全集,如果第一张表中没有匹配项,用NULL代替
依然沿用内链接的例子,只是改为右连接
(2)使用右连接查询学生的信息,其中包括学生ID,学生姓名和专业名称
查询结果:
通过结果可以看到,包含了第二张表Majors的全集,Computer在Students表中没有匹配项,就用NULL代替。
3、FULL JOIN (全连接)
会把两个表所有的行都显示在结果表中
3)使用全连接查询学生的信息,其中包括学生ID,学生姓名和专业名称。
查询结果:
包含了两张表的所有记录,没有记录丢失,没有匹配的行用NULL代替。
4、CROSS JOIN(交叉连接)
交叉连接。交叉连接返回左表中的所有行,左表中的每一行与右表中的所有行组合。交叉连接也称作笛卡尔积。
简单查询两张表组合,这是求笛卡儿积,效率最低。
笛卡儿积:笛卡尔乘积,也叫直积。假设集合A={a,b},集合B={0,1,2},则两个集合的笛卡尔积为{(a,0),(a,1),(a,2),(b,0),(b,1), (b,2)}。可以扩展到多个集合的情况。类似的例子有,如果A表示某学校学生的集合,B表示该学校所有课程的集合,则A与B的笛卡尔积表示所有可能的选课情况。
4)交叉连接查询学生的信息,其中包括学生ID,学生姓名和专业名称。
查询结果:
5)查询多表,其实也是笛卡儿积,与CROSS JOIN等价,以下查询同上述结果一样。
这个可能很常见,但是大家一定要注意了,这样就查询了两张表中所有组合的全集。
查询结果:
6)增加查询条件
注意:在使用CROSS JOIN关键字交叉连接表时,因为生成的是两个表的笛卡尔积,因而不能使用ON关键字,只能在WHERE子句中定义搜索条件。
查询结果:
查询结果与INNER JOIN一样,但是其效率就慢很多了。
8. 6条比较有用的MySQL数据库操作的SQL语句小结
在MySQL数据库操作中,我们常常编写一些SQL语句来实现自己想要的功能。但是对于初学MySQL数据库的人来说这似乎又有一定的难度。本文我们总结了六条比较有用的SQL语句,初学者可以套用下面的格式,接下来就让我们一起来了解一下这部分内容。
1.计算年数
如果您想通过生日来计算这个人的年龄,可以用以下的语句来实现:
SELECT
DATE_FORMAT(FROM_DAYS(TO_DAYS(now())
-
TO_DAYS(@dateofbirth)),
'%Y')
+
0;
2.两个时间的差
取得两个
datetime
值的差。假设
dt1
和
dt2
是
datetime
类型,其格式为
‘yyyy-mm-dd
hh:mm:ss',那么它们之间所差的秒数为:UNIX_TIMESTAMP(
dt2
)
-
UNIX_TIMESTAMP(
dt1
)
除以60就是所差的分钟数,除以3600就是所差的小时数,再除以24就是所差的天数。
3.显示某一列出现过N次的值
SELECT
id
FROM
tbl
GROUP
BY
id
HAVING
COUNT(*)
=
N;
4.计算两个日子间的工作日
所谓工作日就是除出周六周日和节假日。
SELECT
COUNT(*)
FROM
calendar
WHERE
d
BETWEEN
Start
AND
Stop
AND
DAYOFWEEK(d)
NOT
IN(1,7)
AND
holiday=0;
5.查找表中的主键
SELECT
k.column_name
FROM
information_schema.table_constraints
t
JOIN
information_schema.key_column_usage
k
USING
(constraint_name,table_schema,table_name)
WHERE
t.constraint_type='PRIMARY
KEY'
AND
t.table_schema='db'
AND
t.table_name=tbl'
6.查看你的数库有多大
SELECT
table_schema
AS
'Db
Name',
Round(
Sum(
data_length
+
index_length
)
/
1024
/
1024,
3
)
AS
'Db
Size
(MB)',
Round(
Sum(
data_free
)
/
1024
/
1024,
3
)
AS
'Free
Space
(MB)'
FROM
information_schema.tables
GROUP
BY
table_schema
;
关于MySQL数据库的比较有用的SQL语句的介绍就到这里了.
9. sql语句的几个常用函数总结
聚合函数max() count() sum() min()
开窗函数row_number(),rank()
时间函数convert(),adatediff(week,[dateadd],getdate())
10. SQL 语句总结
1、说明:创建数据库
CREATE DATABASE database-name
2、说明:删除数据库
drop database dbname
3、说明:备份sql server
--- 创建 备份数据的 device
USE master
EXEC sp_admpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat'
--- 开始 备份
BACKUP DATABASE pubs TO testBack
4、说明:创建新表
create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..)
根据已有的表创建新表:
A:create table tab_new like tab_old (使用旧表创建新表)
B:create table tab_new as select col1,col2… from tab_old definition only
5、说明:删除新表
drop table tabname
6、说明:增加一个列
Alter table tabname add column col type
注:列增加后将不能删除。DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。
7、说明:添加主键: Alter table tabname add primary key(col)
说明:删除主键: Alter table tabname drop primary key(col)
8、说明:创建索引:create [unique] index idxname on tabname(col….)
删除索引:drop index idxname
注:索引是不可更改的,想更改必须删除重新建。
9、说明:创建视图:create view viewname as select statement
删除视图:drop view viewname
10、说明:几个简单的基本的sql语句
选择:select * from table1 where 范围
插入:insert into table1(field1,field2) values(value1,value2)
删除:delete from table1 where 范围
更新:update table1 set field1=value1 where 范围
查找:select * from table1 where field1 like ’%value1%’ ---like的语法很精妙,查资料!
排序:select * from table1 order by field1,field2 [desc]
总数:select count as totalcount from table1
求和: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
11、说明:几个高级查询运算词
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),不消除重复行。
注:使用运算词的几个查询结果行必须是一致的。
12、说明:使用外连接
A、left (outer) join:
左外连接(左连接):结果集几包括连接表的匹配行,也包括左连接表的所有行。
SQL: select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c
B:right (outer) join:
右外连接(右连接):结果集既包括连接表的匹配连接行,也包括右连接表的所有行。
C:full/cross (outer) join:
全外连接:不仅包括符号连接表的匹配行,还包括两个连接表中的所有记录。
12、分组:Group by:
一张表,一旦分组 完成后,查询后只能得到组相关的信息。
组相关的信息:(统计信息) count,sum,max,min,avg 分组的标准)
在SQLServer中分组时:不能以text,ntext,image类型的字段作为分组依据
在selecte统计函数中的字段,不能和普通的字段放在一起;
13、对数据库进行操作:
分离数据库: sp_detach_db; 附加数据库:sp_attach_db 后接表明,附加需要完整的路径名
14.如何修改数据库的名称:
sp_renamedb 'old_name', 'new_name'