sql server操作案例

简介: sql server操作案例

今天没事做,总结了下sql server的些知识:

--创建表
CREATE TABLE users
(
  id INT ,
  name VARCHAR(50),
  age INT
)
--添加数据
SELECT * FROM users
INSERT INTO users VALUES(2,'张三1',13);
INSERT INTO users VALUES(4,'王五',12,'山西省吕梁市',DEFAULT);   --默认性别是男,年龄必须大于0小于100
--创建一个Student表
CREATE TABLE student
(
  id INT ,
  name VARCHAR(50),
  age VARCHAR(50)
)
--将users表中的id name age 查询出来之后放在student表里面,其中student已经事先存在了
INSERT INTO student(id,name,age) SELECT id,name,age FROM users ;
SELECT * FROM student;
--将users表中的id name age address 查询出来放在新表studentinfo中,其中studentinfo事先不存在
SELECT id,name,age,address INTO studentinfo FROM users;
SELECT * FROM studentinfo;
--给studetninfo表里面一次插入多条记录
INSERT INTO studentinfo VALUES(5,'张无',45,'山东省济南市'),
(6,'张无1',45,'山东省济南市1'),
(7,'张无2',42,'山东省济南市2'),
(9,'张无3',78,'山东省济南市3')
SELECT * FROM studentinfo;
--修改users的信息,将张三的性别修改成女
SELECT * FROM users;
UPDATE users set sex='女' WHERE name='张三'
--删除张三1
DELETE FROM users WHERE name='张三1'
--查询
--使用别名AS
SELECT id AS '编号',name AS '姓名',age AS '年龄' FROM users
--使用别名.
SELECT id  '编号',name  '姓名',age  '年龄' FROM users
--合并两列数据
SELECT name+'.'+address FROM studentinfo;
--查询空行
INSERT INTO users (id,name,age) VALUES(5,'王宝宝',15);
SELECT * FROM users;
SELECT * FROM users WHERE address is null;
--查询前3行
SELECT top 2 * FROM users;
--按照百分数查询
SELECT top 10 percent * FROM users;
--按年龄排序(升序),编号降序
SELECT * FROM users order by age ASc,id desc;
--查询m在My Jbns Course里面出现的位置
SELECT CHARINDEX('m','My Jbns Course')
--查询My Jbns Course的长度
SELECT len('My Jbns Course')
--把传递给他的字符串转换成大写
SELECT UPPER('my is father');
--清除字符左边的空格
SELECT ltrim('     你是谁      ')
--清除字符右边的空格
SELECT rtrim(' 你是谁      ')
--从字符串右边返回指定的字符,4代表截取几个字符
SELECT RIGHT('买卖提5吐尔松',4)
--替换一个字符串中的字符:把(我)替换成(你)
SELECT replace('我是谁','我','你')
--在一个字符串中,删除指定长度的字符,并在改位置插入一个新字符,1是从第一个开始,5是截取5个
SELECT stuff('abcdefg',1,5,'明朝的皇帝是谁?')
--日期函数
--取得系统当前的日期
SELECT getdate()
--将指定的数值添加到指定的日期部分后的日期(yy:年,mm:月,dd:日,5代表加的数字)
SELECT DATEADD(yy,5,'01/01/2009')
--两个日期中指定日期的间隔(yy:年,mm:月,dd:日,输出一个整型)
SELECT DATEDIFF(yy,'2017-05-08','2019-05-04')
--日期中指定日期部分的字符串形式(yy:年,mm:月,dd:日,输出一个字符串:星期六)
SELECT datename(dw,'2015-05-09')
--日期中指定日期部分的整数形式
SELECT datepart(day,'2014-05-09')
--数学函数
--返回0-1之间的随机数float值
SELECT rand()
--取大于或等于指定数值、表达式的最小整数
SELECT ceiling(45.6)
--取数值表达式的绝对值
SELECT abs(-8)
--取小于或等于指定数值、表达式的最大整数
SELECT floor(32.8)
--取数值表达式的幂值(5的2次方)
SELECT power(5,2)
--取数值表达式四舍五入为指定的精度(2代表保留2位,其余的都是0)
SELECT round(3.1415926,2)
--对于正数返回+1,对于负数返回-1,对于0则返回0
SELECT sign(-1)
--取浮点表达式的平方根
SELECT sqrt(9)
--系统函数
--用来转变数据类型
SELECT CONVERT (VARCHAR (5),12345)
--返回当前用户的名字
SELECT CURRENT_USER
--返回用于指定表达式的字节数
SELECT DATALENGTH ('中国A联盟')
--返回当前用户所登录的计算机名字
SELECT HOST_NAME()
--返回当前所登录的用户名称
SELECT SYSTEM_USER
--从给定的用户ID返回用户名
SELECT USER_NAME(1)
--案例
--某公司印了一批充值卡,卡的密码是随机生成的,现在出现这个问题:
--卡里面的字母“O和数字0”、“字母i和数字1”,用户反映说看不清楚,
--公司决定,把存储在数据库中的密码中所有的“O”都改成“0”,把所有的“i”都改成“1”;
UPDATE Card SET PassWord = REPLACE(PassWord ,'O','0')
UPDATE Card SET PassWord = REPLACE(PassWord ,'i','1')
--使用函数更加简便
UPDATE  Card 
SET   PassWord = REPLACE(REPLACE(PassWord ,'O','0'),'i','1')
目录
相关文章
|
SQL 数据库 数据安全/隐私保护
数据库数据恢复——sql server数据库被加密的数据恢复案例
SQL server数据库数据故障: SQL server数据库被加密,无法使用。 数据库MDF、LDF、log日志文件名字被篡改。 数据库备份被加密,文件名字被篡改。
|
SQL 数据库
数据库数据恢复—SQL Server数据库报错“错误823”的数据恢复案例
SQL Server附加数据库出现错误823,附加数据库失败。数据库没有备份,无法通过备份恢复数据库。 SQL Server数据库出现823错误的可能原因有:数据库物理页面损坏、数据库物理页面校验值损坏导致无法识别该页面、断电或者文件系统问题导致页面丢失。
409 13
数据库数据恢复—SQL Server数据库报错“错误823”的数据恢复案例
|
SQL 数据库
数据库数据恢复—SQL Server报错“错误 823”的数据恢复案例
SQL Server数据库附加数据库过程中比较常见的报错是“错误 823”,附加数据库失败。 如果数据库有备份则只需还原备份即可。但是如果没有备份,备份时间太久,或者其他原因导致备份不可用,那么就需要通过专业手段对数据库进行数据恢复。
|
数据库 Windows
SqlServer数据恢复—SqlServer数据库所在分区损坏的数据恢复案例
一块硬盘上存放的SqlServer数据库,windows server操作系统+NTFS文件系统。由于误操作导致分区损坏,需要恢复硬盘里的SqlServer数据库数据。
|
存储 数据挖掘 数据库
数据库数据恢复—SQLserver数据库ndf文件大小变为0KB的数据恢复案例
一个运行在存储上的SQLServer数据库,有1000多个文件,大小几十TB。数据库每10天生成一个NDF文件,每个NDF几百GB大小。数据库包含两个LDF文件。 存储损坏,数据库不可用。管理员试图恢复数据库,发现有数个ndf文件大小变为0KB。 虽然NDF文件大小变为0KB,但是NDF文件在磁盘上还可能存在。可以尝试通过扫描&拼接数据库碎片来恢复NDF文件,然后修复数据库。
|
SQL 小程序 数据库
数据库数据恢复—SqlServer数据库无法被读取的数据恢复案例
SQL Server数据库的数据无法被读取。 经过数据库数据恢复工程师的初步检测,发现SQL Server数据库文件无法被读取的原因是底层File Record被截断为0,无法找到文件开头,而且数据表结构也已经损坏。镜像文件的前几十M和中间一部分空间被覆盖,系统表损坏,所以无法读取。
数据库数据恢复—SqlServer数据库无法被读取的数据恢复案例
|
SQL 数据库
数据库数据恢复—sqlserver数据库分区空间不足导致故障的数据恢复案例
数据库数据恢复环境: 某品牌r520服务器,服务器中有7块SAS硬盘,这7块硬盘组建了一组2盘raid1阵列和一组5盘raid5阵列,raid1阵列存储空间安装操作系统,raid5阵列存储空间存放数据。服务器上部署sql server数据库,数据库存放在C盘。 数据库故障: 工作人员发现服务器的C盘容量即将耗尽,于是将sql server数据库路径指向D盘,在D盘生成了一个.ndf文件。一个多星期后,sql server数据库出现故障,连接失效,无法正常附加查询。
数据库数据恢复—sqlserver数据库分区空间不足导致故障的数据恢复案例
|
SQL 存储 小程序
数据库数据恢复—Sql Server数据库文件丢失的数据恢复案例
数据库数据恢复环境: 5块硬盘组建一组RAID5阵列,划分LUN供windows系统服务器使用。windows系统服务器内运行了Sql Server数据库,存储空间在操作系统层面划分了三个逻辑分区。 数据库故障: 数据库文件丢失,主要涉及3个数据库,数千张表。数据库文件丢失原因未知,不能确定丢失的数据库文件的存放位置。数据库文件丢失后,服务器仍处于开机状态,所幸未写入大量数据。
数据库数据恢复—Sql Server数据库文件丢失的数据恢复案例
|
SQL 存储 安全
数据库数据恢复—SQL Server数据库出现逻辑错误的数据恢复案例
SQL Server数据库数据恢复环境: 某品牌服务器存储中有两组raid5磁盘阵列。操作系统层面跑着SQL Server数据库,SQL Server数据库存放在D盘分区中。 SQL Server数据库故障: 存放SQL Server数据库的D盘分区容量不足,管理员在E盘中生成了一个.ndf的文件并且将数据库路径指向E盘继续使用。数据库继续运行一段时间后出现故障并报错,连接失效,SqlServer数据库无法附加查询。管理员多次尝试恢复数据库数据但是没有成功。
|
SQL 存储 数据挖掘
数据库数据恢复—RAID5上层Sql Server数据库数据恢复案例
服务器数据恢复环境: 一台安装windows server操作系统的服务器。一组由8块硬盘组建的RAID5,划分LUN供这台服务器使用。 在windows服务器内装有SqlServer数据库。存储空间LUN划分了两个逻辑分区。 服务器故障&初检: 由于未知原因,Sql Server数据库文件丢失,丢失数据涉及到3个库,表的数量有3000左右。数据库文件丢失原因还没有查清楚,也不能确定数据存储位置。 数据库文件丢失后服务器仍处于开机状态,所幸没有大量数据写入。 将raid5中所有磁盘编号后取出,经过硬件工程师检测,没有发现明显的硬件故障。以只读方式将所有磁盘进行扇区级的全盘镜像,镜像完成后将所
数据库数据恢复—RAID5上层Sql Server数据库数据恢复案例