`
宁辉522
  • 浏览: 15815 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

MYSQL操作常用命令大全

阅读更多
归纳总结mysql操作常用增删改查,MYSQL操作大全--SQL必杀技

  MYSQL操作大全--SQL必杀技代码:

  --====================简单的查增删改===========

  --查看学生表的全部数据

  select * from studio

  --插入一个新的学生信息

  insert into studio(st_name,st_sex,st_age,st_add,st_tel) values("黄兰淇",0,36,'南充','13943943334')

  --查看class全部数据

  select * from class

  --向class表增加两条条数据

  insert into class(cl_class,cl_coding,cl_o_time,cl_remark) values('新电实训班','GXA-ncs-001','2008-03-11','都是很优秀的朋友')

  insert into class(cl_class,cl_coding,cl_o_time) values('阿坝师专实训班','GXA-ABSZ-001','2008-03-11')

  --更新一条的数据 条件的重要性

  update class set cl_remark='真的是不错' where cl_id=5

  --删除一条数据 条件的重要性

  delete from class where cl_id=7

  --修改列标题

  select cl_id as '班级主键',cl_class as '班级名称' from class

  select 名字=st_name from studio

  --使用文字串

  select '名字是:',st_name from studio

  --=============条件稍微复杂点的查增删改==============

  --主要涉及到 or and not between in like > < = !> !< != <> () <= >= is null is not null

  --查询cl_id 大于 1 的所有信息

  select * from class where cl_id>1

  --使用 or

  select * from class where cl_id<>10 or cl_class='百杰一班'

  --使用and

  select * from class where cl_id<>10 and cl_class='百杰一班'

  --使用like 和 %

  select * from class where cl_class like '百杰%'

  select * from class where cl_remark like '%上午%'

  --使用 between

  select * from class where cl_id between 3 and 5

  --使用 between 配合上 not

  select * from class where cl_id not between 3 and 5

  --使用 is not null

  select * from class where cl_remark is not null

  --使用 in

  select * from class where cl_class in('千星一班','百杰二班')

  --=================使用数学运算符======================

  --主要涉及到 + = * \

  --查询Java相关课程分别要上多少周 按照每周5天,每天6节课来计算

  select '结果'=co_num/5/6 from course where co_name in ('Java基础','Java项目入门')

  --==================使用汇总函数 ========================

  --涉及到COUNT SUM AVG MAX MIN

  --查询课时数小于50的课程一共有多少门

  select count(*) from course where co_num<50

  --查询所有课程一共多少课时

  select sum(co_num) from course

  --计算全部课时费,假设每节课50块钱

  select sum(co_num)*50 from course

  --查询课时最少的课程

  select min(co_num) from course

  --查询课时最多的课程

  select max(co_num) from course

  --查询平均每门课多少课时

  select avg(co_num) from course

  --=================使用数学函数=============================

  --包括求绝对值函数ABS函数、求圆周率函数PI()、求正玄值SIN()函数、求指数函数EXP()等。

  --查询每门课的正弦值

  select sin(co_num) from course

  --查询每门课的绝对值

  select abs(co_num) from course

  --查询每门课课时数 乘以 圆周率 ,具体有什么用我也不知道,反正这好像绝对是8.5杆子都打不到的

  select pi()*co_num from course

  --查询每门课的指数

  select exp(co_num) from course

  --随机返回5个随机生成的数(返回的是0~1之间的随机float值)

  declare @i tinyint

  set @i=1

  while @i<=5

  begin

  select rand(@i) as '随机生成的数' , @i as '当前值'

  set @i=@i+1

  end

  --返回数字表达式并四舍五入为指定的长度或精度 - ROUND

  select round(345.456,-1) as '参数为-1'

  , round(345.456,-2,1) as '参数为-2'

  , round(345.456,0) as '参数为0'

  , round(345.456,1) as '参数为1'

  , round(345.456,2) as '参数为2'

  --================使用日期函数======================

  --DAY()、MONTH()、YEAR()——返回指定日期的天数、月数、年数;

  select day(cl_s_time) as '日' from class --返回天

  select '月'=month(cl_s_time) from class --返回月

  select '年'=year(cl_s_time) from class --返回年

  --DATEADD(datepart,number,date)——在日期上增加给定日期类型的数量;

  select dateadd(yyyy,4,cl_s_time) as '增加4年后' from class --datepart - 年份

  yy、yyyy

  select dateadd(q,2,cl_s_time) as '增加2季度后' from class

  --datepart - 季度

  qq、q

  select dateadd(mm,3,cl_s_time) as '增加3月度后' from class

  --datepart - 月份

  mm、m

  --datepart - 每年的某一日

  dy、y

  --datepart - 日期

  dd、d

  --datepart - 星期

  wk、ww

  --datepart - 小时

  hh

  --datepart - 分钟

  mi、n

  --datepart - 秒

  ss、s

  --datepart - 毫秒

  ms

  --DATEDIFF(datepart,date1,date2)——获取两个日期之间给定的日期类型的数量差(整个函数结果是date2-date1);

  select datediff(mm,cl_s_time,cl_o_time) as '共持续月' from class

  --datepart(datepart,date)——在给定日期基础上返回指定日期类型的值(整数);

  --其实这个等同于DAY、MONTH、和 YEAR 函数

  select datepart(dd,cl_s_time) as '日期' from class

  --GETDATE()——返回当前日期和时间。我们在设计数据库的时候,通常也可能把他作为默认值

  update class set cl_s_time=getdate() where cl_id=6

  select * from class

  Select CONVERT(varchar(100), GETDATE(), 0): 05 16 2006 10:57AM

  Select CONVERT(varchar(100), GETDATE(), 1): 05/16/06

  Select CONVERT(varchar(100), GETDATE(), 2): 06.05.16

  Select CONVERT(varchar(100), GETDATE(), 3): 16/05/06

  Select CONVERT(varchar(100), GETDATE(), 4): 16.05.06

  Select CONVERT(varchar(100), GETDATE(), 5): 16-05-06

  Select CONVERT(varchar(100), GETDATE(), 6): 16 05 06

  Select CONVERT(varchar(100), GETDATE(), 7): 05 16, 06

  Select CONVERT(varchar(100), GETDATE(),: 10:57:46

  Select CONVERT(varchar(100), GETDATE(), 9): 05 16 2006 10:57:46:827AM

  Select CONVERT(varchar(100), GETDATE(), 10): 05-16-06

  Select CONVERT(varchar(100), GETDATE(), 11): 06/05/16

  Select CONVERT(varchar(100), GETDATE(), 12): 060516

  Select CONVERT(varchar(100), GETDATE(), 13): 16 05 2006 10:57:46:937

  Select CONVERT(varchar(100), GETDATE(), 14): 10:57:46:967

  Select CONVERT(varchar(100), GETDATE(), 20): 2006-05-16 10:57:47

  Select CONVERT(varchar(100), GETDATE(), 21): 2006-05-16 10:57:47.157

  Select CONVERT(varchar(100), GETDATE(), 22): 05/16/06 10:57:47 AM

  Select CONVERT(varchar(100), GETDATE(), 23): 2006-05-16

  Select CONVERT(varchar(100), GETDATE(), 24): 10:57:47

  Select CONVERT(varchar(100), GETDATE(), 25): 2006-05-16 10:57:47.250

  Select CONVERT(varchar(100), GETDATE(), 100): 05 16 2006 10:57AM

  Select CONVERT(varchar(100), GETDATE(), 101): 05/16/2006

  Select CONVERT(varchar(100), GETDATE(), 102): 2006.05.16

  Select CONVERT(varchar(100), GETDATE(), 103): 16/05/2006

  Select CONVERT(varchar(100), GETDATE(), 104): 16.05.2006

  Select CONVERT(varchar(100), GETDATE(), 105): 16-05-2006

  Select CONVERT(varchar(100), GETDATE(), 106): 16 05 2006

  Select CONVERT(varchar(100), GETDATE(), 107): 05 16, 2006

  Select CONVERT(varchar(100), GETDATE(), 108): 10:57:49

  Select CONVERT(varchar(100), GETDATE(), 109): 05 16 2006 10:57:49:437AM

  Select CONVERT(varchar(100), GETDATE(), 110): 05-16-2006

  Select CONVERT(varchar(100), GETDATE(), 111): 2006/05/16

  Select CONVERT(varchar(100), GETDATE(), 112): 20060516

  Select CONVERT(varchar(100), GETDATE(), 113): 16 05 2006 10:57:49:513

  Select CONVERT(varchar(100), GETDATE(), 114): 10:57:49:547

  Select CONVERT(varchar(100), GETDATE(), 120): 2006-05-16 10:57:49

  Select CONVERT(varchar(100), GETDATE(), 121): 2006-05-16 10:57:49.700

  Select CONVERT(varchar(100), GETDATE(), 126): 2006-05-16T10:57:49.827

  Select CONVERT(varchar(100), GETDATE(), 130): 18 ???? ?????? 1427 10:57:49:907AM

  Select CONVERT(varchar(100), GETDATE(), 131): 18/04/1427 10:57:49:920AM

  --=============使用字符串函数=====================

  --字符串链接运算符

  select '结果显示' = '班级名称是:' + cl_class + ',班级编号是:' + cl_coding from class

  --使用SUBSTRING函数截取字符串

  select substring(cl_class,1,4) from class

  --从字符串的左边开始返回3个字符

  select left(cl_class,3) from class

  --同理,返回右边的

  select right(cl_class,3) from class

  --返回值的字符数

  select len(cl_class) from class

  --替换

  select replace(cl_class,'实训','强化') from class

  --==============使用系统函数====================

  select host_id()

  --返回工作站标识号

  select host_name()

  --返回工作站所运行的计算机名称

  select db_id()

  select db_name()

  select object_id('Stu_course_ADD')

  --通过名称得到这个服务器对象的服务器ID

  select object_name(151671588)

  --同上相反

  --=======学 云 网-天轰穿-=========

  --首先是 order by 功能 - 排序

  select * from studio order by st_name

  --多排序条件

  select * from studio order by st_name DESC,st_age DESC,st_sex DESC

  --有条件,主要是看下条件和子句的位置

  select * from studio where cl_id=1 order by st_name

  --GROUP BY 子句 功能 - 分组统计

  select cl_id as '班级编号',count(*) as '人数' from studio group by cl_id

  --按宿舍统计年龄平均值

  select ho_id as '宿舍编号',avg(st_age) as '平均年龄' from studio group by ho_id

  --多分组

  select ho_id as '宿舍编号',cl_id as '班级编号',avg(st_age) as '平均年龄' from studio group by ho_id,cl_id

  --有条件,主要是看下条件和子句的位置

  select ho_id as '宿舍编号',avg(st_age) as '平均年龄' from studio where cl_id=1 group by ho_id

  --使用 having 子句 功能 - 指定组或者聚合的搜索条件,通常与group by 子句一起使用,完成分组查询后再进步筛选

  select ho_id as '宿舍编号',avg(st_age) as '平均年龄' from studio group by ho_id having avg(st_age)>35

  --多条件

  select ho_id as '宿舍编号',avg(st_age) as '平均年龄' from studio group by ho_id having avg(st_age)>35 and ho_id>2

  --====学云网-天轰穿-www.ixueyun.com=======联合查询=======学 云 网-天轰穿-www.ixueyun.com======

  --使用union子句的查询称为联合查询,功能:将两个以上的查询结果集组合为一个单个结果集,该集中包括所有集中的全部行数据

  --下面我们尝试将多个查询联合起来

  select * from studio where cl_id=1

  union

  select * from studio where ho_id=1

  union

  select * from studio where st_age>=30

  --下面我们继续利用上面的例题,增加上 All 看下效果

  select * from studio where cl_id=1

  union all

  select * from studio where ho_id=1

  union all

  select * from studio where st_age>=30

  --再继续利用,给他加上排序

  select * from studio where cl_id=1

  union all

  select * from studio where ho_id=1

  union all

  select * from studio where st_age>=30

  order by st_id

  --==========连接查询==================

  --连接查询,功能 - 将多个表中的数据查询出来放在一起

  --内连接:使用比较运算符=><....等进行表间某些数据库的比较操作,并列出这些表中与连接条件相匹配的数据行

  --等值连接,当然就是用等号了,毛病,这也要问

  select * from studio inner join class on studio.cl_id = class.cl_id

  --指明要查询的列(江湖上又称自然连接),并排序

  select st_id as '编号',st_name as '学生姓名',cl_class as '班级名称' from studio inner join class on studio.cl_id = class.cl_id order by st_id

  --使用表别名

  select st.st_name as '学生姓名',st.cl_id as '班级编号',cl.cl_class as '班级名称' from studio as st inner join class as cl on st.cl_id = cl.cl_id

  --不等连接,这个问题很好笑,既然使用等号的是等值连接,那么不等值你说是不是应该是非等于以外的呢?

  --下面我们再连接第三个表,看下是怎么搞滴

  select st.st_name as '学生姓名',st.cl_id as '班级编号',cl.cl_class as '班级名称' ,ho.ho_coding as '所在宿舍编号'

  from studio as st inner join class as cl

  on st.cl_id = cl.cl_id

  inner join hostel as ho

  on st.ho_id=ho.ho_id

  --我们再给他加个条件看下

  --where st.cl_id>2

  --再给他个排序

  --order by st.st_id

  --外连接:

  --与内连接不同的是,内连接至少要有一个同属于两个表的行符合连接条件时才会返回行,外连接会返回符合任意条件的行

  --他的表有主从之分,他用主表中的每行去匹配从表中的,与内连不同的是,他不会丢弃没有匹配的行,而是填充null给从结果集

  --左外连接

  select st.st_id as '学生编号', st.st_name as '学生姓名',cl.cl_id as '班级编号',cl_class as '班级名称'

  from studio as st left outer join class as cl

  on st.cl_id=cl.cl_id

  where cl.cl_id>2

  --多表

  select tka.te_co_id as '课程安排编号'

  ,cl.cl_id as '班级编号',cl.cl_class as '班级名称'

  ,co.co_id as '课程ID',co.co_name as '课程名称',co.co_num as '课时数'

  ,te.te_name as '老师姓名'

  from te_kc_ap as tka left outer join class as cl

  on tka.cl_id=cl.cl_id

  left outer join

  course as co

  on tka.co_id=co.co_id

  left outer join

  teacher as te

  on tka.te_id=te.te_id

  --====================右外连结 ======================

  select st.st_id as '学生编号', st.st_name as '学生姓名',cl.cl_id as '班级编号',cl_class as '班级名称'

  from studio as st right outer join class as cl

  on st.cl_id=cl.cl_id

  where cl.cl_id>2

  --多表

  select tka.te_co_id as '课程安排编号'

  ,cl.cl_id as '班级编号',cl.cl_class as '班级名称'

  ,co.co_id as '课程ID',co.co_name as '课程名称',co.co_num as '课时数'

  ,te.te_name as '老师姓名'

  from te_kc_ap as tka

  right outer join class as cl

  on

  tka.cl_id=cl.cl_id

  right outer join teacher te

  on

  tka.te_id=te.te_id

  right outer join course co

  on

  tka.co_id=co.co_id

  --=======完全连接=============

  select st.st_id as '学生编号', st.st_name as '学生姓名',cl.cl_id as '班级编号',cl_class as '班级名称'

  from studio as st full outer join class as cl

  on st.cl_id=cl.cl_id

  order by st.st_id

  --多表

  select tka.te_co_id as '课程安排编号'

  ,cl.cl_id as '班级编号',cl.cl_class as '班级名称'

  ,co.co_id as '课程ID',co.co_name as '课程名称',co.co_num as '课时数'

  ,te.te_name as '老师姓名'

  from te_kc_ap as tka

  full outer join class as cl

  on

  tka.cl_id=cl.cl_id

  full outer join teacher te

  on

  tka.te_id=te.te_id

  full outer join course co

  on

  tka.co_id=co.co_id

  --==========交叉连接==============

  --该方式在不带where子句时,返回的是两个表中所有数据行的笛卡尔积(第一个表中的行乘以第二个表中的行)

  --用学生和班级表做交叉查询

  select st_name,cl_class from studio cross join class

  select st_name,cl_class from studio,class

  select st_name,cl_class from studio cross join class

  --=========自连接===

  -----------------先临时创建一个表-------------

  create table zone(

  id int primary key identity(1,1) not null,

  z_zone varchar(30),

  z_id int references zone(id))

  --大家试下,这里是否可以给个默认值

  select * from zone

  insert into zone(z_zone) values('北京')

  insert into zone(z_zone,z_id) values('北京',4)

  insert into zone(z_zone) values('四川')

  insert into zone(z_zone,z_id) values('成都',6)

  insert into zone(z_zone,z_id) values('绵阳',6)

  insert into zone(z_zone) values('江苏')

  insert into zone(z_zone,z_id) values('南京',10)

  insert into zone(z_zone,z_id) values('苏州',10)

  insert into zone(z_zone,z_id) values('无锡',10)

  insert into zone(z_zone,z_id) values('常州',10)

  ----------------------------------------------

  --看下自连接的一般用处

  select a.z_zone,b.z_zone from zone as a inner join zone as b on a.z_id=b.id

  --扩展应用下

  select b.z_zone,count(a.z_zone) as '辖区数' from zone as a inner join zone as b on a.z_id=b.id group by b.z_zone

  --简单说就是自己连接自己,换言之对同一个表进行连接操作

  select a.st_name,a.st_add,b.st_name,b.st_add from studio as a inner join studio as b on a.st_add=b.st_add

  --我们发现有人等于自己,那么增加一个条件

  select a.st_name,a.st_add,b.st_name,b.st_add from studio as a inner join studio as b on a.st_add=b.st_add and a.st_name!=b.st_name

  --======子查询=====爱微网-天轰穿-======

  --在一个SQL语句中镶入另一个SQL语句教镶套查询,而被镶入的这个SQL语句就被江湖人称子查询。是处理多表操作的附加方法

  --子查询也称内部查询,而包含子查询的Select语句被诚为外部查询,子查询自身可以包括一个或者多个子查询,也可以镶套任意数量的子查询

  --使用in的子查询

  select * from studio where cl_id in (select cl_id from class where cl_id>2)

  --使用 not in

  select * from studio where cl_id not in (select cl_id from class where cl_id>2)

  --使用比较运算符的子查询 -- any 表示子查询中任意的值 all 表示子查询中的每个值

  --使用any

  select * from class where cl_id>any(select cl_id from studio where st_age>30)

  --使用all

  select * from class where cl_id>all(select cl_id from studio where st_age>30)

  --===========一个分页的SQL语句=======

  select top 3 * from studio

  where st_id>all(select top 3 st_id from studio order by st_id)

  order by st_id

  --使用 exists ,该关键字引入一个子查询的时候基本上是对数据进行一次是否存在的测试

  --我们查询那些人所在的班级是编号为 1 的

  select * from studio where exists(select cl_id from class where studio.cl_id=class.cl_id and class.cl_id=1)

  --使用 not exists

  select * from studio where not exists(select * from class where studio.cl_id=class.cl_id and class.cl_id=1) order by st_id

  --基于查询生成新的表

  select st_name into class_3 from studio where cl_id=3

  --将数据批量插入一个表中

  insert into class_3 select st_name from studio where cl_id=4

  -----------------------sql 编程--------------

  declare @max int;

  --申明一个变量@max

  set @max=1;

  --为变量@max赋值

  while @max<10

  --如果@max小于10就进入循环

  begin

  set @max=@max+1;--每次循环就给@max加1

  print @max;

  --打印当前@max的值

  end

  print '终于循环完了';
2
5
分享到:
评论

相关推荐

    mysql常用操作命令大全

    ### MySQL常用操作命令详解 #### 一、启动与退出 **1. 进入MySQL:** 对于新手而言,了解如何进入MySQL至关重要。通过SSH连接到服务器后,可以通过以下命令来连接MySQL服务: ```sql mysql -u 用户名 -p ```...

    mysql命令行常用命令

    MySQL 命令行常用命令是 MySQL 数据库管理员和开发者需要掌握的基本技能,本文将介绍 MySQL 命令行常用命令的六大招数,包括 MySQL 服务的启动和停止、登陆 MySQL、增加新用户、操作数据库、导出和导入数据、乱码...

    mysql常用操作命令

    mysql常用操作命令 mysql是一个流行的关系数据库管理系统,作为开发人员,掌握mysql的常用操作命令是非常必要的。本文将对mysql的常用操作命令进行总结,包括连接mysql、查询版本信息、查询当前日期、查询服务器中...

    MySQL数据库常用命令大全.pdf

    了解并熟练掌握MySQL的常用命令对于管理和操作数据库至关重要。以下是一些主要的MySQL命令及其详细说明: 1. **连接MySQL**: 使用`mysql -h 主机地址 -u 用户名 -p用户密码`来连接MySQL服务器。例如,连接本地...

    mysql数据库常用命令汇总

    MySQL数据库常用命令汇总 MySQL数据库是目前最流行的开源关系数据库管理系统,它提供了丰富的命令来管理和操作数据库。本文汇总了MySQL数据库常用的命令,包括数据库操作、表操作和数据操作三部分。 数据库操作 1...

    MySQL入门常用操作命令收集.

    MySQL入门常用操作命令收集,集合的mysql中常用的命令操作方法

    mysql的常用操作指令

    ### MySQL的常用操作指令知识点详解 #### 一、MySQL简介及基本概念 - **数据库(Database)**:存储数据的仓库。 - **数据库管理系统(DBMS)**:用于创建和管理数据库的应用软件,如MySQL、Oracle等。 - **关系型...

    MySQL常用命令大全

    根据提供的文件内容,我们可以整理出一系列关于MySQL的重要知识点与实用命令。MySQL是一种广泛使用的...通过以上内容,我们可以清晰地了解到MySQL中常用的各种命令及其功能,这将有助于更好地管理和操作MySQL数据库。

    操作mysql数据库的常用命令总结

    以下是一些关于操作MySQL数据库的常用命令的详细说明: 1. **连接MySQL**:使用`mysql -u 用户名 -p`命令可以连接到MySQL服务器,其中`-u`指定用户名,`-p`会提示输入密码。例如,连接名为root的用户,命令是`mysql...

    MySql常用命令 最新 最全

    根据提供的标题、描述以及部分内容,本文将详细解析MySQL数据库中的常用命令,并且涵盖数据库的创建、管理、查询、更新等核心操作。 ### MySQL 常用命令概览 #### 启动与停止 MySQL 服务 - **启动 MySQL 服务**: ...

    MySQL数据库常用命令大全.doc

    MySQL 数据库常用命令大全 MySQL 是一种常用的关系数据库管理系统,支持多种编程语言,包括 Java、Python、PHP 等。了解 MySQL 的基本命令是非常重要的,本文将对 MySQL 数据库的基本命令进行整理和总结。 一、...

    MYSQL操作常用命令

    ### MySQL操作常用命令及密码重置详解 #### 忘记MySQL ROOT密码的处理方法 当您忘记了MySQL数据库的ROOT密码时,可以通过以下步骤进行重置: 1. **编辑MySQL配置文件** - **Windows环境**: 编辑路径为 `%MySQL_...

    MYSQL常用命令教程

    以上就是从“MYSQL常用命令教程”中提炼出来的关键知识点,涵盖了MySQL服务控制、连接管理、用户管理、数据库操作、数据表操作、数据操作以及数据导入导出等方面的核心命令。熟练掌握这些命令,对于日常开发工作及...

    mysql常用命令大全-最完整版

    以上知识点是对MySQL常用命令的一个全面总结,涉及数据库管理、用户权限、数据备份、表操作、索引使用等关键领域。对于MySQL数据库新手来说,这些知识点能够帮助他们快速上手并有效管理MySQL数据库。

    MySQL常用操作命令

    MySQL常用操作命令 MySQL是一种关系数据库管理系统,常用于各种应用程序的数据存储和管理。...掌握这些基本的MySQL操作命令对于使用MySQL数据库非常重要,可以帮助您更好地管理和维护您的数据库。

    MySQL5.0常用命令

    10. **其他常用命令**: - `SHOW DATABASES;`:显示所有数据库。 - `SHOW TABLES;`:显示当前数据库中的表。 - `DESCRIBE 表名;`:查看表结构。 - `HELP '主题';`:获取帮助信息。 这些命令构成了MySQL5.0日常...

Global site tag (gtag.js) - Google Analytics