mysql基础学习 史上最全的mysql基础教程
wptr33 2024-11-11 16:09 27 浏览
基础命令
MySQL 是最流行的关系型数据库管理系统,在 WEB 应用方面 MySQL 是最好的 RDBMS(Relational Database Management System:关系数据库管理系统)应用软件之一。mysql数据库通过sql来操作数据库
mysql中的注释符
- @
- #
- -- (杠杠空格) (注入中经常用到的)
- /* ..... */
- /*! .... */
information_schema
mysql 5.0版本之后产生了一个虚拟数据库information_schema,在这个数据库中有三个很重要的表:
- information_schema: 该数据表存储了mysql数据库中的所有数据库的库名
- information_schema.tables: 该数据表存储了mysql数据库中的所有数据表的表名
- information_schema.columns: 该数据表存储了mysql数据库中的所有列的列名
mysql中比较常用的一些函数:
- version(): 查询数据库的版本
- user(): 查询数据库的使用者
- database(): 数据库
- system_user(): 系统用户名
- session_user(): 连接数据库的用户名
- current_user: 当前用户名
- load_file(): 读取本地文件
- @@datadir: 读取数据库路径
- @@basedir: mysql安装路径
- @@version_complie_os: 查看操作系统
- length() 返回字符串的长度
- substring() 截取字符串
- substr() 截取字符串
- mid() 截取字符串
- left() 从左侧开始取指定字符个数的字符串
- concat() 没有分隔符的连接字符串
- concat_ws() 含有分割符的连接字符串
- group_conat() 连接一个组的字符串
- ord() 返回ASCII 码
- ascii() 返回ASCII 码
- hex() 将字符串转换为十六进制
- unhex() hex 的反向操作
- md5() 返回MD5 值
- sleep() 睡眠时间为指定的秒数
- if(true,t,f) if 判断
sql注入中的常见函数汇总
ascii(str) : 返回给定字符的ascii值 如 ascii("a")=97
length(str) : 返回给定字符串的长度,如 length("string")=6
substr(string,start,length) 对于给定字符串string,从start位开始截取,截取length长度 ,如 substr("chinese",3,2)="in"
substr()、stbstring()、mid() 三个函数的用法、功能均一致
concat(username): 将查询到的username连在一起,默认用逗号分隔
group_concat(字段1,'*',字段2): 将字段1和字段2的数据查询到一起,中间用*连接
count(table_name) 返回表的个数
if(expr1,expr2,expr3) 如果expr1的值为true,则返回expr2的值,如果expr1的值为false,则返回expr3的值。
基本命令
增删改查
- show databases; 查看有哪些数据库
- use mysql; 进入数据库
- show tables; 查看数据库中有哪些表
- select * from user; 查看users表中的所有内容
- select host,id,name from mysql.user; 查看表中的指定字段
- desc 表名 查看表中的字段
条件查询
- limit 0,1 看第一行
- select host,id,name from mysql.user limit 1; 看第一行
- select host,id,name from mysql.user limit 2: 看前二行
- select host,id,name from mysql.user limit 2,3; 第二行(不包括)往下三行
- select * from users where id=5 查找users表中id字段值等于5的那一行数据
- select * from users where id=5 limit 0,2 查找users表中id字段值等于5的那一行数据,where后面加了两个限定参数第一个是显示第五行第二个是显示第一行和第二行,程序以id=5这个限定条件为先,相当于此时的limit0,2没起作用
mysql允许远程登录
测试环境:phpstudy2016,mysql5.5.53
mysql默认不允许用户进行远程登录,如下进行远程登录显示拒绝用户登录。(用户被禁止远程登录和用户名密码错误的提示一样,所以根据错误并不能判断是否是禁止远程登录还是口令错误。并且扫描端口的状态都为开放的状态)
防火墙默认过滤3306端口
解决办法如下:
1. 进入到mysql命令行中
2. 执行如下
- grant all privileges on *.* to 自己的用户名@'%' identified by '远程登录密码';
- ——>
- grant all privileges on *.* to root@'%' identified by 'root';
- grant all privileges 赋予所有权限
- *.* 为数据库名称.表名 ,表示赋予用户操作服务器上所有数据库所有表的权限
- '%' 表示从任何地址连接。或者可以是localhost,也可以是ip地址、机器名字、域名
3. 执行
flush privileges;
连接成功
相关推荐
- Linux高性能服务器设计
-
C10K和C10M计算机领域的很多技术都是需求推动的,上世纪90年代,由于互联网的飞速发展,网络服务器无法支撑快速增长的用户规模。1999年,DanKegel提出了著名的C10问题:一台服务器上同时...
- 独立游戏开发者常犯的十大错误
-
...
- 学C了一头雾水该咋办?
-
学C了一头雾水该怎么办?最简单的方法就是你再学一遍呗。俗话说熟能生巧,铁杵也能磨成针。但是一味的为学而学,这个好像没什么卵用。为什么学了还是一头雾水,重点就在这,找出为什么会这个样子?1、概念理解不深...
- C++基础语法梳理:inline 内联函数!虚函数可以是内联函数吗?
-
上节我们分析了C++基础语法的const,static以及this指针,那么这节内容我们来看一下inline内联函数吧!inline内联函数...
- C语言实战小游戏:井字棋(三子棋)大战!文内含有源码
-
井字棋是黑白棋的一种。井字棋是一种民间传统游戏,又叫九宫棋、圈圈叉叉、一条龙、三子旗等。将正方形对角线连起来,相对两边依次摆上三个双方棋子,只要将自己的三个棋子走成一条线,对方就算输了。但是,有很多时...
- C++语言到底是不是C语言的超集之一
-
C与C++两个关系亲密的编程语言,它们本质上是两中语言,只是C++语言设计时要求尽可能的兼容C语言特性,因此C语言中99%以上的功能都可以使用C++完成。本文探讨那些存在于C语言中的特性,但是在C++...
- 在C++中,如何避免出现Bug?
-
C++中的主要问题之一是存在大量行为未定义或对程序员来说意外的构造。我们在使用静态分析器检查各种项目时经常会遇到这些问题。但正如我们所知,最佳做法是在编译阶段尽早检测错误。让我们来看看现代C++中的一...
- ESL-通过事件控制FreeSWITCH
-
通过事件提供的最底层控制机制,允许我们有效地利用工具箱,适时选择使用其中的单个工具。FreeSWITCH是一个核心交换与混合矩阵,它周围有几十个模块提供各种功能特性。我们完全控制了所有的即时信息,这些...
- 物理老师教你学C++语言(中篇)
-
一、条件语句与实验判断...
- C语言入门指南
-
当然!以下是关于C语言入门编程的基础介绍和入门建议,希望能帮你顺利起步:C语言入门指南...
- C++选择结构,让程序自动进行决策
-
什么是选择结构?正常的程序都是从上至下顺序执行,这就是顺序结构...
- C++特性使用建议
-
1.引用参数使用引用替代指针且所有不变的引用参数必须加上const。在C语言中,如果函数需要修改变量的值,参数必须为指针,如...
- C++程序员学习Zig指南(中篇)
-
1.复合数据类型结构体与方法的对比C++类:...
- 研一自学C++啃得动吗?
-
研一自学C++啃得动吗?在开始前我有一些资料,是我根据网友给的问题精心整理了一份「C++的资料从专业入门到高级教程」,点个关注在评论区回复“888”之后私信回复“888”,全部无偿共享给大家!!!个人...
- C++关键字介绍
-
下表列出了C++中的常用关键字,这些关键字不能作为变量名或其他标识符名称。1、autoC++11的auto用于表示变量的自动类型推断。即在声明变量的时候,根据变量初始值的类型自动为此变量选择匹配的...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
因果推断Matching方式实现代码 因果推断模型
-
git pull命令使用实例 git pull--rebase
-
git pull 和git fetch 命令分别有什么作用?二者有什么区别?
-
面试官:git pull是哪两个指令的组合?
-
git 执行pull错误如何撤销 git pull fail
-
git fetch 和git pull 的异同 git中fetch和pull的区别
-
git pull 之后本地代码被覆盖 解决方案
-
还可以这样玩?Git基本原理及各种骚操作,涨知识了
-
git命令之pull git.pull
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mysql max (33)
- vba instr (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)