zoukankan      html  css  js  c++  java
  • SQL语句小结

    建立数据库的完整过程 (先只记录一些不常用的,备忘)

    create database pages
    on primary --建立主文件
    (
     name = pages,
     filename = 'E:\myWebSite\myTest\App_Data\pages.mdf',
     size = 5MB,      --初始大小
     maxsize = 10MB,  --最大
     filegrowth = 1MB --每次增加大小
    ),      --主次文件间是有豆号的,
    filegroup subFile  --建立次要文件,可以建立若干个
    (
     name = subPages,
     filename = 'E:\myWebSite\myTest\App_Data\subPages.ndf',
     size = 1MB,
     maxsize = 10MB,
     filegrowth = 1MB
    )
    log on --建立日志文件
    (
     name = logPages,
     filename = 'E:\myWebSite\myTest\App_Data\logPages.ldf',
        maxsize = 10MB,
     filegrowth = 1MB
    )

    collate chinese_PRC_CI_AS
      --排序规则chinese_PRC_简体中文 CI 不分大小写
                                --AS 不区分重音

    -- Alter database XX 修改数据库
    -- Add file   或  (add log file)修改文件或修改日志文件
    --(
    --)
    --Drop database XX  删除数据库

    =====================================================

    use vote  -- 应用某数据库
    go
    SELECT * FROM voteDetails
    GO
    SELECT voteItem FROM voteDetails
    GO
    SELECT DISTINCT voteItem FROM voteDetails --查找无重复的记录
    GO
    SELECT * FROM voteDetails WHERE id= 1 OR voteDetailsID = 5
    GO
    SELECT * FROM voteDetails WHERE voteItem is null --查询某列为空
    --select 语句可以进行数学、逻辑运算
    SELECT voteItem,voteNum,voteNum+100 AS TEMP FROM voteDetails
    GO
    SELECT voteItem,voteNum,voteNum-100 TEMP FROM voteDetails
    GO
    SELECT voteItem,voteNum,voteNum*100  FROM voteDetails
    GO
    SELECT voteItem AS TEMPItem,voteNum,voteNum/100 FROM voteDetails
    GO
    SELECT voteItem,voteNum,voteNum%100 AS TEMP FROM voteDetails
    GO
    --逻辑运算符
    < > = <= >= != <>  AND OR NOT
    --不精确匹配 like %代表多个字符 _ 代表一个字符

    SELECT voteItem FROM voteDetails WHERE voteItem LIKE '很%' --查询以很开头的
    GO
    SELECT * FROM voteDetails WHERE voteItem LIKE '_满%'
    GO
    UNION -- 将两个查询结果去掉重复部分组合起来
    UNION ALL
    INTERSECT --返回两个表中共有的行

    SELECT name1 FROM table1 WHERE name1= 'lkf' UNIOn SELECT name2 FROM table2 WHERE name2= 'lkf'

    --SQL 语句的优化
    SELECT * FROM voteDetails WHERE voteItem = '很好' OR voteItem = '满意' OR voteItem ='不满意'
    --优化后
    SELECT * FROM voteDetails WHERE voteItem IN('很好','满意' ,'不满意')
    GO
    SELECT * FROM voteDetails WHERE voteNum >100 AND voteNum <10000
    GO
    SELECT * FROM voteDetails WHERE voteNum BETWEEN 100 AND 10000
    GO
    UPDATE voteDetails SET voteNum =10 WHERE voteDetailsID =8

    --█████████████████████████████████████████████████████
    -- SQL函数
    --avg 计算平均值
     SELECT AVG(voteNum) FROM voteDetails
    --count
    SELECT COUNT(id&voteDetailsID) FROM voteDetails
    --min max 最小值 最大值
     SELECT MIN(voteNum) FROM voteDetails
    GO
     SELECT MAX(voteNum) FROM voteDetails
    --sum 求和
     SELECT SUM(voteNum) FROM voteDetails

    SELECT GETDATE(),GETUTCDATE(),YEAR(GETDATE()),MONTH(GETDATE()),DAY(GETDATE())
    GO
    SELECT DATEPART(d,GETDATE()),DATENAME(d,GETDATE())--DATENAME返回指定日期部分的字符串
    GO
    SELECT DATEDIFF(d,GETDATE(),GETDATE()+2)--开始时间与被比较的时间的差值 d表示差的天数,s表示秒

    SELECT DATEADD(d,2,GETDATE())--当前时间加上指定时间后的时间

    SELECT ASCII(voteItem)  FROM voteDetails
    GO
    SELECT CHAR(65)
    GO
    SELECT NCHAR(65)--UNIC
    GO
    SELECT SOUNDEX(2)
    GO
    SELECT SPACE(12345)
    GO
    SELECT LEFT('ABCDEFGHRJKLMN',5)--左边取5个字符
    GO
    SELECT RIGHT('ABCDEFGHRJKLMN',5)
    GO
    SELECT LEN('ABCDEFGHRJKLMN')-- 字符串长度
    GO
    SELECT LOWER('FVVCFGGGFFFFFFFGHH'),UPPER('sffgcg hcfddfcdf')
    GO
    SELECT LTRIM('  ffffffff'),RTRIM('vvgjsv   ')--去掉左右空格

    --███████████████████████投票系统SQL脚本██████████████████████

    create database vote
    go
    use vote
    go
    --创建管理员信息表

    create table admin
    (
     id int identity(1,1) primary key,--主键,标识字段
     userName varchar(20) not null,--管理员登录帐号
     password varchar(20) not null--登录密码
    )
    go
    insert into admin(userName,password) values('fengyan','fengyan')
    go
    select * from admin
    go
    --投票主表
    create table voteMaster
    (
     id int identity(1,1) primary key,
     voteTitle varchar(30) not null,--投票的标题,(针对什么内容进行投票)
     voteSum int default(0)--相应标题下投票的总票数,初始值为0
    )
    go
    insert into voteMaster(voteTitle) values('对我们教程的满意度')
    insert into voteMaster(voteTitle) values('你从哪里得知浪曦在线')

    select * from voteMaster
    select * from voteDetails
    --创建投票从表
    go
    create table voteDetails
    (
     id int foreign key references voteMaster(id),--外键约束,确保数据的完整性
     voteDetailsID int identity(1,1) primary key,--主键,标识字段
     voteItem varchar(20) not null,--参与投票的选项
     voteNum int default(0)--相应选手得到的票数
    )
    go
    insert into voteDetails(id,voteItem) values(1,'非常满意')
    insert into voteDetails(id,voteItem) values(1,'比较满意')
    insert into voteDetails(id,voteItem) values(1,'很一般')
    insert into voteDetails(id,voteItem) values(1,'有待改进')
    insert into voteDetails(id,voteItem) values(2,'友情连接')
    insert into voteDetails(id,voteItem) values(2,'百度')
    insert into voteDetails(id,voteItem) values(2,'广告')
    insert into voteDetails(id,voteItem) values(2,'杂志')
    go
    --创建更新总票数的触发器
    create trigger updateVoteSum
    on voteDetails
    for update
    as
    begin
     update voteMaster set voteSum = voteSum+1 where id=(select top 1 id from inserted)
    end
    go
    --创建系统配置信息表
    create table voteConfig
    (
     id int foreign key references voteMaster(id),--设置系统前台需要调查的投票项
     checkIP int default(0),--系统是否限制IP,0为限制,1为不限制
     checkTime int default(0)--限制时间间隔,单位(分钟)
    )
    go
    insert into voteConfig(id) values(1)
    select * from voteConfig
    go
    --创建投票者信息表
    create table voter
    (
     id int foreign key references voteMaster(id),--该用户针对哪项调查进行投票,也加上外键约束
     ip varchar(30) not null,--该用户的IP
     voteTime datetime default(getdate()),--用户的投票时间
     voteNum int default(1) --该用户针对此项目投票的次数
    )
    go
    insert into voter(id,ip) values(1,'222.125.35.65')
    go
    select * from voter

    --█████████████████建立关系级联更新删除████████████████████████

    一、触发器方式:
    create trigger trg_A
    on A
    for update,delete
    as
    begin
        if exists(select 1 from inserted)
            update B set Name=(select Name from inserted) where Name=(select Name from deleted)
        else
            delete B where Name=(select Name from deleted)
    end
    go

    二、级联更新和级联删除方式:

    ALTER TABLE [dbo].[T_USERGROUP] ADD
            CONSTRAINT [FK_T_USERGROUP_T_ACCTTEMPLATE] FOREIGN KEY 
            (  [ATNAME] )

                 REFERENCES [dbo].[T_ACCTTEMPLATE]

           ( [ATNAME] ) ON UPDATE CASCADE ON DELETE CASCADE

    ================================================================================

     ALTER TABLE 表名1 add constraint 约束名 foreign key(字段) references 表名2(字段)on update cascade

    on delete cascade

    ==================================================================

    Ms Sql ADCCESS
    binary VarBinary
    bit Boolean
    char Char
    datetime Date
    decimal Numeric
    float Double
    int Integer
    money Currency
    nchar WChar
    ntext LongVarChar
    numeric Numeric
    nvarchar VarWChar
    real Single
    smalldatetime Date
    smallint SmallInt
    text LongVarChar
    timestamp Binary
    tinyint UnsignedTinyInt
    UniqueIdentifier GUID
    varBinary VarBinary
    varChar VarChar
  • 相关阅读:
    SQL Server 索引基本概念与优化
    将Heap RID转换成RID格式
    有关DeadLock的文章列表
    sql报字段过大的错误解决方法
    查询当天数据(mysql)
    cookie和session的区别
    get和post的区别
    jq点击切换按钮最简洁代码
    js提示确认删除吗
    thinkphp解决分页后序列号自增的问题
  • 原文地址:https://www.cnblogs.com/lkf18/p/1707652.html
Copyright © 2011-2022 走看看