数据库操作----找了MySQL和SQL Sever两个的基础语句
这是MySQL的基本操作:
1 登入数据库:mysql -uroot -p+密码 (SQL Sever登入: osql -U 用户名 -P 密码)
显示已存在的数据库:show databases;
使用某个数据库:use+数据库名;
显示某个数据库下已存在的关系表:show tables; 查看某个关系表所有数据:select * from tableName;
查看某个关系表部分字段数据:select 字段1,字段2,...,字段n from tableName;
查看n条记录:select ... from ... limit n;
查看第i条到第j条之间的记录:select ... from ... limit i,j; 使用order by 来对记录进行排序,默认从小到大
>select stuName, stuScore from student order by stuScore desc; //(从大到小)
>select stuName, stuScore from student order by stuScore asc; //(从小到大) 去重: distinct
>select distinct stuCourse from student;
> select count(distinct stuCourse) from student; 聚合函数(常用于GROUP BY从句的SELECT查询中)
AVG(col)返回指定列的平均值
COUNT(col)返回指定列中非NULL值的个数
MIN(col)返回指定列的最小值
MAX(col)返回指定列的最大值
SUM(col)返回指定列的所有值之和
GROUP_CONCAT(col) 返回由属于一组的列值连接组合而成的结果
> select stuCourse, sum(stuScore) from student where stuCourse = "Chinese";
> select stuCourse, sum(stuScore) from student group by stuCourse;
> select stuCourse, avg(stuScore) from student group by stuCourse;
> select stuCourse, max(stuScore) from student group by stuCourse;
> select stuCourse, min(stuScore) from student group by stuCourse;
> select avg(stuAge) as avg_age from student;
> select group_concat(stuName, stuCourse) from student; 条件限制:where : =, !=, >, >=, <, <=, and, not, or
, between...and..., not between...and...
, is null, is not null, like(%, _), not like(%, _)
, in(项1, 项2, …), not in(项1, 项2, …)
, exists, not exists
, any, some, all %: 匹配任意个字符
_:匹配单个字符 创建数据库:create database 数据库名;
创建关系表:create table tableName(字段1 类型 限制,字段2 类型 限制,...,字段n 类型 限制);
显示关系表的格式:show create table tableName;
更新数据:update tableName set 字段1 = 字段1值, 字段2 = 字段2值, ..., 字段n = 字段n值; 插入数据:insert tableName(字段1,字段2,...,字段n) values(字段1值,字段2值,...,字段n值); 生成一个关系表的备份:create table baktableName (select * from tableName);
使用备份的数据对新表插入数据
> insert book select * from bookBak; 生成一个数据库的备份:mysqldump -uUserName -p dbname > bakefile;
使用数据库的备份恢复数据库:mysql -uUserName -p dbname < bakefile; 使用交互方式恢复数据库:
> create database dbName; (如果不存在这个数据库)
> use dbName;
> source bakeFile; 删除一个数据库:drop database dbname;
删除关系表中所有数据:delete from tableName;
删除关系表中符合条件的数据:delete from tableName where...; 给关系表增加一个字段:alter table tableName add 字段名 说明(default 'H');
给关系表删除一个字段:alter table tableName drop 字段名;
给关系表修改一个字段:alter table tableName modify 字段名 说明;
给关系表修改一个字段:alter table tableName change 旧字段名 新字段名 说明(类型...); 设置字段值唯一,即该字段的值不允许有重复的: unique
> create table tmp(id int unique not null, name varchar()); 主键:唯一标识一条记录,主键可以是单个字段,也可以是多个字段合成的
> alter table student modify stuId varchar() primary key not null; > create table book(bookId bigint auto_increment primary key not null, bookName varchar() not null);
> create table book(bookId bigint auto_increment not null, bookName varchar() not null, primary key(bookId)); > create table score(stuId varchar() not null,
> bookId bigInt not null,
> score float,
> primary key(stuId, bookId)); 多表查询
> select score.bookId, stuName, bookName from score, student, book where score.bookId = book.bookId and score.stuId = student.stuId;
> select score.bookId, stuName, bookName, score from score, student, book where score.bookId = book.bookId and score.stuId = student.stuId; 外键
> alter table score add constraint stuId_cons foreign key(stuId) references student(stuId);
> alter table score add constraint bookId_cons foreign key(bookId) references book(bookId); > create table tecbook(tecId varchar() not null, bookId bigint not null, primary key(tecId, bookId), foreign key(tecId) references teacher(tecId), foreign key(bookId) references book(bookId)); 学生表student(stuId,stuName,stuAge,stuSex)
mysql> create table student(stuId varchar() primary key not null,
-> stuName varchar() not null,
-> stuAge int,
-> stuSex char); 教师表 teacher(tecId,tecName)
mysql> create table teacher(tecId varchar() primary key not null,
-> tecName varchar() not null); 课程表course(courseId,courseName,tecId)
mysql> create table course(courseId bigint primary key auto_increment not null,
-> courseName varchar() not null,
-> tecId varchar() not null,
-> foreign key(tecId) references teacher(tecId) on update cascade on delete cascade); 成绩表score(stuId,courseId,score,note)
mysql> create table score(stuId varchar() not null,
-> courseId bigint not null,
-> score float,
-> note varchar(),
-> primary key(stuId, courseId),
-> foreign key(stuId) references student(stuId) on delete cascade on update cascade,
-> foreign key(courseId) references course(courseId) on delete no action on update cascade); 级联操作:
foreign key(column) references tableName(column)
[[on delete | on update] [cascade | no action | set null | restrict]]; 查询每个学生每门课的成绩
> select stuName, courseName, score from student, course, score where student.stuId = score.stuId
and course.courseId = score.courseId; 查询每个学生的总成绩
> select stuName, sum(score) from student, course, score where student.stuId = score.stuId
and course.courseId = score.courseId group by stuName; 对每个学生的总成绩排序
> select stuName, sum(score) as sum_score from student, course, score where student.stuId = score.stuId
and course.courseId = score.courseId group by stuName order by sum_score desc; 查询每个学生的平均成绩
> select stuName, avg(score) from student, course, score where student.stuId = score.stuId
and course.courseId = score.courseId group by stuName; 查询平均成绩>80的学生
> select stuName, avg(score) as avg_score from student, course, score where student.stuId = score.stuId and course.courseId = score.courseId group by stuName having avg_score > ;
Note: having字句可以让我们筛选成组后的各种数据,where字句在聚合前先筛选记录,也就是说作用在group by和having字句前。而 having子句在聚合后对组记录进行筛选。 查询“”课程比“”课程成绩高的所有学生的学号
> select t1.stuId from (select stuId, score from score where courseId = ) as t1,
(select stuId, score from score where courseId = ) as t2 where t1.score < t2.score
and t1.stuId = t2.stuId; > select stuId from score s1 where courseId = and score <
(select score from score s2 where courseId = and s1.stuId = s2.stuId); > select s1.stuId from score s1, score s2 where s1.score < s2.score and s1.stuId = s2.stuId
and s1.courseId = and s2.courseId = ; 查询所有同学的学号、姓名、课数、总成绩
> select score.stuId, stuName, count(courseId) as course_num, sum(score) as sum_score from score, student where score.stuId = student.stuId group by stuId; 查询和likui性别相同的学生信息
> select stuId, stuName from student where stuSex = (select stuSex from student where stuName = "likui")
and stuName != "likui"; 查询没学过“mozi”老师课的同学的学号、姓名
> select distinct score.stuId, stuName from score, student where score.stuId = student.stuId
and score.stuId !=
(
select stuId from score where courseId in
(
select courseId from course where tecId =
(select tecId from teacher where tecName = "mozi")
)
); 查询每个老师所教课程平均分从高到低显示
> select c.courseId, c.courseName, avg(sc.score) avgScore, t.tecName from course c, score sc, teacher t where c.courseId = sc.courseId and c.tecId = t.tecId group by(sc.courseId) order by avgScore DESC; > select course.tecId, teacher.tecName, t1.courseId, t1.avg_score from (select courseId, avg(score) as avg_score from score group by courseId) as t1, course, teacher where t1.courseId = course.courseId and course.tecId = teacher.tecId; 删除学习“laozi”老师课的score表记录
> delete from score where courseId in (select courseId from course
where tecId = (select tecId from teacher where tecName = "laozi")); 查询两门及以上不及格课程的同学的学号及其平均成绩
> select stuId, avg(score) from score where stuId in (select stuId from score where score < group by stuId having count(*) >= ) group by stuId; > select stuId, avg(score) from score where stuId in (select stuId from (select stuId, count(*) as blow from score where score < group by stuId having blow >= )as t1) group by stuId; 查询各科成绩最高和最低的分:以如下形式显示:课程ID,最高分,最低分
> select courseId, max(score), min(score) from score group by courseId; 查询学过“”并且也学过编号“”课程的同学的学号、姓名
> select stuId, stuName from student where stuId in (select s1.stuId from score s1, score s2 where s1.courseId = and s2.courseId = and s1.stuId = s2.stuId); 查询“”课程的分数比“”课程平均分低的学生stuId, stuName
> select stuId, stuName from student where stuId in(select stuId from score where score < (select avg(score) from score where courseId = ) and courseId = ); 查询“”课程的分数比“”课程平均分低的学生stuId, stuName, score
> select score.stuId, stuName, score from score, student where score < (select avg(score) from score
where courseId = ) and courseId = and score.stuId = student.stuId; 查询“”课程的分数比“”课程平均分低的学生stuId, stuName, score, avg_score
> select score.stuId, stuName, (select avg(score) from score where courseId = ) as avg_score, score from score, student where score < (select avg(score) from score where courseId = ) and courseId = and score.stuId = student.stuId; view: 是视图,是一张虚表,表中没有任何数据
> create view score_view as select score.stuId, stuName, count(courseId) as course_num, sum(score) as sum_score from score, student where score.stuId = student.stuId group by stuId; > select * from score_view; 存储过程:
delimiter $$
create procedure proName(in | out | inout)
begin
commands;
end
$$ mysql> delimiter //
mysql> create procedure pro_new()
-> begin
-> select * from student;
-> select * from course;
-> select * from teacher;
-> end
-> //
mysql> delimiter ;
mysql> call pro_new; mysql> delimiter //
mysql> create procedure addTec(in id varchar(), in name varchar())
-> begin
-> insert teacher(tecId, tecName) values(id, name);
-> end
-> // mysql> delimiter ;
mysql> call addTec("", "daai"); mysql> delimiter //
mysql> create procedure pp(out op int)
-> begin
-> set op = ;
-> end
-> // mysql> delimiter ;
mysql> set @opp = ;
mysql> select @opp;
mysql> call pp(@opp);
mysql> select @opp; , if-then-else 分支
if condition then
commands;
[elseif condition then
commands;]
[else
commands;]
end if; mysql> delimiter //
mysql> create procedure sala_pro4(in level int)
> begin
> if level = then
> update teacher set tecSalary = where tecLevel = level;
> elseif level = then
> update teacher set tecSalary = where tecLevel = level;
> elseif level = then
> update teacher set tecSalary = where tecLevel = level;
> else
> select * from teacher;
> end if;
> end// > show create procedure proName;
> show procedure status;
> drop procedure proName; ,case 分支
case expression
when value1 then
commands;
[when value2 then
commands;]
[else
commands;]
end case; mysql> create procedure tec_pro(in level int)
> begin
> case level
> when then
> update teacher set tecSalary = where tecLevel = ;
> when then
> update teacher set tecSalary = where tecLevel = ;
> when then
> update teacher set tecSalary = where tecLevel = ;
> when then
> update teacher set tecSalary = where tecLevel = ;
> when then
> update teacher set tecSalary = where tecLevel = ;
> else
> select * from teacher;
> end case;
> end// while 循环
[loopName:] while condition do
commands;
end while [loopName]; mysql> create procedure show_pro(in id bigint)
> begin
> declare var int;
> set var = ;
> while var < do
> select * from course where courseId = id + var;
> set var = var + ;
> end while;
> end// repeat-until 循环
[loopName:] repeat
commands;
until condition
end repeat [loopName]; mysql> create procedure ins_pro2(in name varchar())
> begin
> declare tim int;
> set tim = ;
> repeat
> insert usename(Name, Time, Level) values(name, tim, tim);
> set tim = tim + ;
> until tim >
> end repeat;
> end// loop 循环
loopName: loop
commands;
end loop loopName; 函数创建:
create function(...) returns valueType
begin
commands;
return value;
end mysql> create function test(n int) returns text
> begin
> declare i int default ;
> declare s text default '';
> myloop: loop
> set i = i + ;
> set s = concat(s, "*");
> if i >= n then
> leave myloop;
> end if;
> end loop myloop;
> return s;
> end// mysql> select test();
mysql> set @tt = test(); ,游标定义:declare cursorName cursor for select...
,打开游标:open cursorName
,使用fetch cursorName into var1,var2,...命令去遍历select结果数据表里的数据记录
,关闭游标:close cursorName(游标会在对它们做出声明的 begin-end 语句块执行终了时自动随之结束)
备注:若使用fetch命令把select结果数据表的记录都读完了会出发一个错误:no data to fetch。
对于该错误可以定义一个错误处理器来捕获。出错处理条件一般使用 not found 即可 mysql> create procedure cur_pro2()
> begin
> declare result varchar() default '';
> declare name varchar();
> declare done int default ;
> declare cur_book cursor for select courseName from course;
> declare continue handler for not found set done = ;
> open cur_book;
> repeat
> fetch cur_book into name;
> set result = concat(result, name);
> until done
> end repeat;
> select result;
> close cur_book;
> end//
下面是SQL Sever的语法,其实基本上差不多,这两天我所用到,大概也就一个递增、一个级联不同
一、基础 、说明:创建数据库
CREATE DATABASE database-name
、说明:删除数据库
drop database dbname
、说明:备份sql server
— 创建 备份数据的 device
USE master
EXEC sp_addumpdevice ‘disk’, ‘testBack’, ‘c:\mssql7backup\MyNwind_1.dat’
— 开始 备份
BACKUP DATABASE pubs TO testBack
、说明:创建新表
create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..) 根据已有的表创建新表:
A:create table tab_new like tab_old (使用旧表创建新表)
B:create table tab_new as select col1,col2… from tab_old definition only
、说明:删除新表
drop table tabname
、说明:增加一个列
Alter table tabname add column col type
注:列增加后将不能删除。DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。
、说明:添加主键: Alter table tabname add primary key(col)
说明:删除主键: Alter table tabname drop primary key(col)
、说明:创建索引:create [unique] index idxname on tabname(col….)
删除索引:drop index idxname
注:索引是不可更改的,想更改必须删除重新建。
、说明:创建视图:create view viewname as select statement
删除视图:drop view viewname
、说明:几个简单的基本的sql语句 选择:select * from table1 where 范围
插入:insert into table1(field1,field2) values(value1,value2)
删除:delete from table1 where 范围
更新:update table1 set field1=value1 where 范围
查找:select * from table1 where field1 like ’%value1%’ —like的语法很精妙,查资料!
排序:select * from table1 order by field1,field2 [desc]
总数:select count as totalcount from table1
求和:select sum(field1) as sumvalue from table1
平均:select avg(field1) as avgvalue from table1
最大:select max(field1) as maxvalue from table1
最小:select min(field1) as minvalue from table1
、说明:几个高级查询运算词
A: UNION 运算符
UNION 运算符通过组合其他两个结果表(例如 TABLE1 和 TABLE2)并消去表中任何重复行而派生出
一个结果表。当 ALL 随 UNION 一起使用时(即 UNION ALL),
不消除重复行。两种情况下,派生表的每一行不是来自 TABLE1 就是来自 TABLE2。
B: EXCEPT 运算符
EXCEPT运算符通过包括所有在 TABLE1 中但不在 TABLE2 中的行并消除所有重复行而派生出一个结果表。
当 ALL 随 EXCEPT 一起使用时 (EXCEPT ALL),不消除重复行。
C: INTERSECT 运算符
INTERSECT运算符通过只包括 TABLE1 和 TABLE2 中都有的行并消除所有重复行而派生出一个结果表。
当 ALL随 INTERSECT 一起使用时 (INTERSECT ALL),不消除重复行。
注:使用运算词的几个查询结果行必须是一致的。
、说明:使用外连接
A、left (outer) join:
左外连接(左连接):结果集几包括连接表的匹配行,也包括左连接表的所有行。
SQL: select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c
B:right (outer) join:
右外连接(右连接):结果集既包括连接表的匹配连接行,也包括右连接表的所有行。
C:full/cross (outer) join:
全外连接:不仅包括符号连接表的匹配行,还包括两个连接表中的所有记录。
、分组:Group by:
一张表,一旦分组 完成后,查询后只能得到组相关的信息。
组相关的信息:(统计信息) count,sum,max,min,avg 分组的标准)
在SQLServer中分组时:不能以text,ntext,image类型的字段作为分组依据
在selecte统计函数中的字段,不能和普通的字段放在一起; 、对数据库进行操作:
分离数据库: sp_detach_db;附加数据库:sp_attach_db 后接表明,附加需要完整的路径名
.如何修改数据库的名称:
sp_renamedb ‘old_name’, ‘new_name’ 二、提升
、说明:复制表(只复制结构,源表名:a 新表名:b) (Access可用)
法一:select * into b from a where <>(仅用于SQlServer)
法二:select top * into b from a
、说明:拷贝表(拷贝数据,源表名:a 目标表名:b) (Access可用)
insert into b(a, b, c) select d,e,f from b; 、说明:跨数据库之间表的拷贝(具体数据使用绝对路径) (Access可用)
insert into b(a, b, c) select d,e,f from b in ‘具体数据库’ where 条件
例子:..from b in ‘”&Server.MapPath(“.”)&”\data.mdb” &”‘ where.. 、说明:子查询(表名1:a 表名2:b)
select a,b,c from a where a IN (select d from b ) 或者: select a,b,c from a where a IN (,,) 、说明:显示文章、提交人和最后回复时间
select a.title,a.username,b.adddate from table a,(select max(adddate) adddate from table where table.title=a.title) b 、说明:外连接查询(表名1:a 表名2:b)
select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c 、说明:在线视图查询(表名1:a )
select * from (SELECT a,b,c FROM a) T where t.a > ; 、说明:between的用法,between限制查询数据范围时包括了边界值,not between不包括
select * from table1 where time between time1 and time2
select a,b,c, from table1 where a not between 数值1 and 数值2 、说明:in 的使用方法
select * from table1 where a [not] in (‘值1’,’值2’,’值4’,’值6’) 、说明:两张关联表,删除主表中已经在副表中没有的信息
delete from table1 where not exists ( select * from table2 where table1.field1=table2.field1 ) 、说明:四表联查问题:
select * from a left inner join b on a.a=b.b right inner join c on a.a=c.c inner join d on a.a=d.d where ….. 、说明:日程安排提前五分钟提醒
SQL: select * from 日程安排 where datediff(‘minute’,f开始时间,getdate())> 、说明:一条sql 语句搞定数据库分页
select top b.* from (select top 主键字段,排序字段 from 表名 order by 排序字段 desc) a,表名 b where b.主键字段 = a.主键字段 order by a.排序字段
具体实现:
关于数据库分页: declare @start int,@end int @sqlnvarchar() set @sql=’select top’+str(@end-@start+)+’+from T where rid not in(select top’+str(@str-)+’Rid from T where Rid>-)’ exec sp_executesql @sql 注意:在top后不能直接跟一个变量,所以在实际应用中只有这样的进行特殊的处理。Rid为一个标识列,如果top后还有具体的字段,这样做是非常有好处的。因为这样可以避免 top的字段如果是逻辑索引的,查询的结果后实际表中的不一致(逻辑索引中的数据有可能和数据表中的不一致,而查询时如果处在索引则首先查询索引) 、说明:前10条记录
select top * form table1 where 范围 、说明:选择在每一组b值相同的数据中对应的a最大的记录的所有信息(类似这样的用法可以用于论坛每月排行榜,每月热销产品分析,按科目成绩排名,等等.)
select a,b,c from tablename ta where a=(select max(a) from tablename tb where tb.b=ta.b) 、说明:包括所有在 TableA中但不在 TableB和TableC中的行并消除所有重复行而派生出一个结果表
(select a from tableA ) except (select a from tableB) except (select a from tableC) 、说明:随机取出10条数据
select top * from tablename order by newid() 、说明:随机选择记录
select newid() 、说明:删除重复记录
),delete from tablename where id not in (select max(id) from tablename group by col1,col2,…)
),select distinct * into temp from tablename
delete from tablename
insert into tablename select * from temp
评价: 这种操作牵连大量的数据的移动,这种做法不适合大容量但数据操作
),例如:在一个外部表中导入数据,由于某些原因第一次只导入了一部分,但很难判断具体位置,这样只有在下一次全部导入,这样也就产生好多重复的字段,怎样删除重复字段 alter table tablename
–添加一个自增列
addcolumn_b int identity(,)
delete from tablename where column_b not in(
select max(column_b)from tablename group by column1,column2,…)
alter table tablename drop column column_b 、说明:列出数据库里所有的表名
select name from sysobjects where type=’U’ // U代表用户 、说明:列出表里的所有的列名
select name from syscolumns where id=object_id(‘TableName’) 、说明:列示type、vender、pcs字段,以type字段排列,case可以方便地实现多重选择,类似select 中的case。
select type,sum(case vender when ‘A’ then pcs else end),sum(case vender when ‘C’ then pcs else end),sum(case vender when ‘B’ then pcs else end) FROM tablename group by type
显示结果:
type vender pcs
电脑 A
电脑 A
光盘 B
光盘 A
手机 B
手机 C 、说明:初始化表table1 TRUNCATE TABLE table1 、说明:选择从10到15的记录
select top * from (select top * from table order by id asc) table_别名 order by id desc 三、技巧 、=,=2的使用,在SQL语句组合时用的较多 “where =” 是表示选择全部 “where =”全部不选,
如:
if @strWhere !=”
begin
set @strSQL = ‘select count(*) as Total from [' + @tblName + '] where ‘ + @strWhere
end
else
begin
set @strSQL = ‘select count(*) as Total from [' + @tblName + ']‘
end 我们可以直接写成 错误!未找到目录项。
set @strSQL = ‘select count(*) as Total from [' + @tblName + '] where = 安定 ‘+ @strWhere 、收缩数据库
–重建索引
DBCC REINDEX
DBCC INDEXDEFRAG
–收缩数据和日志
DBCC SHRINKDB
DBCC SHRINKFILE 、压缩数据库
dbcc shrinkdatabase(dbname) 、转移数据库给新用户以已存在用户权限
exec sp_change_users_login ‘update_one’,'newname’,'oldname’
go 、检查备份集
RESTORE VERIFYONLY from disk=’E:\dvbbs.bak’ 、修复数据库
ALTER DATABASE [dvbbs] SET SINGLE_USER
GO
DBCC CHECKDB(‘dvbbs’,repair_allow_data_loss) WITH TABLOCK
GO
ALTER DATABASE [dvbbs] SET MULTI_USER
GO 、日志清除
SET NOCOUNT ON
DECLARE @LogicalFileName sysname,
@MaxMinutes INT,
@NewSize INT USE tablename — 要操作的数据库名
SELECT @LogicalFileName = ‘tablename_log’, — 日志文件名
@MaxMinutes = , — Limit on time allowed to wrap log.
@NewSize = — 你想设定的日志文件的大小(M) Setup / initialize
DECLARE @OriginalSize int
SELECT @OriginalSize = size
FROM sysfiles
WHERE name = @LogicalFileName
SELECT ‘Original Size of ‘ + db_name() + ‘ LOG is ‘ +
CONVERT(VARCHAR(),@OriginalSize) + ‘ 8K pages or ‘ +
CONVERT(VARCHAR(),(@OriginalSize*/)) + ‘MB’
FROM sysfiles
WHERE name = @LogicalFileName
CREATE TABLE DummyTrans
(DummyColumn char () not null) DECLARE @Counter INT,
@StartTime DATETIME,
@TruncLog VARCHAR()
SELECT @StartTime = GETDATE(),
@TruncLog = ‘BACKUP LOG ‘ + db_name() + ‘ WITH TRUNCATE_ONLY’ DBCC SHRINKFILE (@LogicalFileName, @NewSize)
EXEC (@TruncLog)
– Wrap the log if necessary.
WHILE @MaxMinutes > DATEDIFF (mi, @StartTime, GETDATE()) — time has not expired
AND @OriginalSize = (SELECT size FROM sysfiles WHERE name = @LogicalFileName)
AND (@OriginalSize * /) > @NewSize
BEGIN — Outer loop.
SELECT @Counter =
WHILE ((@Counter < @OriginalSize / ) AND (@Counter < ))
BEGIN — update
INSERT DummyTrans VALUES (‘Fill Log’) DELETE DummyTrans
SELECT @Counter = @Counter +
END
EXEC (@TruncLog)
END
SELECT ‘Final Size of ‘ + db_name() + ‘ LOG is ‘ +
CONVERT(VARCHAR(),size) + ‘ 8K pages or ‘ +
CONVERT(VARCHAR(),(size*/)) + ‘MB’
FROM sysfiles
WHERE name = @LogicalFileName
DROP TABLE DummyTrans
SET NOCOUNT OFF 、说明:更改某个表
exec sp_changeobjectowner ‘tablename’,'dbo’ 、存储更改全部表 CREATE PROCEDURE dbo.User_ChangeObjectOwnerBatch
@OldOwner as NVARCHAR(),
@NewOwner as NVARCHAR()
AS DECLARE @Name as NVARCHAR()
DECLARE @Owner as NVARCHAR()
DECLARE @OwnerName as NVARCHAR() DECLARE curObject CURSOR FOR
select ‘Name’ = name,
‘Owner’ = user_name(uid)
from sysobjects
where user_name(uid)=@OldOwner
order by name OPEN curObject
FETCH NEXT FROM curObject INTO @Name, @Owner
WHILE(@@FETCH_STATUS=)
BEGIN
if @Owner=@OldOwner
begin
set @OwnerName = @OldOwner + ‘.’ + rtrim(@Name)
exec sp_changeobjectowner @OwnerName, @NewOwner
end
– select @name,@NewOwner,@OldOwner FETCH NEXT FROM curObject INTO @Name, @Owner
END close curObject
deallocate curObject
GO 、SQL SERVER中直接循环写入数据
declare @i int
set @i=
while @i<
begin
insert into test (userid) values(@i)
set @i=@i+
end
案例:
有如下表,要求就裱中所有沒有及格的成績,在每次增長0.1的基礎上,使他們剛好及格: Namescore Zhangshan80 Lishi Wangwu Songquan69 while((select min(score) from tb_table)<) begin update tb_table set score =score*1.01 where score< if(select min(score) from tb_table)> break else continue end 数据开发-经典 .按姓氏笔画排序:
Select * From TableName Order By CustomerName Collate Chinese_PRC_Stroke_ci_as //从少到多 .数据库加密:
select encrypt(‘原始密码‘)
select pwdencrypt(‘原始密码‘)
select pwdcompare(‘原始密码‘,’加密后密码‘) = –相同;否则不相同 encrypt(‘原始密码‘)
select pwdencrypt(‘原始密码‘)
select pwdcompare(‘原始密码‘,’加密后密码‘) = –相同;否则不相同 .取回表中字段:
declare @list varchar(),
@sql nvarchar()
select @list=@list+‘,’+b.name from sysobjects a,syscolumns b where a.id=b.id and a.name=‘表A’
set @sql=‘select ‘+right(@list,len(@list)-)+‘ from 表A‘
exec (@sql) .查看硬盘分区:
EXEC master..xp_fixeddrives .比较A,B表是否相等:
if (select checksum_agg(binary_checksum(*)) from A)
=
(select checksum_agg(binary_checksum(*)) from B)
print ‘相等‘
else
print ‘不相等‘ .杀掉所有的事件探察器进程:
DECLARE hcforeach CURSOR GLOBAL FOR SELECT ‘kill ‘+RTRIM(spid) FROM master.dbo.sysprocesses
WHERE program_name IN(‘SQL profiler’,N’SQL 事件探查器‘)
EXEC sp_msforeach_worker ‘?‘ .记录搜索:
开头到N条记录
Select Top N * From 表
——————————-
N到M条记录(要有主索引ID)
Select Top M-N * From 表 Where ID in (Select Top M ID From 表) Order by ID Desc
———————————-
N到结尾记录
Select Top N * From 表 Order by ID Desc
案例
例如1:一张表有一万多条记录,表的第一个字段 RecID 是自增长字段, 写一个SQL语句, 找出表的第31到第40个记录。 select top recid from A where recid notin(select top recid from A) 分析:如果这样写会产生某些问题,如果recid在表中存在逻辑索引。 select top recid from A where……是从索引中查找,而后面的select top recid from A则在数据表中查找,这样由于索引中的顺序有可能和数据表中的不一致,这样就导致查询到的不是本来的欲得到的数据。 解决方案 ,用order by select top recid from A order by ricid 如果该字段不是自增长,就会出现问题 ,在那个子查询中也加条件:select top recid from A where recid>- 例2:查询表中的最后以条记录,并不知道这个表共有多少数据,以及表结构。
set @s = ‘select top * from Twhere pid not in (select top ‘ + str(@count-) + ‘ pidfrom T)’ print @sexecsp_executesql@s :获取当前数据库中的所有用户表
select Name from sysobjects where xtype=’u’ and status>= :获取某一个表的所有字段
select name from syscolumns where id=object_id(‘表名‘) select name from syscolumns where id in (select id from sysobjects where type = ‘u’ and name = ‘表名‘) 两种方式的效果相同 :查看与某一个表相关的视图、存储过程、函数
select a.* from sysobjects a, syscomments b where a.id = b.id and b.text like ‘%表名%’ :查看当前数据库中所有存储过程
select name as 存储过程名称 from sysobjects where xtype=’P’ :查询用户创建的所有数据库
select * from master..sysdatabases D where sid not in(select sid from master..syslogins where name=’sa’)
或者
select dbid, name AS DB_NAME from master..sysdatabases where sid <> × :查询某一个表的字段和数据类型
select column_name,data_type from information_schema.columns
where table_name = ‘表名‘ :不同服务器数据库之间的数据操作 –创建链接服务器 exec sp_addlinkedserver’ITSV ‘, ‘ ‘, ‘SQLOLEDB ‘, ‘远程服务器名或ip地址 ‘ exec sp_addlinkedsrvlogin’ITSV ‘, ‘false ‘,null, ‘用户名 ‘, ‘密码 ‘ –查询示例 select * from ITSV.数据库名.dbo.表名 –导入示例 select * into 表 from ITSV.数据库名.dbo.表名 –以后不再使用时删除链接服务器 exec sp_dropserver’ITSV ‘, ‘droplogins ‘ –连接远程/局域网数据(openrowset/openquery/opendatasource)
–、openrowset –查询示例 select * from openrowset( ‘SQLOLEDB ‘, ‘sql服务器名 ‘; ‘用户名 ‘; ‘密码 ‘,数据库名.dbo.表名) –生成本地表 select * into 表 from openrowset( ‘SQLOLEDB ‘, ‘sql服务器名 ‘; ‘用户名 ‘; ‘密码 ‘,数据库名.dbo.表名) –把本地表导入远程表
insert openrowset( ‘SQLOLEDB ‘, ‘sql服务器名 ‘; ‘用户名 ‘; ‘密码 ‘,数据库名.dbo.表名) select *from 本地表 –更新本地表 update b set b.列A=a.列A from openrowset( ‘SQLOLEDB ‘, ‘sql服务器名 ‘; ‘用户名 ‘; ‘密码 ‘,数据库名.dbo.表名)as a inner join 本地表 b on a.column1=b.column1 –openquery用法需要创建一个连接 --首先创建一个连接创建链接服务器 exec sp_addlinkedserver’ITSV ‘, ‘ ‘, ‘SQLOLEDB ‘, ‘远程服务器名或ip地址 ‘ –查询 select * FROM openquery(ITSV,’SELECT *FROM 数据库.dbo.表名 ‘) –把本地表导入远程表 insert openquery(ITSV,’SELECT *FROM 数据库.dbo.表名 ‘) select * from 本地表 –更新本地表 update b set b.列B=a.列B FROM openquery(ITSV,’SELECT * FROM 数据库.dbo.表名 ‘) as a inner join 本地表 b on a.列A=b.列A –、opendatasource/openrowset
SELECT* FROMopendatasource( ‘SQLOLEDB ‘,’Data Source=ip/ServerName;User ID=登陆名;Password=密码 ‘ ).test.dbo.roy_ta –把本地表导入远程表 insert opendatasource( ‘SQLOLEDB ‘,’Data Source=ip/ServerName;User ID=登陆名;Password=密码 ‘).数据库.dbo.表名 select * from 本地表 SQL Server基本函数 SQL Server基本函数 .字符串函数 长度与分析用 ,datalength(Char_expr) 返回字符串包含字符数,但不包含后面的空格
,substring(expression,start,length) 取子串,字符串的下标是从“”,start为起始位置,length为字符串长度,实际应用中以len(expression)取得其长度
,right(char_expr,int_expr) 返回字符串右边第int_expr个字符,还用left于之相反
,isnull( check_expression , replacement_value )如果check_expression為空,則返回replacement_value的值,不為空,就返回check_expression字符操作类 ,Sp_addtype自定義數據類型
例如:EXEC sp_addtype birthday, datetime, 'NULL' ? 内存溢出
其实、这些语句,如果需要想不起来,就看一下,很方便的。
数据库操作----找了MySQL和SQL Sever两个的基础语句的更多相关文章
- C#---数据库访问通用类、Access数据库操作类、mysql类 .[转]
原文链接 //C# 数据库访问通用类 (ADO.NET)using System;using System.Collections.Generic;using System.Text;using Sy ...
- C#---数据库访问通用类、Access数据库操作类、mysql类 .
//C# 数据库访问通用类 (ADO.NET)using System;using System.Collections.Generic;using System.Text;using System. ...
- C# 中的数据库操作~存储过程篇Mysql SqlServer
Mysql 存储过程查询方式 SQL server 普通数据库操作 EF 调用SQL SERVER存储过程 Mysql 存储过程查询方式: public NetPort GetNetdevicePor ...
- Android中SQLite数据库操作(1)——使用SQL语句操作SQLite数据库
下面是最原始的方法,用SQL语句操作数据库.后面的"Android中SQLite数据库操作(2)--SQLiteOpenHelper类"将介绍一种常用的android封装操作SQL ...
- python 数据库操作 SQLite、MySQL 摘录
转自: http://www.cnblogs.com/windlaughing/p/3157531.html 不管使用什么后台数据库,代码所遵循的过程都是一样的:连接 -> 创建游标 -> ...
- PHP数据库操作:从MySQL原生API到PDO
本文将举详细例子向大家展示PHP是如何使用MySQL原生API.MySQLi面向过程.MySQLi面向对象.PDO操作MySQL数据库的. 为了后面的测试,先建立数据库表test.包含表名user,s ...
- win7+SQL2008无法打开物理文件 操作系统错误 5:拒绝访问 SQL Sever
今天在win7+SQL2008的环境下操作分离附加数据库,分离出去然后再附加,没有问题.但是一把.mdf文件拷到其它文件夹下就出错,错误如下:无法打开物理文件 "E:\db\MyDB.mdf ...
- 无法打开物理文件 操作系统错误 5:拒绝访问 SQL Sever
今天分离附加数据库,分离出去然后再附加,没有问题.但是一把.mdf文件拷到其它文件夹下就出错,错误如下: 无法打开物理文件 "E:\db\homework.mdf".操作系统 ...
- sql语言 含有包含关系的查询 (含mysql 和sql sever)
一.sql中查询包含关系的查询 sql语句中包含关系可以使用 in 和exist,但有些时候仅仅用这两个是不够的,还有表示方法是 not exist(b expect a )可以表示a包含b. 二. ...
随机推荐
- 在MongoDB中修改数据类型
引言 本文主要讲解Mongodb的类型转换.包括:string转double, string转int, string转Date. 0. 出现类型不一致的原因 ES导入数据到Mongo后,会出现类型统一 ...
- linux下安装mysql的三种方法:rpm包安装、yum安装、源码包安装
1 安装MySQL数据库服务器安装方法一://查询系统自带的数据库rpm -qa | grep -i mysql //卸载查询到的所有mysqlrpm -e --nodeps mysql-libs-5 ...
- Jquery中的toggle()方法
Jquery中的toggle()方法,有一次在看别人写的Jquery插件时,发现对toggle有如下使用 search.pagePrevious.toggle(data.pageNumber > ...
- php array数组(第二部分)
array_fill() 用给定的键值填充数组 参数 index 必须.规定返回数组的起始索引. 参数 number 必须.规定填充的元素的数量,其值必须大于0. 参数 value 必须.规定用于填充 ...
- iOS内购流程一(协议、税务和银行业务)
协议.税务和银行业务,这一选项是当你App使用了In-app purchaes时候,你跟苹果签订协议的,需要签订合同和填写你的银行收款等信息 一.填写法人信息 1.登录iTunes Store,点击协 ...
- RPC原理与实践(一)----RPC原理与实现(Thrift版)
什么是RPC?为什么要使用RPC? 首先什么是RPC,RPC全称Remote Process Call,远程过程调用,现在几乎所有的公司都在使用RPC这种架构,诸如YOUTUBE使用的Thrift,B ...
- 《剑指offer》面试题22—栈的压入、弹出序列
<程序员面试宝典>上也有经典的火车进站问题,类似. 如果12345是压栈顺序,序列45321可能是出栈顺序,但序列43512不可能. 规律:对序列中任意元素n,排在n后且比n小的元素一定是 ...
- C#—反射(反射类型、方法、构造函数、属性、实现可配置可扩展、数据库访问类反射封装)
反射是.NET中的重要机制,通过反射,可以在运行时获得程序或程序集中每一个类型(包括类.结构.委托.接口和枚举等)的成员和成员的信息.有了反射,即可对每一个类型了如指掌.另外我还可以直接创建对象,即使 ...
- 存储过程接收JSON格式数据
前端有可能一次性上传多笔记录,并使用JSON序列化. 现在在MS SQL Server 2016版本上,可以直接处理JSO数据. 如下面的前端序列化的数据: DECLARE @json_string ...
- AI决策算法 之 GOAP (一)
http://blog.csdn.net/lovethrain/article/details/67632033 本系列文章内容部分参考自:http://gamerboom.com/archives/ ...