zoukankan      html  css  js  c++  java
  • 数据库操作SQL命令

    1.关于数据库的操作

    • 1.1创建数据库(注:sql语句区分大小写)
      create database Hero
    • 1.2使用某个数据库
      use Hero
      go--执行
    • 1.3删除数据库
      drop database Hero

    2.关于表的操作

    • 2.1创建表并指定主键
      create table hero
      (heroID int primary key,heroName varchar(50)
      )
    • 2.2删除表
      drop table hero

    3.关于表数据的操作

    • 3.1添加数据
      insert into hero values(1,'宋江')

    • 3.2查询数据
      select * from hero where heroName='宋江'

    • 3.3修改数据
      update hero set heroID=heroID*1.1,heroName='武松'

    • 3.4删除数据
      delete from hero where heroID=1 and heroName='武松'

    • 3.5插入部分字段(主键必须给)
      insert into hero (heroID) values(1)

    • 3.6外键的介绍

      即建立关联:()外键只能指向主键
      ()主键和外键的数据类型要一致

      create table emp( empo int primary key, deptno int foreign key references dept(deptno) )
      注:dept为表(deptno为字段)

    • 3.7查询指定列
      select 字段,字段from 表名where 条件

    • 3.8取消重复行
      select distinct 字段from 表名where 条件

    4.关于数据技巧的操作

    • 4.1加别名
      select 字段别名,字段from 表名where 条件
    • 4.2判断是否为NULL,若为NULL则用代替
      select 字段,isnull(字段,0) from 表名where 条件
    • 4.3判断是否在两者之间,包括两者(数据型)
      select * from 表名where sal between 2000 and 5000
    • 4.4显示首字母为s的人% :代表到多个字符_ :代表单个字符
      select * from hero where heroName like's%'
    • 4.5 or 和in 的区别
      select * from hero where heroID=1 or heroID=2 or heroID=5
      select * from hero where heroID in(1,2,5)
    • 4.6升降序的排列
      select * from hero order by heroID desc--降序
      select * from hero order by heroID-------默认为升序(asc)
    • 4.7聚合函数如min()
    • 4.8平均和求和
      select avg(sal) ,sum(sal) from hero
    • 4.9计算有多少记录
      select count(*) from hero

    5.关于数据复杂查询

    • 5.1group by分组,having对分组结果进行筛选
      select avg(sal) from hero group by 部门having avg(sal)>2000
    • 5.2取了别名后,别名先载入,而且以后也得用别名
      select e.dept from emp e,depo d where e.dept=d.dept
    • 5.3单行子查询= 多行用in
      select dept from emp where dept=(select dept from emp where name='song')
      select dept from emp where dept in(select dept from emp where name='song')
    • 5.4显示前个人的记录
      select top 4 *from emp order by sal
      • 显示-10人的记录
        select top 6 *from emp not in(select top 4 *from emp order by sal) order by sal
    • 5.5自增长和构造大量数据
      create table hero
      (heroID int primary key identity(1,1),heroName varchar(50)
      )--identity(1,1)表示该字段自增从,每次+1
      insert into hero (heroID) values(1)
      insert into hero(heroID) select heroID from hero
      
    • 5.6左外连右外连
      select w.ename,b.ename from emp w left join emp b on w.mgr=b.empo

    6.关于数据的约束

    • 6.1 not null unique check default
    create table hero
    (heroID int primary key identity(1,1) not null,--非空
    heroName varchar(50) unique------------------唯一
    sal int check sal>2000------------------------规定取值范围
    sex nchar(1) check(sex in('男','女')) default '男'----------------------默认)
    

    7.关于数据库备份和还原

    backup database Hero to disk='f:/sp.bak'---备份
    restore database Hero from disk='f:/sp.bak'--还原

    8.关于数据库的测试

    • 自我复制
      insert into users (username,passwd,email,grade)
      select username,passwd,email,grade from users

    9.关于sql语句的其它操作

    • 查询数据库
      show databases;
    • 查询表名
      show tables;
    • 查询表字段
      show columns from 表名

    10. mysql权限相关

    • 创建用户
    CREATE USER 'test'@'%' IDENTIFIED BY 'test@123';
    '%' - 所有情况都能访问
    'localhost' - 本机才能访问
    '111.222.33.44' - 指定 ip 才能访问
    
    • 赋予权限
    grant all on 数据库名.数据库表 to 用户名@'%'  IDENTIFIED by '密码';
    all 可以替换为 select,delete,update,create,drop
    数据库名 所有的 用*
    数据库表 所有的 用*
    
  • 相关阅读:
    python全栈学习--day57(响应式页面-@media介绍,移动端单位介绍,Bootstrap学习)
    网络编程-Socket介绍
    网络编程-五层协议详解
    python-封装
    python- 类的多态与多态性
    python-接口类与抽象类
    python-类的组合和使用
    python-类继承与重用
    python-面向对象编程小结
    python-属性的查找与绑定方法
  • 原文地址:https://www.cnblogs.com/reamd/p/15103263.html
Copyright © 2011-2022 走看看