常用sql语句记录

1、表

--建表
if OBJECT_ID(‘Student‘) is not null
create table Student(
  ID int identity(1,1) not null,
  Name nvarchar(50),
  Code nvarchar(50),
  flag int default(0)
)

--建表时添加约束,表字段定义外键、由函数计算获得
CREATE TABLE [dbo].[A](
    [Id] [int] IDENTITY(1,1) NOT NULL primary key,
    [ClassId] [int] NOT NULL foreign key references [dbo].[Class] ([Id]) ,
    [Name] nvarchar(50),
    [InvoiceYear] int,
    [InvoiceMonth] int,
    [Date] AS  (dbo.ToDateFromPeriod(InvoiceYear,InvoiceMonth))PERSISTED,
    Memo nvarchar(50)  NULL
) 

--增加列
if not exists(select * from syscolumns where id=OBJECT_ID(‘Student‘) and name=‘ID‘)
alter table student add id int identity(1,1) not null

--添加主键约束
if OBJECT_ID(‘PK_Student‘) is not null
ALTER TABLE Student DROP CONSTRAINT [PK_ApprovalMatrix]
GO
ALTER TABLE Student  WITH CHECK ADD  CONSTRAINT [PK_ApprovalMatrix] PRIMARY KEY CLUSTERED (ID asc)
GO

--删除表
DELETE FROM [Student]

--清空标识值
DBCC  CHECKIDENT  (Student, RESEED,0)

--插入数据
IF NOT EXISTS(SELECT * FROM [Student] WHERE NAME=‘Win‘)
INSERT [Student] ([Code],[Memo]) VALUES (N‘CA‘,N‘Simon Deschenes‘)

--更新数据
UPDATE [dbo].[Student] SET Code = ‘001‘  WHERE NAME=‘Win‘

--insert into要求目标表Table2必须存在,由于目标表Table2已经存在,所以我们除了插入源表Table1的字段外,还可以插入常量
Insert into Table2(field1,field2,...) select value1,value2,... from Table1

--select into,要求目标表Table2不存在,因为在插入时会自动创建表Table2,并将Table1中指定字段数据复制到Table2中。
SELECT vale1, value2 into Table2 from Table1

insert into and select into :http://www.cnblogs.com/freshman0216/archive/2008/08/15/1268316.html

2、函数

2.1 --自定义函数,根据年月返回日期

USE TEST
        GO
        SET ANSI_NULLS ON
        GO
        SET QUOTED_IDENTIFIER ON
        GO
        Create function [dbo].[ToDateFromPeriod](@Year int, @Month int)
        returns datetime
        with SCHEMABINDING
        as
        -- Returns the first of the month for the specified year and month.
        begin
        return dateadd(mm,((@Year-1900)*12)[email protected],0)
        end

--调用自定义函数
        select dbo.[ToDateFromPeriod](‘2015‘,‘1‘) as result

2.2、表值函数

2.2.1 直接返回表

 create function getp(@id int)
       returns table as
       return select * from [Project] where [email protected]

2.2.2 返回自定义表

create function getp()
      returns @t table (id int ,name varchar(50))
      as 
        begin
           insert into @t select p.Id,p.Name from Project p
           return 
        end

3、判断对象是否存在

3.1 判断用户是否存在,并创建

if USER_ID(‘fas‘) is null

CREATE USER [fas] WITHOUT LOGIN WITH DEFAULT_SCHEMA=[dbo]

其他相关判断参考http://www.cnblogs.com/fumj/archive/2012/07/15/2592558.html

4、给角色db_owner添加用户dds

EXEC sp_addrolemember ‘db_owner‘, ‘dds‘

角色功能https://www.mssqltips.com/sqlservertip/1900/understanding-sql-server-fixed-database-roles/

时间: 2024-08-07 13:52:55

常用sql语句记录的相关文章

Oracle数据库常用Sql语句大全

一,数据控制语句 (DML) 部分 1.INSERT  (往数据表里插入记录的语句) INSERT INTO 表名(字段名1, 字段名2, --) VALUES ( 值1, 值2, --); INSERT INTO 表名(字段名1, 字段名2, --)  SELECT (字段名1, 字段名2, --) FROM 另外的表名; 字符串类型的字段值必须用单引号括起来, 例如: 'GOOD DAY' 如果字段值里包含单引号' 需要进行字符串转换, 我们把它替换成两个单引号''. 字符串类型的字段值超过

oracle常用SQL语句(汇总版)

Oracle数据库常用sql语句 ORACLE 常用的SQL语法和数据对象 一.数据控制语句 (DML) 部分 1.INSERT (往数据表里插入记录的语句) INSERT INTO 表名(字段名1, 字段名2, ……) VALUES ( 值1, 值2, ……); INSERT INTO 表名(字段名1, 字段名2, ……) SELECT (字段名1, 字段名2, ……) FROM 另外的表名; 字符串类型的字段值必须用单引号括起来, 例如: ’GOOD DAY’ 如果字段值里包含单引号’ 需要

学生表 课程表 成绩表 教师表常用SQL语句

学生表 课程表 成绩表 教师表 50个常用sql语句 建表 Student(S#,Sname,Sage,Ssex) 学生表 Course(C#,Cname,T#) 课程表 SC(S#,C#,score) 成绩表 Teacher(T#,Tname) 教师表 ---- If database exists the same name datatable deletes it. IF EXISTS(SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHE

经典MSSQL语句大全和常用SQL语句命令的作用

下列语句部分是Mssql语句,不可以在access中使用. SQL分类: DDL类型包括数据库.表的创建,修改,删除,声明—数据定义语言(CREATE,ALTER,DROP,DECLARE) DML类型包括数据表中记录的查询,删除,修改,插入—数据操纵语言(SELECT,DELETE,UPDATE,INSERT) DCL类型包括数据库用户赋权,废除用户访问权限, 提交当前事务,中止当前事务—数据控制语言(GRANT,REVOKE,COMMIT,ROLLBACK) 首先,简要介绍基础语句: 1.说

Oracle 数据库常用sql语句及知识

<Oracle 数据库> 一.常用sql语句: 1.连接系统管理员账号:conn system/system(安装时口令); 2.创建新账号:create user Leo(账号名) identified by Leo(密码): 3.给新账号授权:grant connect,resource to Leo; 4.从某个账户收权:revoke resource from Leo; 5.连接新账号:conn Leo/Leo; 6.显示当前客户:show user; 7.查看表结构:desc s_e

学生表 课程表 成绩表 教师表 50个常用sql语句[转]

Student(S#,Sname,Sage,Ssex) 学生表 Course(C#,Cname,T#) 课程表 SC(S#,C#,score) 成绩表 Teacher(T#,Tname) 教师表   create table Student(S# varchar(20),Sname varchar(10),Sage int,Ssex varchar(2)) 前面加一列序号: if exists(select table_name from information_schema.tables wh

用友维护常用SQL语句脚本

用友维护常用SQL语句脚本(经典)(上) 用友维护人员常用SQL 脚本 --查询用友版本号 use ufsystem go select * from UA_Version go ----------------------------------------------------------------- --查看系统用户信息表 use ufsystem selec ... 用友维护人员常用SQL 脚本--查询用友版本号use ufsystemgoselect * from UA_Versi

MySQL(用户管理,常用sql语句,数据库备份恢复,MySQL调优,恢复误操作数据)

一.MySQL用户管理. 一个MySQL数据库里可以跑多个库,总不能给所有人的程序员root用户,则可以给他们单独的用户访问数据库. 创建用户:(grant all on *.* to 'user1'是把所有库的权限给'user1,他的来源Ip是127.0.0.1,他的密码是lty123456') (第一个*是库名,如果你写成mysql.*那就是对mysql库的所有权限) (来源ip也可以写成 % ,表示来源的所有ip) (grant这种语句是不会记录到命令历史里去的,因为不安全.) mysql

常用sql语句,SSC源码开发堪称经典

1.查询"001"课程比"002"课程成绩高的所有学生的学号; select a.S# from (select S#,score from SC where C#='001') a,(select S#,score from SC where C#='002') b where a.score>b.score and a.S#=b.S#; 2.查询平均成绩大于60分的同学的学号和平均成绩; select S#,avg(score) from SC group