Sql语言基础:

核心思想:我们自己构造一段查询的代码,然后添加到语句后,从而得到想要的某些数据。

Mysql是一种开源数据库

APP Serv:Apache+php+mysql,相当于phpstudy(建议装在本机上,不建议装在虚拟机)

安装(主要):4个主件都要安装,本地网址需要自己命名,例如:www.test.com

然后设置Mysql密码,选择允许通过防火墙。

默认启动Apache和mysql

Mysql操作:

打开mysql.exe和mysqld.exe所在的文件夹,复制路径地址;

登录数据库:

也可越权访问,此时就跳过了mysql的用户验证。注意输入此命令之后命令行就无法操作了,此时可以再打开一个新的命令行。

注意:在输入此命令之前先在任务管理器中结束mysqld.exe进程,确保mysql服务器端已结束运行; 然后直接输入mysql,不需要带任何登录参数直接回车就可以登陆上数据库

此时我们就可以进行一系列操作了

输入select version();   显示当前版本号

输入show databases;  查看当前包含哪些数据库(从以下可以看到6个数据库)

Information_schema,mysql,内置的,不需要做任何改动,test除外,因为test

本来就是用来做测试的

打开test数据库:use test;

显示当前打开的数据库:select database;

显示test数据库的表:show tables;(这里可以看到test数据库表为空)

创建表:

mysql>create table hack                创建表hack;

->(                              表的内容如下;

->id int                           id字段为整数型

->usename varchar(20),             usename为可变长度的20个字节长度类型

->password varchar(30)

->);

往表里添加记录:

insert into hack values(1,’admin’,’456’);

insert into hack values(2,’boss’,’123’);

select查询语句:

select * from hack;                    显示hack表里所有字段内容;

select usename,password from hack;   只显示usename和password两个字段的内容;

select usename,password from hack where id=1;   从hack表中查找满足条件id=1的记录;

select * from hack where id=1 and usename=’admin’;   从hack表中查找满足id=1且usename=”admin”时的记录;

select * from hack where id=1 or usename=”boss”;  从hack表中查找满足id=1或者usename=”admin”时的记录;

我们再创建个表new

我们还可以删除表(这里以删除表news为例)

验证删除表news是否成功:

select * from new where id=1 and exists(select * from hack);     判断在hack数据库中查找关于new表中是否存在id=1的字段;

select * from hack order by password;          查询所有字段,按照password来排序(默认升序)

select * from hack order by 4;                        查询hack数据库的字段数(这里可以看到不存在4个字段)

select * from hack order by 3;        判断当前查询显示几个字段,这里用3判断了下,说明是存在3个字段的

Union联合查询:

知道显示的是几个字段显示几个字段有什么用呢?

其实就是为了我们后面的union联合查询,可以使用union查询一次性执行两个或者多个查询,并将它们的结果组合在一起输出显示。必须知道有多少个字段才能执行。

这里需要特别注意的是union联合查询的基本规则就是所有查询中的列数必须相同。意思就是说前面的查询结果的字段数跟后面查询结果的字段数必须是一样的。

具体查询操作如下所示:

查询new表字段数,如下图可以看到,有两个字段

查询hack表字段数,如下图可以看到,有三个字段

由前面我们知道new表中有两个字段,hack表中有3个字段,当我们输入:  select * from new union select * from hack;  时查询是报错的,报错原因说的是字段数不匹配

不匹配怎么办呢?我们保证前后字段数相同不就行啦!

new表有两个字段,我们让hack表也只显示两个字段(usename和password)

我们再输入select * from new union select usename,password from hack;

看到没,成功啦!

那么我们还可以满足hack表,让new表显示3个字段

输入 select * from hack union select 1,2,3 from new;          其中1,2,3可以替换成new表中的字段名

例如我这里要同时输入hack表里所有字段和new表里id和title两个字段如下所示。

最后说一下mysql中的注释语句,因为有时我们需要屏蔽一下语句的作用,就需要用到注释符。

单行注释:在某一行中插入一个符号,这一行就没有意义了,例如,我们在此处插入#,后面的语句就被注释掉了,输出结果就不会显示。

除了# 还有-- 注释符,注意:这里—后面有一个空格

多行注释:/*      */,”/*”用于注释文字的开头,”*/”用于注释文字的结尾。

学到这里我们几乎就可以开始sql注入啦!!

SQL语言基础和数据库操作的更多相关文章

  1. .NET面试题解析(11)-SQL语言基础及数据库基本原理

      系列文章目录地址: .NET面试题解析(00)-开篇来谈谈面试 & 系列文章索引 本文内容涉及到基本SQL语法,数据的基本存储原理,数据库一些概念.数据优化等.抱砖引玉,权当一个综合复习! ...

  2. .NET面试题解析(9)-SQL语言基础及数据库基本原理

    见面试题 1. 索引的作用?她的优点缺点是什么? 2. 介绍存储过程基本概念和 她的优缺点? 3. 使用索引有哪些需要注意的地方? 4. 索引碎片是如何产生的?有什么危害?又该如何处理? 5. 锁的目 ...

  3. SQL语言基础及数据库的创建

    一.数据类型:1.二进制数据二进制数据以十六进制形式存储.二进制数据最多能存8000个英文字符,4000个汉字字符. 2.字符数据char:存100,不足100补足.varcha:存多少占多少. 3. ...

  4. 6.JAVA语言基础部分--数据库操作

    操作数据数据流程:得到Connecnt->获取Statement对象->执行sql语句返回ResultSet 1.通过DriverManager.getConnection("j ...

  5. 新手学python(2):C语言调用完成数据库操作

    继续介绍本人的python学习过程.本节介绍如何利用python调用c代码.内容还是基于音乐信息提取的过程,架构如图一.Python调用c实现的功能是利用python访问c语言完成mysql数据库操作 ...

  6. PL/SQL语言基础

    PL/SQL语言基础 进行PL/SQL编程前,要打开输出set serveroutput on 1.创建一个匿名PL/SQL块,将下列字符输出到屏幕:"My PL/SQL Block Wor ...

  7. MySQL数据库:SQL语句基础、库操作、表操作、数据类型、约束条件、表之间的关系

    数据库相关概念: 1. 数据库服务器:运行数据库管理软件的计算机 2. 数据库管理软件:MySQL.Oracle.db2.slqserver 3. 库:文件夹,用来组织文件/表 4. 表:文件(类似于 ...

  8. SQL Server 基础 01 数据库、表操作

    对着书慢慢学习,一天一点点! 数据库操作 (create.alter.drop)  --3-3-1 /create database 语句创建数据库 create database testSQL - ...

  9. orcale 之 SQL 语言基础

    SQL 全称是结构化查询语句(Structure Query Language),是数据库操作的国际化语言,对所有的数据库产品都要支持. SQL 语言的分类 我们按照其功能可以大致分为四类: 数据定义 ...

随机推荐

  1. vim常用命令整理

    #创建文件 vim test.txt vi test.txt touch test.txt #在vim中要想退出,先按[esc],再输入如下命令 [:wq]保存并退出 [:q]退出,未修改 [:q!] ...

  2. 理解Spring中的IoC和DI

    什么是IoC和DI IoC(Inversion of Control 控制反转):是一种面向对象编程中的一种设计原则,用来减低计算机代码之间的耦合度.其基本思想是:借助于"第三方" ...

  3. C的位运算符

    1.前言 C的位运算符有&(按位与).|(按位或).^(按位异或).~(按位取反),位运算符把运算对象看作是由二进制位组成的位串信息,按位完成指定的运算,得到相应的结果. 2.位运算符 在上面 ...

  4. 第三节:EF Core上下文DbContext相关配置和生命周期

    一. 配置相关 1. 数据库连接字符串的写法 (1).账号密码:Server=localhost;Database=EFDB01;User ID=sa;Password=123456; (2).win ...

  5. Flink 源码解析 —— 项目结构一览

    Flink 源码项目结构一览 https://t.zsxq.com/MNfAYne 博客 1.Flink 从0到1学习 -- Apache Flink 介绍 2.Flink 从0到1学习 -- Mac ...

  6. Docker的安装与使用

    Docker的安装 (1)卸载老版本yum remove docker \                  docker-client \                  docker-clien ...

  7. 红黑树和AVL树的区别(转)

    add by zhj: AVL树和红黑树都是平衡二叉树,虽然AVL树是最早发明的平衡二叉树,但直接把平衡二叉树等价于AVL树,我认为非常不合适. 但很多地方都在这么用.两者的比较如下 平衡二叉树类型 ...

  8. MyBatis-Plus入门Demo详解

    一.简介: 引用官方文档(本文主要参考官方文档示例): MyBatis-Plus(简称 MP)是一个 MyBatis 的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发.提高效率而生 ...

  9. Introducing KSQL: Streaming SQL for Apache Kafka

    Update: KSQL is now available as a component of the Confluent Platform. I’m really excited to announ ...

  10. Unity PhysicsScene测试

    应该是unity 2018.3中加入的功能,对象可以放置于不同的物理场景中. 一个Scene对应一个物理场景(PhysicsScene),若想放入独立的物理场景测试创建一个Scene即可.见下图gif ...