`
cainiaoyu
  • 浏览: 21998 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

SQL小结

阅读更多
<转>[size=medium][/size]
结构化查询语言(Structured Query Language)简称SQL,是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统。各种不同的数据库对SQL语言的支持与标准存在着细微的不同,本文主要是在mySQL上测试的。

本文从以下几个方面开始总结

[/color]
一:DDL--数据定义语言(CREATE,ALTER,DROP,DECLARE) :

其语句包括动词CREATE和DROP。在数据库中创建新表或删除表(CREAT TABLE 或 DROP TABLE);为表加入索引等。DDL包括许多与人数据库目录中获得数据有关的保留字。它也是动作查询的一部分。
1,新建数据库和删除数据库
create database SQL_Test;
drop database sql_test;
2,新建表和删除表
create table tabname(col1 type1 [not null] ,col2 type2 [not null],..);
drop table tabname;
注:如果需要根据已有的表创建新表:
A:create table tab_new like tab_old (创建一个与旧表字段完全一样的新表)
B:create table tab_new as select col1,col2… from tab_old definition;(创建只包含就表中选定的部分字段的表)
例:
图片 图片
3,为表增加一列和删除一列
Alter table tabname add col type;(增加多列的话只需要在后面跟上添加的字段以“,”隔开)
Alter table tabname drop column col;(删除col这一列)
增加多列:Alter table tabname add col1 type, add col2 type....;
删除多列的话则:Alter table tabname drop column col1, drop column col2,...;
图片
4,增加与删除主键
主键可以在创建表示增加,也可以
添加主键: Alter table tabname add primary key(col) ;
添加自增主键:Alter table tb add primary key(id);
Alter table tb change id id int(10) not null auto_increment;
删除主键: Alter table tabname drop primary key;
删除自增主键:
先删除自增长在删除主键
Alter table tb change id id int(10);
Alter table tb drop primary key;
5、创建与删除索引
创建索引:
(1)ALTER TABLE用来创建普通索引、UNIQUE索引或PRIMARY KEY索引。
ALTER TABLE table_name ADD INDEX index_name (column_list)
ALTER TABLE table_name ADD UNIQUE (column_list)
ALTER TABLE table_name ADD PRIMARY KEY (column_list)
其中table_name是要增加索引的表名,column_list指出对哪些列进行索引,多列时各列之间用逗号分隔。索引名index_name可选,缺省时,MySQL将根据第一个索引列赋一个名称。另外,ALTER TABLE允许在单个语句中更改多个表,因此可以在同时创建多个索引。
(2)CREATE INDEX可对表增加普通索引或UNIQUE索引。
CREATE INDEX index_name ON table_name (column_list)
CREATE UNIQUE INDEX index_name ON table_name (column_list)
table_name、index_name和column_list具有与ALTER TABLE语句中相同的含义,索引名不可选。另外,不能用CREATE INDEX语句创建PRIMARY KEY索引。
删除索引:
DROP INDEX index_name ON talbe_name
ALTER TABLE table_name DROP INDEX index_name
ALTER TABLE table_name DROP PRIMARY KEY
其中,前两条语句是等价的,删除掉table_name中的索引index_name。
第3条语句只在删除PRIMARY KEY索引时使用,因为一个表只可能有一个PRIMARY KEY索引,因此不需要指定索引名。如果没有创建PRIMARY KEY索引,但表具有一个或多个UNIQUE索引,则MySQL将删除第一个UNIQUE索引。
注:索引是不可更改的,想更改必须删除重新建。
6、创建与删除试图
创建视图:CREATE [OR REPLACE] [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}] VIEW [db_name.]view_name [(column_list)]  AS select_statement [WITH [CASCADED | LOCAL] CHECK OPTION]
例如: CREATE VIEW purchase_detail AS SELECT product.name as name, product .price as price, purchase.qty as qty, product .price * purchase.qty as total_value from product, purchase where product.product_id = purchase.product_id;
修改视图:ALTER [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]    VIEW view_name [(column_list)]    AS select_statement    [WITH [CASCADED | LOCAL] CHECK OPTION]
该语句用于更改已有视图的定义。其语法与CREATE VIEW类似。
删除视图:DROP VIEW [IF EXISTS] view_name [, view_name] ...  [RESTRICT | CASCADE]
该语句用户删除视图,可一次删除多个视图。[IF EXISTS]选项确保语句正确运行。若没有该子句,当指定的视图不存在时,将发生错误。
二、DML--数据操纵语言(SELECT,DELETE,UPDATE,INSERT)
1,简单查询
选择:select * from table1 where 范围;选择部分字段以逗号隔开:select COL1,COL2 from table1 where 范围;
插入:insert into table1(field1,field2) values(value1,value2);(自增字段可以不用指定值)
删除:delete from table1 where 范围;(从表中删除符合条件的行)
更新:update table1 set field1=value1 where 范围;更新多个属性为符合条件的行:update table1 set field1=value1,field2=value2 where 范围;
计算:select field*2 from table;将字段乘2
别名:select filed as name from table;将field命名为name选取出来;
去除重复行: select distinct field from table;(去除field字段中重复的行)这种方法只对单表有效
查找:select * from table1 where field1 like ’%value1%’;%表示一个或多个字符
排序:select * from table1 order by field1,field2 [desc];首先按第一个字段排序,若字段1的值相等,则按字段2来排序
总数:select count(*) as totalcount from table1;统计某一字段的元素个数
求和:select sum(field1) as sumvalue from table1;统计某一字段的和(字符型返回0)
平均:select avg(field1) as avgvalue from table1;求平均值(字符型返回0)
最大:select max(field1) as maxvalue from table1;求最大值(字符型,根据acsii来返回大小)
最小:select min(field1) as minvalue from table1;求最小值
2,多表查询
连接查询
(1)内连接
只返回满足连接条件的数据。
SELECT table1.column, table2.column
    FROM table1, table2

    WHERE table1.column1 = table2.column2;
where 条件要有效,两张表间有一个相同的字段,才好进行有效的多表查询。查询时列名前,加表名或表别名前辍(如果字段在两个表中是唯一的可以不加)
例:查询每个员工的工号,姓名,工资,部门名和工作地点*/

    select empno,ename,sal,dname,loc from emp,dept

    where emp.deptno=dept.deptno;

(2)外连接
除了返回满足连接条的行以外,还返回左(右)表中,不满足条件的行,称为左(右)连接。
SELECT table1.column, table2.column   --右外连接

       FROM table1 right outer join table2

       on table1.column = table2.column;(table1中不符合条件的部分也会显示)
SELECT table1.column, table2.column   --左外连接

       FROM table1 left outer join  table2

       on table1.column = table2.column;


(3)自身连接
将自身表的一个镜像当另一个表来对待。
select e.name,d.name from emp e,emp d where ...;(将e和d做成emp的别名,然后将他们当做两个表来操作)
[color=red]

分组:Group by:
一旦分组完成后,查询只能得到组相关的信息。组相关的信息:(统计信息) count,sum,max,min,avg  分组的标准)
对所分的组进行选择使用:HAVING子句。如 select count(*) from client_info group by number having number >5;
而 select count(*) from client_info where id >2 group by number;
两者差别在于:HAVING是先分组后选择(选择的是组);而WHERE是先选择后分组。
子查询:
(1)使用IN的子查询
用于判断某个属性值是否在子查询的结果中
select a,b,c from a where a IN (select d from b ) 或者: select a,b,c from a where a IN (1,2,3)
(2)使用比较运算符的子查询
select a from table where a < (select avg(d) from b );
(3)使用ANY或ALL运算符的子查询
ANY表示至少一或者某一,ALL表示所有或每个;
select a,b,c from a where a <ANY(select d from b );
(4)使用EXISTS运算符的子查询
删除主表中已经在副表中没有的信息:delete from table1 where not exists ( select * from table2 where table1.field1=table2.field1 )
(5)组合查询
将多个查询结果的集合并起来,使用关键字UNION,并且会去掉重复的元组,如果需要保留重复的,则使用UNION ALL。
(select a,b,c from a where a=‘xxx’)union(select a,b,c from a where b = 'xxx');


分享到:
评论

相关推荐

    常用sql小结

    常用sql小结,描述了在日常数据库开发中经常用到的sql语句,以及对这些语句进行了相应的总结。

    SQL小结作业.docx

    SQL小结作业.docx 在这个资源中,我们可以提炼出以下知识点: 知识点1:创建数据库 在SQL中,创建数据库可以使用CREATE DATABASE语句,例如:Create database abcOn(name='abc',Filename='e:\abc.mdf')logOn(name...

    DB2 sql 小结

    本人应用db2过程中的一些总结,以及在使用的时候的一些注意事项

    SQL语句总结

    SQL小结

    SQL LOADER错误小结

    在使用SQL*Loader进行数据加载时,我们可能会遇到多种错误情况。SQL*Loader是一个Oracle数据库提供的工具,用于高效地从平面文件批量导入数据。以下是一些常见错误的总结及其解决方案: 1. **编码错误导致的乱码...

    个人 sql 学习小结

    个人 sql 学习小结 sql基础学习总结,

    SQL增删改查小结

    在这个“SQL增删改查小结”中,我们重点讨论了SQL的基本语句、数据库引擎、数据库对象以及如何执行CRUD操作(创建、读取、更新、删除)。 首先,数据库引擎的选择对数据库性能有很大影响。ISAM引擎在读取操作上速度...

    sql server 高级查询语句小结

    sql server 高级查询语句小结 讲述sql高级查询语句小结

    SQL知识小结-联查附例子

    SQL是Structured Query Language的缩写,是用于管理关系数据库的标准语言。本文主要总结了SQL中的基本操作:增、删、改、查,并给出了相应的实例。 一、增(INSERT) 插入数据是向数据库添加新记录的过程。插入单行...

    sqlserver 中时间为空的处理小结

    现将几种主要情况进行小结: 一、如何输入NULL值 如果不输入null值,当时间为空时,会默认写入”1900-01-01″,在业务处理时很麻烦。 ctrl+0即可输入NULL值。 二、如何在sql语句中判断为NULL的时间字段 假设表为:...

    数据库简单SQL语句小结,菜鸟不可不看

    数据库简单SQL语句小结,菜鸟不可不看数据库简单SQL语句小结,菜鸟不可不看

    SQL Server的链接服务器技术小结

    SQL Server 链接服务器技术小结 链接服务器技术是 SQL Server 中的一种功能,允许用户从一个 SQL Server 数据库访问其他数据库管理系统中的数据。这种技术可以帮助用户实现数据集成和数据交换,提高数据共享和协作...

    SQL server 和C#中的DateTime使用小结

    SQL Server 和 C# 中的 DateTime 使用小结 SQL Server 中的日期函数是数据库管理系统中非常重要的一部分,它提供了多种日期函数来操作日期类型的数据。同时,在 C# 中也提供了多种方法来处理日期类型的数据。本文将...

    SQL Server 最佳实践分析器使用小结

    SQL Server 最佳实践分析器使用小结 SQL Server 最佳实践分析器是 Microsoft SQL Server 开发团队开发的一个数据库管理工具,可以检测设计的数据库是否遵循 SQL Server 操作和管理的最佳实践准则。这些准则公认有助...

    PL/SQL Developer 使用技巧小结

    ### PL/SQL Developer 使用技巧小结 #### 一、PL/SQL Developer 记住登录密码功能 在使用 PL/SQL Developer 进行数据库操作时,频繁地输入用户名和密码可能会带来不便。为了提高工作效率,我们可以设置让 PL/SQL ...

    SQL SEVER常用语句小结

    根据提供的文件信息,我们可以总结出一系列关于SQL Server的常用语句及操作方法。这些语句在数据库管理和数据操作中非常实用。以下是对标题、描述以及部分文件内容中的关键知识点进行详细解析: ### 1. 创建表 ####...

    小结SQLServer连接失败错误及解决

    北京 在使用SQLServer的过程中,用户遇到的最多的问题莫过于连接失败了。一般而言,有以下两种连接SQLServer的方式,一是利用SQLServer自带的客户端工具,如企业管理器、查询分析器、事务探查器等;二是利用用户...

    PL SQL编程经验小结

    这些经验小结涵盖了PL/SQL中的关键概念和技术,包括数据处理优化、时间控制、数据返回以及游标的有效利用,旨在提升开发者的编程效率和代码质量。通过理解和应用这些知识,可以更好地应对复杂的数据库编程任务。

    1034543354315878mysql小结.sql

    1034543354315878mysql小结.sql

Global site tag (gtag.js) - Google Analytics