首页 > 代码库 > SQL学习整理_1

SQL学习整理_1

数据库是保存表和其他相关SQL结构的容器。

列是存储在表中的一块同类型数据。 行是一组能够描述某个事物的列的集合。

SQL不区分大小写,但建议命令采用大写,表名采用小写,便于读写。

 

建立数据库 CREATE DATABASE hf_test

新建数据表 CREATE TABLE test_list1

               (

        list1_name VARCHAR(10) NOT NULL DEFAULT **  PRIMARY KEY IDENTITY(1,1),

        list1_type VARCHAR(6),

      )

//指定主键可以在列定义时说明,也可单独说明 PRIMARY KEY(ID)

//IDENTITY(1,1)用于定义自增列

 

常见的数据类型

CHAR/VARCHAR, INT, TEXT, DATE, DEC , DATETIME

刚学到的CHAR/VARCHAR/NCHAR等类型的区别:

CHAR存储你指定的定长数据,检索数据时效率高,可存储1~8000个非unicode字符。

VARCHAR存储小于指定长度的可变长数据,检索数据时相对CHAR较低,可存储1~8000个非unicode字符。但VARCHAR的实际存储空间占N+1,1为数据长度。

NCHAR/NVARCHAR可存储unicode字符,但存储量为CHAR/VARCHAR的一半。但不必担心中英文数据的错乱。

一般来说,若包含中文数据则为NCHAR/NVARCHAR,纯英文和数字则为CHAR/NVARCHAR。

 

向数据表中插入数据

INSERT INTO list1_test (column_name...)

        VALUES(value1,value2)

//若不指定列名,则需为每个列都定义数据,默认按表格式顺序排列。

 

更新数据

UPDATE **

SET **

WHERE **

//如果要改变多行数据,只需把所有要修改的行和值放在一个SET子句中。

 

使用ALTER更新表:
ALTER命令几乎可以改变表中的一切属性,例如CHANGE 改变列名和数据类型;MODIFY仅改变数据类型;ADD添加新列;DROP删除特定列

ALTER TABLE ** ADD ** ; ALTER TABLE ** CHANGE COLUMN 列名,新数据类型

更改数据类型时,应注意格式转换时数据丢失的可能性。

 

重命名数据表(表名或列名):

EXEC SP_RENAME ‘oldname’ , ‘newname’

EXEC SP_RENAME ‘oldname.column‘,‘new column‘

EXEC是执行存储过程的命令

SP_RENAME是系统自带的存储过程重命名的指令

 

查看数据表

SELECT ** FROM **

WHERE ** AND **

GROUP BY **

HAVING **

//group by主要是将查询结果按类别分组

//having 一般包含聚会函数,从查询结果中检索符合条件的数据

 

删除数据表

DROP TABLE list1_test

删除特定某行数据

DELETE FROM **

WHERE **

//DELETE 不能删除单一列,可以用ALTER删除列

但DELETE可以删除所有行:DELETE FROM **

 

条件判断
AND, OR, LIKE, IS,BETWEEN, IN, NOT IN,

通配符% 表示任意数量的未知字符

     _  表示一个未知字符

 

定义文本数据时最好采用单引号,因为当SQL和其他数据语言结合使用时,会使用双引号表示开始引用。

 

注释以及一些快捷键整理:

单行注释: --

多行注释:\8    *\

ctrl+K+C/ctrl+K+U快捷添加移除注释

ctrl+alt+enter 全屏显示

ctrl+shift+u 转为大写

ctrl+delete 删除整行

ctrl+backspace 整词删除

 

---发于11/30/2016 1:05PM

SQL学习整理_1