数据库基础

数据库学习笔记

  • DB:数据库(database):存储数据的“仓库”

  • DBMS:数据库管理系统、数据库软件(产品):MYSQL、Oracle(甲骨文)、DB2(IBM)、SqlServer(微软,只能安装在window系统)

  • SQL:结构化查询语言,几乎所有的数据库都支持的语言

  • MySQL的基础使用

    • 1、打开“计算机”—>"管理"—>"服务",找到自己的mysql,手动启动和停止服务

    • 2、管理员身份打开cmd,输入net start mysql启动,net stop mysql停止服务

    • 3、输入mysql -h (主机名)localhost -P 3306(端口号) -u (用户名)root -p(密码)进入mysql命令行

    • 4、连接本机可以简写mysql -u用户名 -p密码

    • 5、show databases;显示已有数据库

    • 6、进入某个数据库use 库名;

    • 7、查看数据库的所有表show tables;

    • 8、查看其它数据的所有表show tables from 数据库名

    • 9、查询现在在哪个表select database();

    • 10、创建表

      create table stuinfo(
          id int,
          name varchar(20)
      );
      
    • 11、查看表的结构desc stuinfo;

    • 12、查看表中的所有数据select * from stuinfo;

    • 13、向表中插入数据

      insert into stuinfo (id,name) values(1,'tom');
      
    • 14、修改表中数据

      update stuinfo set name="zhangsan" where id=1;
      
    • 15、删除表中数据

      delete from stuinfo where id=1;
      
    • 16、查看当前mysql版本

      • 方式一:登录mysql服务端,select version();
      • 方式二:没有登录mysql服务端,mysql --version 或 mysql -V

    SQL语言

    • DQL:数据库查询语句

      # 基础查询一
      # 语法:select 查询列表 from  表名;
      # 查询列表:字段、常量值、函数、表达式
      use employees;
      # 1.查询表中的单个字段
      select last_name from employees;
      # 2.查询表中的多个字段
      select last_name,salary,email from employees;
      # 3.查询表中所有字段
      select * from employees;
      # 4.查询常量值
      select 100;
      select 'john';
      # 5.查询表达式
      select 100*98;
      # 6.查询函数
      select version();
      # 7.起别名
      # 7.1 便于理解
      # 7.2 如果要查询的字段有重名的情况,使用别名可以区分开来
      # 方式一
      select 100%98 as 结果;
      select last_name as 姓, first_name as 名 from employees;
      # 方式二
      select last_name 姓, first_name 名 from employees;
      # 8.去重
      select distinct department_id from employees;
      # 9. +号的作用
      # 案列:查询员工名和姓连接成一个字段,并显示为姓名
      # SQL中的 + 号只表示运算符的意义,'123'+1=1, 1+123=124, 1+null=null。
      select concat(last_name,first_name) as 姓名 from employees;
      
      # 基础查询二
      # 语法 select 查询列表 from 表名 where 筛选条件;
      # 条件表达式:> < = != <> >= <=
      # 逻辑运算符:&& || ! and or not
      # 模糊查询 like between and in is null
      # 1. 按条件表达式筛选
      # 查询工资>12000的员工信息
      select * from employees where salary>12000;
      # 查询部门编号不等于90号的员工名和部门编号
      select last_name,department_id from employees where department_id<>90;
      # 2. 按逻辑运算符筛选
      # 查询工资在10000到20000之间的员工名、工资以及奖金
      select last_name,salary,commission_pct from employees where salary>=10000 and salary<=20000;
      # 查询部门编号不是90到110之间,或者工资高于15000的员工信息
      select * from employees where department_id<90 or department_id>110 or salary>15000; 
      select * from employees where not(dapartment_id >=90 and department_id<=110) or salary>15000;
      # 3. 模糊查询 % _ 为占位符,% 匹配多个字符,_ 匹配一个字符。
      # 查询员工名中包含字符a的员工信息
      select * from employees where last_name like '%a%';
      # 查询员工编号在100到120之间的员工信息
      select * from employees where employee_id between 100 and 120;
      # 等价于
      select * from employees where employee_id >=120 AND employee_id<=100;
      # 查询员工的工种编号为 IT_PROT、AD_VP、AD_PRES 中的一个员工名和工种编号
      select last_name,job_id from employees where join_id = 'IT_PROT' or join_id = 'AD_VP' or job_id = 'AD_PRES';
      # 等价于
      select last_name,job_id from employees where job_id in('IT_PROT','AD_VP','AD_PRES');
      # 查询没有奖金的员工名和奖金率
      select last_name,commission_pct from employees where commission_pct IS NULL;
      # 查询有奖金的员工名和奖金率
      select last_name,commission_pct from employees where commission_pct IS NOT NULL;
      # 安全等于 <=>
      # 查询没有奖金的员工名和奖金率
      select last_name,commission_pct from employees where commission_pct <=> NULL;
      select last_name,salary from employees where salary <=> 12000;
      
      # 排序查询
      # select 查询列表 from 表 where 查询条件 order by 排序列表 【DESC: 降序 ASC:升序】 默认升序
      # 查询部门编号>=90的员工信息,按入职时间的先后进行排序
      select * from employees where department_id>=90 order by hiredate ASC;
      # 按年薪的高低显示员工的信息和年薪(安表达式排序)
      select *,salary*12*(1+IFNULL(commision_pct,0)) 年薪 from employees order by 年薪 DESC;
      # 按姓名的长度显示员工的姓名和工资(按函数排序)
      select length(last_name) 字节长度,last_name,salary from employees order by length(last_name) DESC;
      # 查询员工信息,要求先按工资排序,再按员工编号排序(按多个字段排序)
      select * from employees order by salary ASC,employee_id DESC;
      
      # 常见函数
      # 单行函数:concat、length、ifnull等
      # 分组函数:聚合函数
      # 1. 字符函数 length 获取参数值的字节个数
      select length('john'); # 4
      select length('张三aaaa') # 10 汉字在utf-8中占3个字节
      show variables like '%char%'; # UTF-8
      # 2. concat 拼接字符串
      select concat(last_name,'_',first_name) 姓名 from employees;
      # 3. upper、lower 
      # 将姓变大写,名变小写,然后拼接
      select concat(upper(last_name),'_',lower(first_name)) 姓名 from employees;
      # 4. substr、substring 截取,注意:索引从1开始
      select substr('我是蜘蛛侠', 3) out_put; # 蜘蛛侠
      select substr('我是蜘蛛侠',1,4); # 我是蜘蛛
      # 5. instr 返回字串第一次出现的索引,如果找不到返回0
      select instr('我是勤劳的小蜜蜂,小蜜蜂啊!小蜜蜂!', '小蜜蜂') as out; # 6
      # 6. trim 去前后空格
      select length(trim('   张三   ')) as out; # 6
      select trim('a', from 'aaaa张aaaa三aaaa') as out; # 张aaaa三
      
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,463评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,868评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,213评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,666评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,759评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,725评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,716评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,484评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,928评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,233评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,393评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,073评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,718评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,308评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,538评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,338评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,260评论 2 352