网站导航网学 原创论文 原创专题 网站设计 最新系统 原创论文 论文降重 发表论文 论文发表 UI设计定制 论文答辩PPT格式排版 期刊发表 论文专题
返回网学首页
网学原创论文
最新论文 推荐专题 热门论文 论文专题
当前位置: 网学 > 交易代码 > SQL语法 > 正文

SQL标准语法手册

论文降重修改服务、格式排版等 获取论文 论文降重及排版 论文发表 相关服务

【网学网提醒】:本文主要为网学会员提供SQL标准语法手册,希望对需要SQL标准语法手册网友有所帮助,学习一下!


    Select用途:用途:从指定表中取出指定的列的数据语法:语法:
    SELECTcolumn_name(s)FROMtable_name
    解释:解释:从数据库中选取资料列,并允许从一或多个资料表中,选取一或多个资料列或资料行。SELECT陈述式的完整语法相当复杂,但主要子句可摘要为:SELECTselect_list[INTOnew_table]FROMtable_source[WHEREsearch_condition][GROUPBYgroup_by_expression][HAVINGsearch_condition][ORDERBYorder_expression[ASC|DESC]]
    例:
    “Persons”表中的数据有LastNameHansenSvendsonPettersenFirstNameOlaToveKariAddressTimoteivn10Borgvn23Storgt20CitySandnesSandnesStavanger
    选出字段名”LastName”、”FirstName”的数据
    SELECTLastName,FirstNameFROMPersons
    返回结果:LastNameHansenSvendsonPettersenFirstNameOlaToveKari
    选出所有字段的数据
    SELECT*FROMPersons
    返回结果:
    LastNameHansenSvendsonPettersen
    FirstNameOlaToveKari
    AddressTimoteivn10Borgvn23Storgt20
    CitySandnesSandnesStavanger
     Where用途:用途:被用来规定一种选择查询的标准语法:语法:
    SELECTcolumnFROMtableWHEREcolumnconditionvalue
    下面的操作符能被使用在WHERE中:=,<>,>,<,>=,<=,BETWEEN,LIKE注意:在某些SQL的版本中不等号<>能被写作为!=
    解释:解释:SELECT语句返回WHERE子句中条件为true的数据例:
    从”Persons”表中选出生活在”Sandnes”的人
    SELECT*FROMPersonsWHERECity='Sandnes'
    "Persons"表中的数据有:
    LastNameHansenSvendsonSvendsonPettersen
    FirstNameOlaToveStaleKari
    AddressTimoteivn10Borgvn23Kaivn18Storgt20
    CitySandnesSandnesSandnesStavanger
    Year1951197819801960
    返回结果:
    LastNameHansenSvendsonSvendson
    FirstNameOlaToveStale
    AddressTimoteivn10Borgvn23Kaivn18
    CitySandnesSandnesSandnes
    Year195119781980
    And&;Or
    用途:用途:在WHERE子句中AND和OR被用来连接两个或者更多的条件解释:解释:AND在结合两个布尔表达式时,只有在两个表达式都为TRUE时才传回TRUEOR在结合两个布尔表达式时,只要其中一个条件为TRUE时,OR便传回TRUE例:
    "Persons"表中的原始数据:
     LastNameHansenSvendsonSvendson
    FirstNameOlaToveStephen
    AddressTimoteivn10Borgvn23Kaivn18
    CitySandnesSandnesSandnes
    用AND运算子来查找"Persons"表中FirstName为”Tove”而且LastName为”Svendson”的数据
    SELECT*FROMPersonsWHEREFirstName='Tove'ANDLastName='Svendson'
    返回结果:
    LastNameSvendson
    FirstNameTove
    AddressBorgvn23
    CitySandnes
    用OR运算子来查找"Persons"表中FirstName为”Tove”或者LastName为”Svendson”的数据
    SELECT*FROMPersonsWHEREfirstname='Tove'ORlastname='Svendson'
    返回结果:
    LastNameSvendsonSvendson
    FirstNameToveStephen
    AddressBorgvn23Kaivn18
    CitySandnesSandnes
    你也
    能结合AND和OR(使用括号形成复杂的表达式),如:
    SELECT*FROMPersonsWHERE(FirstName='Tove'ORFirstName='Stephen')ANDLastName='Svendson'
    返回结果:
    LastNameSvendsonSvendson
    FirstNameToveStephen
    AddressBorgvn23Kaivn18
    CitySandnesSandnes
    Between…And用途:用途:
     指定需返回数据的范围语法:语法:
    SELECTcolumn_nameFROMtable_nameWHEREcolumn_nameBETWEENvalue1ANDvalue2
    例:
    “Persons”表中的原始数据
    LastNameHansenNordmannPettersenSvendsonFirstNameOlaAnnaKariToveAddressTimoteivn10Neset18Storgt20Borgvn23CitySandnesSandnesStavangerSandnes
    用BETWEEN…AND返回LastName为从”Hansen”到”Pettersen”的数据:
    SELECT*FROMPersonsWHERELastNameBETWEEN'Hansen'AND'Pettersen'
    返回结果:
    LastNameHansenNordmannPettersenFirstNameOlaAnnaKariAddressTimoteivn10Neset18Storgt20CitySandnesSandnesStavanger
    为了显示指定范围之外的数据,也可以用NOT操作符:
    SELECT*FROMPersonsWHERELastNameNOTBETWEEN'Hansen'AND'Pettersen'
    返回结果:
    LastNameSvendsonFirstNameToveAddressBorgvn23CitySandnes
    Distinct用途:用途:DISTINCT关键字被用作返回唯一的值语法:语法:
    SELECTDISTINCTcolumn-name(s)FROMtable-name
    解释:解释:当column-name(s)中存在重复的值时,返回结果仅留下一个例:“Orders”表中的原始数据
    CompanyOrderNumber
     SegaW3SchoolsTrioW3Schools
    3412231246786798
    用DISTINCT关键字返回Company字段中唯一的值:
    SELECTDISTINCTCompanyFROMOrders
    返回结果:
    CompanySegaW3SchoolsTrio
    Orderby用途:用途:指定结果集的排序语法:语法:
    SELECTcolumn-name(s)FROMtable-nameORDERBY{order_by_expression[ASC|DESC]}
    解释:解释:指定结果集的排序,可以按照ASC(递增方式排序,从最低值到最高值)或者DESC(递减方式排序,从最高值到最低值)的方式进行排序,默认的方式是ASC例:“Orders”表中的原始数据:
    CompanySegaABCShopW3SchoolsW3SchoolsOrderNumber3412567823126798
    按照Company字段的升序方式返回结果集:
    SELECTCompany,OrderNumberFROMOrdersORDERBYCompany
    返回结果:
    CompanyABCShopSegaW3SchoolsW3SchoolsOrderNumber5678341267982312
    按照Company字段的降序方式返回结果集:
     SELECTCompany,OrderNumberFROMOrdersORDERBYCompanyDESC
    返回结果:
    CompanyW3SchoolsW3SchoolsSegaABCShopOrderNumber6798231234125678
    Groupby用途:用途:对结果集进行分组,常与汇总函数一起使用。语法:语法:
    SELECTcolumn,SUM(column)FROMtableGROUPBYcolumn
    例:“Sales”表中的原始数据:
    CompanyW3SchoolsIBMW3SchoolsAmount550045007100
    按照Company字段进行分组,求出每个Company的Amout的合计:
    SELECTCompany,SUM(Amount)FROMSalesGROUPBYCompany
    返回结果::
    CompanyW
    3SchoolsIBMSUM(Amount)126004500
    Having用途:用途:指定群组或汇总的搜寻条件。语法:语法:
    SELECTcolumn,SUM(column)FROMtableGROUPBYcolumnHAVINGSUM(column)conditionvalue
    解释:解释:HAVING通常与GROUPBY子句同时使用。不使用GROUPBY时,HAVING则与WHERE子句功能相似。例:
     “Sales”表中的原始数据:
    CompanyW3SchoolsIBMW3SchoolsAmount550045007100
    按照Company字段进行分组,求出每个Company的Amout的合计在10000以上的数据:
    SELECTCompany,SUM(Amount)FROMSalesGROUPBYCompanyHAVINGSUM(Amount)>10000
    返回结果::
    CompanyW3SchoolsSUM(Amount)12600
    Join用途:用途:当你要从两个或者以上的表中选取结果集时,你就会用到JOIN。例:
    “Employees”表中的数据如下,(其中ID为主键):ID01020304NameHansen,OlaSvendson,ToveSvendson,StephenPettersen,Kari
    “Orders”表中的数据如下:ID010303ProductPrinterTableChair
    用Employees的ID和Orders的ID相关联选取数据:
    SELECTEmployees.Name,Orders.ProductFROMEmployees,OrdersWHEREEmployees.ID=Orders.ID
    返回结果:NameHansen,OlaSvendson,StephenSvendson,StephenProductPrinterTableChair
    或者你也可以用JOIN关键字来完成上面的操作:
    SELECTEmployees.Name,Orders.Product
     FROMEmployeesINNERJOINOrdersONEmployees.ID=Orders.ID
    INNERJOIN的语法:的语法:
    SELECTfield1,field2,field3FROMfirst_tableINNERJOINsecond_tableONfirst_table.keyfield=second_table.foreign_keyfield
    解释:解释:INNERJOIN返回的结果集是两个表中所有相匹配的数据。LEFTJOIN的语法:的语法:
    SELECTfield1,field2,field3FROMfirst_tableLEFTJOINsecond_tableONfirst_table.keyfield=second_table.foreign_keyfield
    用”Employees”表去左外联结”Orders”表去找出相关数据:
    SELECTEmployees.Name,Orders.ProductFROMEmployeesLEFTJOINOrdersONEmployees.ID=Orders.ID
    返回结果:
    NameHansen,OlaSvendson,ToveSvendson,StephenSvendson,StephenPettersen,KariTableChairProductPrinter
    解释:解释:LEFTJOIN返回”first_table”中所有的行尽管在”second_table”中没有相匹配的数据。RIGHTJOIN的语法:的语法:
    SELECTfield1,field2,field3FROMfirst_tableRIGHTJOINsecond_tableONfirst_table.keyfield=second_table.foreign_keyfield
    用”Employees”表去右外联结”Orders”表去找出相关数据:
    SELECTEmployees.Name,Orders.ProductFROMEmployeesRIGHTJOINOrdersONEmployees.ID=Orders.ID
     返回结果:
    NameHansen,OlaSvendson,StephenSvendson,StephenProductPrinterTableChair
    解释:解释:RIGHTJOIN返回”second_table”中所有的行尽管在”first_table”中没有相匹配的数据。
    Alias
    用途:用途:可用在表、结果集或者列上,为它们取一个逻辑名称语法:语法:给列取
    别名:
    SELECTcolumnAScolumn_aliasFROMtable
    给表取别名:
    SELECTcolumnFROMtableAStable_alias
    例:“Persons”表中的原始数据:
    LastNameHansenSvendsonPettersen运行下面的SQL:FirstNameOlaToveKariAddressTimoteivn10Borgvn23Storgt20CitySandnesSandnesStavanger
    SELECTLastNameASFamily,FirstNameASNameFROMPersons
    返回结果::
    FamilyHansenSvendsonPettersen运行下面的SQL:NameOlaToveKari
    SELECTLastName,FirstNameFROMPersonsASEmployees
    返回结果::Employees中的数据有:
    LastNameHansenSvendsonPettersenFirstNameOlaToveKari
     InsertInto
    用途:用途:在表中插入新行语法:语法:插入一行数据
    INSERTINTOtable_nameVALUES(value1,value2,....)插入一行数据在指定的字段上INSERTINTOtable_name(column1,column2,...)VALUES(value1,value2,....)
    例:“Persons”表中的原始数据:
    LastNamePettersenFirstNameKariAddressStorgt20CityStavanger
    运行下面的SQL插入一行数据:
    INSERTINTOPersonsVALUES('Hetland','Camilla','Hagabakka24','Sandnes')
    插入后”Persons”表中的数据为::
    LastNamePettersenHetlandFirstNameKariCamillaAddressStorgt20Hagabakka24CityStavangerSandnes
    运行下面的SQL插入一行数据在指定的字段上:
    INSERTINTOPersons(LastName,Address)VALUES('Rasmussen','Storgt67')
    插入后”Persons”表中的数据为::
    LastNamePettersenHetlandRasmussenFirstNameKariCamillaAddressStorgt20Hagabakka24Storgt67CityStavangerSandnes
    Update
    用途:用途:更新表中原有数据语法:语法:
    UPDATEtable_nameSETcolumn_name=new_valueWHEREcolumn_name=some_value
    例:“Person”表中的原始数据:
     LastNameNilsenRasmussen
    FirstNameFred
    AddressKirkegt56Storgt67
    CityStavanger
    运行下面的SQL将Person表中LastName字段为”Rasmussen”的FirstName更新为”Nina”:
    UPDATEPersonSETFirstName='Nina'WHERELastName='Rasmussen'
    更新后”Person”表中的数据为::
    LastNameNilsenRasmussenFirstNameFredNinaAddressKirkegt56Storgt67CityStavanger
    同样的,用UPDATE语句也可以同时更新多个字段:
    UPDATEPersonSETAddress='Stien12',City='Stavanger'WHERELastName='Rasmussen'
    更新后”Person”表中的数据为::
    LastNameNilsenRasmussenFirstNameFredNinaAddressKirkegt56Stien12CityStavangerStavanger
    Delete
    用途:用途:删除表中的数据语法:语法:
    DELETEFROMtable_nameWHEREcolumn_name=some_value
    例:“Person”表中的原始数据:
    LastNameNilsenRasmussenFirstNameFredNinaAddressKirkegt56Stien12CityStavangerStavanger
    删除Person表中LastName为”Rasmussen”的数据:
    DELETEFROMPersonWHERELastName='Rasmussen'
    执行删除语句后”Person”表中的数据为::
    LastNameNilsenFirstNameFredAddressKirkegt56CityStavanger
    CreateTab
    le
    用途:用途:建立新的资料表。
     语法:语法:
    CREATETABLEtable_name(column_name1data_type,column_name2data_type,.......)
    例:创建一张叫“Person”的表,该表有4个字段"LastName","FirstName","Address","Age":
    CREATETABLEPerson(LastNamevarchar,FirstNamevarchar,Addressvarchar,Ageint)
    如果想指定字段的最大存储长度,你可以这样:
    CREATETABLEPerson(LastNamevarchar(30),FirstNamevarchar(30),Addressvarchar(120),Ageint(3))
    下表中列出了在SQL的一些数据类型:
    DataTypeinteger(size)int(size)smallint(size)tinyint(size)decimal(size,d)numeric(size,d)Holdnumberswithfractions.Themaximumnumberofdigitsarespecifiedin"size".Themaximumnumberofdigitstotherightofthedecimalisspecifiedin"d".char(size)Holdsafixedlengthstring(cancontainletters,numbers,andspecialcharacters).Thefixedsizeisspecifiedinparenthesis.varchar(size)Holdsavariablelengthstring(cancontainletters,numbers,andspecialcharacters).Themaximumsizeisspecifiedinparenthesis.date(yyyymmdd)HoldsadateDescriptionHoldintegersonly.Themaximumnumberofdigitsarespecifiedinparenthesis.
    AlterTable
    用途:用途:
     在已经存在的表中增加后者移除字段语法:语法:
    ALTERTABLEtable_nameADDcolumn_namedatatypeALTERTABLEtable_nameDROPCOLUMNcolumn_name
    注意:注意:某些数据库管理系统不允许移除表中的字段例:“Person”表中的原始数据:
    LastNamePettersenFirstNameKariAddressStorgt20
    在Person表中增加一个名为City的字段:
    ALTERTABLEPersonADDCityvarchar(30)
    增加后表中数据如下:
    LastNamePettersenFirstNameKariAddressStorgt20City
    移除Person表中原有的Address字段::
    ALTERTABLEPersonDROPCOLUMNAddress
    移除后表中数据如下:
    LastNamePettersenFirstNameKariCity
    DropTable
    用途:用途:在数据库中移除一个数据表定义及该数据表中的所有资料、索引、触发程序、条件约束及权限指定。语法:语法:
    DROPTABLEtable_name
    CreateDatabase
    用途:用途:建立新的数据库.语法:语法:
    CREATEDATABASEdatabase_name
     DropDatabase
    用途:用途:移除原有的数据库语法:语法:
    DROPDATABASEdatabase_name
    聚集函数
    count用途:用途:传回选取的结果集中行的数目。语法:语法:
    SELECTCOUNT(column_name)FROMtable_name
    例:“Persons”表中原始数据如下:
    NameHansen,OlaSvendson,TovePettersen,KariAge344519
    选取记录总数:
    SELECTCOUNT(Name)FROMPersons
    执行结果:
    3
    sum用途:用途:以表达式传回所有值的总和,或仅DISTINCT值。SUM仅可用于数值资料行。已忽略Null值。语法:语法:
    SELECTSUM(column_name)FROMtable_name
    例:“Persons”表中原始数据如下:
    NameHansen,OlaSvendson,TovePetter
    sen,KariAge344519
    选取”Persons”表中所有人的年龄总和:
    SELECTSUM(Age)FROMPersons
    执行结果:
    98
    选取”Persons”表中年龄超过20岁的人的年龄总和:
     SELECTSUM(Age)FROMPersonsWHEREAge>20
    执行结果:
    79
    avg用途:用途:传回选取的结果集中值的平均值。已忽略Null值。语法:语法:
    SELECTAVG(column_name)FROMtable_name
    例:“Persons”表中原始数据如下:
    NameHansen,OlaSvendson,TovePettersen,KariAge344519
    选取”Persons”表中所有人的平均年龄:
    SELECTAVG(Age)FROMPersons
    执行结果:
    32.67
    选取”Persons”表中年龄超过20岁的人的平均年龄:
    SELECTAVG(Age)FROMPersonsWHEREAge>20
    执行结果:
    39.5
    max用途:用途:传回选取的结果集中值的最大值。已忽略Null值。语法:语法:
    SELECTMAX(column_name)FROMtable_name
    例:“Persons”表中原始数据如下:
    NameHansen,OlaSvendson,TovePettersen,KariAge344519
    选取”Persons”表中的最大年龄:
    SELECTMAX(Age)FROMPersons
    执行结果:
    45
     min用途:用途:传回选取的结果集中值的最小值。已忽略Null值。语法:语法:
    SELECTMIN(column_name)FROMtable_name
    例:“Persons”表中原始数据如下:
    NameHansen,OlaSvendson,TovePettersen,KariAge344519
    选取”Persons”表中的最小年龄:
    SELECTMIN(Age)FROMPersons
    执行结果:
    19
    算术函数abs用途:用途:传回指定数值表达式(NumericExpression)的绝对正值。语法:语法:
    ABS(numeric_expression)
    例:
    ABS(-1.0)ABS(0.0)ABS(1.0)
    执行结果:
    1.00.01.0
    ceil用途:用途:传回大于等于给定数值表达式的最小整数。语法:语法:
    CEIL(numeric_expression)
    例:
    CEIL(123.45)CEIL(-123.45)
    执行结果:
    124.00-123.00
     floor用途:用途:传回小于或等于给定数值表达式的最大整数。语法:语法:
    FLOOR(numeric_expression)
    例:
    FLOOR(123.45)FLOOR(-123.45)
    执行结果:
    123.00-124.00
    cos用途:用途:在指定表达式中传回指定角度(以弪度为单位)的三角余弦值的数学函数。语法:语法:
    COS(numeric_expression)
    例:
    COS(14.78)
    执行结果:
    -0.599465
    cosh用途:用途:传回以弧度为单位的角度值,其余弦为指定的float表达式,也称为反余弦。语法:语法:
    COSH(numeric_expression)
    例:
    COSH(-1)
    执行结果:
    3.14159
    sin用途:用途:以近似的数值(float表达式传回给定角度(以弧度)之三角正弦函数(Trigonometricfloat)floatSine)。语法:语法:
    SIN(numeric_expression)
    例:
    SIN(45.175643)
    执行结果:
    0.929607
     sinh用途:用途:传回以弪度为单位的角度,其正弦为指定的float表达式(也称为反正弦)。语法:语法:
    SINH(numeric_expression)
    例:
    SINH(-1.00)
    执行结果:
    -1.5708
    tan用途:用途:
    传回输入表达式的正切函数。语法:语法:
    TAN(numeric_expression)
    例:
    TAN(3.14159265358979/2)
    执行结果:
    1.6331778728383844E+16
    tanh用途:用途:传回以弪度为单位的角度,其正切为指定的float表达式(也称为反正切)。语法:语法:
    TANH(numeric_expression)
    例:
    TANH(-45.01)
    执行结果:
    -1.54858
    exp用途:用途:传回给定的float表达式的指数(Exponential)值。语法:语法:
    EXP(numeric_expression)
    例:
    EXP(378.615345498)
    执行结果:
    2.69498e+164
     log用途:用途:传回给定的float表达式之自然对数。语法:语法:
    LOG(numeric_expression)
    例:
    LOG(5.175643)
    执行结果:
    1.64396
    power用途:用途:传回给定表达式指定乘幂的值。语法:语法:
    POWER(numeric_expression,v)
    例:
    POWER(2,6)
    执行结果:
    64
    sign用途:用途:传回给定的表达式之正(+1)、零(0)或负(-1)号。语法:语法:
    SIGN(numeric_expression)
    例:
    SIGN(123)SIGN(0)SIGN(-456)
    执行结果:
    10-1
    sqrt用途:用途:传回给定表达式的平方。语法:语法:
    SQRT(numeric_expression)
    例:
    SQRT(10)
    执行结果:
    100
    
    
  • 上一篇资讯: SQL毕业生信息管理系统
  • 设为首页 | 加入收藏 | 网学首页 | 原创论文 | 计算机原创
    版权所有 网学网 [Myeducs.cn] 您电脑的分辨率是 像素
    Copyright 2008-2020 myeducs.Cn www.myeducs.Cn All Rights Reserved 湘ICP备09003080号 常年法律顾问:王律师