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’) (编辑:湖南网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |