加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 电商 > 正文

SQL 语法参考手册(SQL)

发布时间:2018-08-12 15:10:32 所属栏目:电商 来源:站长网
导读:SQL 语法参考手册(SQL) DB2 提供了关系式资料库的查询说话 SQL (Structured Query Language),是一种很是口语化、既易学又易懂的语法。此一说话险些是每个资料库体系都必需提供的,用以暗示关系式的*作,包括了资料的界说(DDL)以及资料的处理赏罚(

SQL 语法参考手册(SQL)

DB2 提供了关系式资料库的查询说话 SQL (Structured Query Language),是一种很是口语化、既易学又易懂的语法。此一说话险些是每个资料库体系都必需提供的,用以暗示关系式的*作,包括了资料的界说(DDL)以及资料的处理赏罚(DML)。SQL原本拼成SEQUEL,这说话的原型以“体系 R“的名字在 IBM 圣荷西尝试室完成,颠末IBM内部及其他的很多行使性及服从测试,其功效相合时人满足,并抉择在体系R 的技能基本成长出来 IBM 的产物。并且美国国度尺度学会(ANSI)及国际尺度化组织(ISO)在1987遵循一个险些是以 IBM SQL 为基本的尺度关系式资料说话界说。

一、资料界说 DDL(Data Definition Language)
资料定说话是指对资料的名目和形态下界说的说话,他是每个资料库要成立时辰时起主要面临的,举凡资料分哪些表格相关、表格内的有什麽栏位主键、表格和表格之间相互参考的相关等等,都是在开始的时辰所必需筹划好的。

1、建表格:
CREATE TABLE table_name(
column1 DATATYPE [NOT NULL] [NOT NULL PRIMARY KEY],
column2 DATATYPE [NOT NULL],
...)
声名: 
DATATYPE --是资料的名目,详见表。
NUT NULL --可不行以应承资料有空的(尚未有资料填入)。
PRIMARY KEY --是本表的主键。

2、变动表格 
ALTER TABLE table_name
ADD COLUMN column_name DATATYPE
声名:增进一个栏位(没有删除某个栏位的语法。
ALTER TABLE table_name
ADD PRIMARY KEY (column_name)
声名:变动表得的界说把某个栏位设为主键。
ALTER TABLE table_name
DROP PRIMARY KEY (column_name)
声名:把主键的界说删除。

3、成立索引 
CREATE INDEX index_name ON table_name (column_name)
声名:对某个表格的栏位成立索引以增进查询时的速率。

4、删除 
DROP table_name
DROP index_name

二、的资料形态 DATATYPEs
smallint
16 位元的整数。
interger
32 位元的整数。
decimal(p,s)
p 准确值和 s 巨细的十进位整数,准确值p是指所有有几个数(digits)巨细值,s是指小数
点後有几位数。假如没有出格指定,则体系会设为 p=5; s=0 。
float
32位元的实数。
double
64位元的实数。
char(n)
n 长度的字串,n不能高出 254。
varchar(n)
长度不牢靠且其最大长度为 n 的字串,n不能高出 4000。
graphic(n)
和 char(n) 一样,不外其单元是两个字元 double-bytes, n不能高出127。这个形态是为
了增援两个字元长度的字体,譬喻中笔墨。
vargraphic(n)
可变长度且其最大长度为 n 的双字元字串,n不能高出 2000。
date
包括了 年份、月份、日期。
time
包括了 小时、分钟、秒。
timestamp
包括了 年、月、日、时、分、秒、千分之一秒。

三、资料*作 DML (Data Manipulation Language)
资料界说好之後接下来的就是资料的*作。资料的*作不过乎增进资料(insert)、查询资料(query)、变动资料(update) 、删除资料(delete)四种模式,以下分 别先容他们的语法:

1、增进资料:
INSERT INTO table_name (column1,column2,...)
valueS ( value1,value2, ...)
声名:
1.若没有指定column 体系则会按表格内的栏位次序填入资料。
2.栏位的资料形态和所填入的资料必需相符。
3.table_name 也可所以景观 view_name。

INSERT INTO table_name (column1,column2,...)
SELECT columnx,columny,... FROM another_table
声名:也可以颠末一个子查询(subquery)把此外表格的资料填入。

2、查询资料:
根基查询
SELECT column1,columns2,...
FROM table_name
声名:把table_name 的特定栏位资料所有列出来
SELECT *
FROM table_name
WHERE column1 = xxx
[AND column2 > yyy] [OR column3 <> zzz]
声名:
1.’*’暗示所有的栏位都列出来。
2.WHERE 之後是接前提式,把切合前提的资料列出来。

SELECT column1,column2
FROM table_name
ORDER BY column2 [DESC]
声名:ORDER BY 是指定以某个栏位做排序,[DESC]是指从大到小分列,若没有指明,则是从小到大
分列

组合查询
组合查询是指所查询得资料来历并不但有单一的表格,而是连系一个以上的
表格才气够获得功效的。
SELECT *
FROM table1,table2
WHERE table1.colum1=table2.column1
声名:
1.查询两个表格中个中 column1 值沟通的资料。
2.虽然两个表格彼此较量的栏位,其资料形态必需沟通。
3.一个伟大的查询其动用到的表格也许会许多个。

整合性的查询:
SELECT COUNT (*)
FROM table_name
WHERE column_name = xxx
声名:
查询切合前提的资料共有几笔。
SELECT SUM(column1)
FROM table_name
声名:
1.计较出总和,所选的栏位必需是可数的数字形态。
2.除此以外尚有 AVG() 是计较均匀、MAX()、MIN()计较最大最小值的整合性查询。
SELECT column1,AVG(column2)
FROM table_name
GROUP BY column1
HAVING AVG(column2) > xxx
声名:
1.GROUP BY: 以column1 为一组计较 column2 的均匀值必需和 AVG、SUM等整合性查询的要害字
一路行使。
2.HAVING : 必需和 GROUP BY 一路行使作为整合性的限定。

复合性的查询
SELECT *
FROM table_name1
WHERE EXISTS (
SELECT *
FROM table_name2
WHERE conditions )
声名:
1.WHERE 的 conditions 可所以其它一个的 query。
2.EXISTS 在此是指存在与否。
SELECT *
FROM table_name1
WHERE column1 IN (
SELECT column1
FROM table_name2
WHERE conditions )
声名: 
1. IN 後面接的是一个荟萃,暗示column1 存在荟萃内里。
2. SELECT 出来的资料形态必需切合 column1。

其他查询
SELECT *
FROM table_name1
WHERE column1 LIKE ’x%’
声名:LIKE 必需和後面的’x%’ 相呼应暗示以 x为开头的字串。
SELECT *
FROM table_name1
WHERE column1 IN (’xxx’,’yyy’,..)
声名:IN 後面接的是一个荟萃,暗示column1 存在荟萃内里。
SELECT *
FROM table_name1
WHERE column1 BETWEEN xx AND yy
声名:BETWEEN 暗示 column1 的值介於 xx 和 yy 之间。

3、变动资料:
UPDATE table_name
SET column1=’xxx’
WHERE conditoins
声名:
1.变动某个栏位设定其值为’xxx’。
2.conditions 是所要切合的前提、若没有 WHERE 则整个 table 的谁人栏位城市所有被变动。

4、删除资料:
DELETE FROM table_name
WHERE conditions
声名:删除切合前提的资料。

声名:关于WHERE前提后头假如包括有日期的较量,差异数据库有差异的表达式。详细如下:
(1)假如是ACCESS数据库,则为:WHERE mydate>#2000-01-01#
(2)假如是ORACLE数据库,则为:WHERE mydate>cast(’2000-01-01’ as date)
或:WHERE mydate>to_date(’2000-01-01’,’yyyy-mm-dd’)
在Delphi中写成:
thedate=’2000-01-01’;
query1.SQL.add(’select * from abc where mydate>cast(’+’’’’+thedate+’’’’+’ as date)’);

假如较量日期时刻型,则为:
WHERE mydatetime>to_date(’2000-01-01 10:00:01’,’yyyy-mm-dd hh24:mi:ss’)

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读