前置步骤:


下载一个绿色版的mysql数据库客户端连接工具 :http://wosn.net/821.html

mysql平台为win7(以后会有CentOS上的)

学习目的:


掌握数据库的基本概念,基础的数据库查询语句(测试人员的基础技能)

正式步骤:


step1:可能会用到的一些周边命令

--查看mysql版本
SELECT VERSION();
--查看系统时间
SELECT NOW();
--linux 中设置允许所有用户远程登录sql服务器,%表示所有用户,123456(此字段为数据库密码)
grant all on *.* to root@'%' IDENTIFIED BY '';

step2: SQL语句的分类

  • DQL(数据查询语言,比如:select)
  • DML(数据操作语言,比如:insert、update、delete)
  • DDL(数据定义语言,比如:create、alter、drop)
  • DCL(数据控制语言,比如:grant、revoke)
  • TCL(事务控制语言,比如:SAVEPOINT、ROLLBACK、SET TRANSACTION、COMMIT)
  1. 数据库操作(DDL)

    --创建数据库
    create database db_name; --删除数据库
    drop database db_name; --切换数据库
    use db_name; --查看当前选择的数据库
    select database();

    使用navicat新建表
    在相应的数据库下,新建表,设置完字段信息后,保存,设置表明,右击新建的表,查看对象信息,点击DDL

  2. 表操作(DDL)
    修改表:
    --创建一个students表,id自增长
    create table t_student(
    id int(2) auto_increment primary key,
    sname varchar(10) not null,
    address varrchar(255)
    )
    
    --修改表:增加列、修改列、删除列
    alter table t_student add grade int;
    alter table t_student change grade mygrade int(2);
    ALTER table t_student drop mygrade;

    删除表

    --删除表
    drop table table_name;

    查看表结构

    --查看表结构
    DESC t_person;

    表的重命名

    --表的重命名
    rename table old_name to new_name;

step3: 数据操作(DML、DQL)

  1. 数据的插入

    --全字段的插入
    insert into t_student values(1,'python','BJ'); --部分字段插入
    insert into t_student(id,sname) values(2,'java'); --一次插入多行数据
    insert into t_student(id , sname) values(3,'C'),(4,'C#'),(5,'JS');
  2. 将id设置为自增长
    --将id设置为自增长
    alter table t_student modify id int(2) auto_increment;

    此时插入数据:

    insert into t_student (id,sname,address) values(0,'html','NJ');

    此时虽然输入时id为0,而实际插入数据后,id会自动增长

  3. 使用update修改数据
    --UPDATE
    update t_student set address ='目标值' where id =5;
  4. 删除数据
    --DELETE 整个表中数据
    delete from t_student
    --删除id为5的数据
    delete from s_student where id =5;

step4: DQL-select语句操作

  1. 创建dept表

    CREATE TABLE `dept` (
    `DEPTNO` varchar(255) NOT NULL,
    `DNAME` varchar(255) DEFAULT NULL,
    `LOC` varchar(255) DEFAULT NULL
    );
  2. 创建emp表
    CREATE TABLE `emp` (
    `EMPNO` int(4) DEFAULT NULL,
    `ENAME` varchar(255) DEFAULT NULL,
    `JOB` varchar(255) DEFAULT NULL,
    `MGR` varchar(255) DEFAULT NULL,
    `HIREDATE` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
    `SAL` varchar(255) DEFAULT NULL,
    `COMM` varchar(255) DEFAULT NULL,
    `DEPTNO` int(4) DEFAULT NULL
    );
  3. 使用算术表达式
    --查询所有员工的年薪
    select ename ,sal*12 '年薪' from emp;
  4. 字段别名的设置
    as关键字可以不用
  5. 去除重复项
    --去除重复项
    select distinct deptno from emp;
  6. 排序:order by,默认为升序asc (↓最上数据为小,下面的数据大),desc为降序  (↓由大到小)
    --按月薪,升序排
    select ename ,sal from emp order by sal;

    PS:多字段排序,请在order by后接字段

  7. 查询条件中,可以使用逻辑运算符
    --条件查询
    select * from emp where deptno = 10 and sal>1250;
    select * from emp where deptno = 20 or job='CLERK';
    select * from emp where sal not in (800,1600,2000);

难点分析:


测试中,基础的语句可以提高工作效率

python3 速查参考- python基础 9 -> MySQL基础概念、数据库create、alter、insert、update、delete、select等基础命令的更多相关文章

  1. python3 速查参考- python基础 6 -> 函数编程之参数、变量、作用域、递归、匿名函数 lambda

    函数基础 1. 速查笔记 #-- 函数相关的语句和表达式 myfunc('spam') # 函数调用 def myfunc(): # 函数定义 return None # 函数返回值 global a ...

  2. python3 速查参考- python基础 8 -> 面向对象基础:类的创建与基础使用,类属性,property、类方法、静态方法、常用知识点概念(封装、继承等等见下一章)

    基础概念 1.速查笔记: #-- 最普通的类 class C1(C2, C3): spam = 42 # 数据属性 def __init__(self, name): # 函数属性:构造函数 self ...

  3. python3 速查参考- python基础 7 -> 函数编程之 装饰器、生成器

    装饰器 1.速查笔记 #-- 函数装饰器:是它后边的函数的运行时的声明 由@符号以及后边紧跟的"元函数"(metafunction)组成 @staticmethod def sme ...

  4. python3速查参考- python基础 4 -> 元组 + 字典 + 字符串 的学习

    元组 元组:特点就是内容不可变,算只读的列表,可以被查询,不能被修改 a = 2, print(a) print(type(a)) b = ('a','b','c') print(b[1]) 运行结果 ...

  5. python3速查参考- python基础 5 -> 常用的文件操作

    文件的打开方式 打开方式 详细释义 r  以只读方式打开文件.文件的指针会放在文件的开头.这是默认模式. rb  以二进制只读方式打开一个文件.文件指针会放在文件的开头. r+  以读写方式打开一个文 ...

  6. python3速查参考- python基础 3 -> -> while循环实例 + Continue && break的应用 + 列表的初步学习

    while语句的应用 实例如下: """ 述求:用户登录系统,最多只能登录三次 第三次失败后,程序终止 """ user_table = { ...

  7. python3速查参考- python基础 1 -> python版本选择+第一个小程序

    题外话: Python版本:最新的3.6 安装注意点:勾选添加路径后自定义安装到硬盘的一级目录,例如本人的安装路径: F:\Python 原因:可以自动添加python环境变量,自动关联.py文件,其 ...

  8. python3速查参考- python基础 2 -> if语句应用 + while循环应用

    if语句应用之——求最大值 """ 求三个数字中的最大值,并打印出来 """ a = int(input("a:")) ...

  9. mysql字符集,insert,update,delete,select

    发现有错误:数据太长了.//查看数据库的所有编码:show variables like 'character%';-----+| character_set_client     | utf8    ...

随机推荐

  1. LVM卷管理

    一.LVM是做什么的 LVM ( Logical Volume Manager ,逻辑卷管理器)LVM 是建立在磁盘和分区之上的一个逻辑层,用来提高磁盘分区管理的灵活性.LVM 可以对磁盘分区按照组的 ...

  2. 【Android-关闭所有Activity】关闭activity之前的所有activity,重启actibity

    Android关闭activity之前的所有activity,重启actibity 直接关闭一个activity之前的所有Activity页面 解决方法:清理activity堆栈 Intent ine ...

  3. eq(index|-index)

    eq(index|-index) 概述 获取当前链式操作中第N个jQuery对象,返回jQuery对象,当参数大于等于0时为正向选取,比如0代表第一个,1代表第二个.当参数为负数时为反向选取,比如-1 ...

  4. luogu 3698 [CQOI2017]小Q的棋盘 树形dp

    Code: #include <bits/stdc++.h> #define N 107 #define setIO(s) freopen(s".in","r ...

  5. ege图形库之简单贪吃蛇(c++)

    第二次做动画显示效果的小程序,心血来潮想做下儿时的经典游戏----贪吃蛇.由于时间有限,只是简单地做了基本功能,有时间后再完善更多功能. 由于个人水平有限,可能代码有些地方可以改进.不足之处敬请指出. ...

  6. DP基础(线性DP)总结

    DP基础(线性DP)总结 前言:虽然确实有点基础......但凡事得脚踏实地地做,基础不牢,地动山摇,,,嗯! LIS(最长上升子序列) dp方程:dp[i]=max{dp[j]+1,a[j]< ...

  7. Hdu 4333 Revolving Digits(Exkmp)

    Revolving Digits Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) To ...

  8. 二维FFT,IFFT,c语言实现

    学习DIP第6天 完整内容迁移至http://www.face2ai.com/DIP-2-4-二维FFT-IFFT-c语言实现/ http://www.tony4ai.com/DIP-2-4-二维FF ...

  9. JVM基本讲解

    1.数据类型 java虚拟机中,数据类型可以分为两类:基本类型和引用类型. 基本类型的变量保存原始值,即:它代表的值就是数值本身,而引用类型的变量保存引用值. “引用值”代表了某个对象的引用,而不是对 ...

  10. 如何检测域名是否被微信屏蔽 微信域名检测接口API是如何实现

    微信域名检测技术的主要用户是微信域名防封,大家知道拼多多这种网站,靠诱导分享方式在微信里面摇身一变已经估值160亿美元,身价仅次于京东了 ,这是何等的速度,简直是惊为天人,but 如果你想玩微信病毒营 ...