SQL 学习整理

PHPer 2020-03-25 1726 0 0

Yii2遇到了Post::find()->where(['exists',Mark::find()->where()]);这样的语句于是看了下他对应的是SQL中的exists,于是决定这里整理下学习SQL时遇到的问题 2020...

Yii2遇到了Post::find()->where(['exists',Mark::find()->where()]);这样的语句...

立即注册

更新于:2020-05-02 14:17:51
    您需要登录后才可以评论。 立即注册

    sql查询两张表中不同的数据

    select * from B where (select count(1) from A where A.ID = B.ID) = 0

    select * from B where (select count(1) from A where A.ID = B.ID) = 0

    注意,这里A.id字段要和B.id字段的类型相同,比如都是int,否则执行会报错

    有比如

    select * from B where (select count(1) from A where A.name= B.name) = 0...

    立即注册
    更新于:2022-04-19 03:26:04

    SQL中EXISTS的使用

    SQL中EXISTS的使用1.简介不相关子查询:子查询的查询条件不依赖于父查询的称为不相关子查询。相关子查询:子查询的查询条件依赖于外层父查询的某个属性值的称为相关...

    SQL中EXISTS的使用

    1.简介

    • 不相关子查询:子查询的查询条件不依赖于父查询的称为不相关子查询。
    • 相关子查询:子查询的查询条件依赖于外层父查询的某个属性值的称为相关子查询,带EXISTS 的子查询就是相关子查询
    • EXISTS表示存在量词:带有EXISTS的子查询不返回任何记录的数据,只返回逻辑值“True”或“False”

    2.表结构

    选课表:学号、课程号

    学生表:学号、姓名

    课程表:课程号、课程名

    3.查询所有选修了“C1”课程的学生名。

    普通SQL查询:

    SELECT 姓名 
    FROM 学生表 
    WHERE 学号 IN (SELECT 学号 FROM 选课表 WHERE 课程号 = 'C1'); 
    

    带EXISTS的SQL查询:

    SELECT 姓名
    FROM 学生表
    WHERE EXISTS    
    (
        SELECT * 
        FROM 选课表
        WHERE 学生表.学号 = 选课表.学号 AND 课程号 = 'C1' 
    );
    

    相关子查询执行过程:先在外层查询中取“学生表”的第一行记录,用该记录的相关的属性值(在内层WHERE子句中给定的)处理内层查询,若外层的WHERE子句返回“TRUE”值,则这条记录放入结果表中。然后再取下一行记录;重复上述过程直到外层表的记录全部遍历一次为止。

    EXISTS语句不关心子查询的具体内容,因此用“SELECT *”,“Exists + 子查询”用来判断该子查询是否返回记录。...

    立即注册
    更新于:2020-03-25 23:49:32

    Yii2报错没有关联命名 common\models\Post has no relation named

    Invalid Parameter – yii\base\InvalidParamExceptioncommon\models\Post has no relation named "{{%mark}}". 我记得是在程序里用了$query = Post::find()->with({...

    Invalid Parameter – yii\base\InvalidParamException

    common\models\Post has no relation named "{{%mark}}".

    我记得是在程序里用了$query = Post::find()->with({{%mark}}.... 这样的语句,其实就是想在标记表里取出符合条件的帖子id,然后在帖子表里查找这些id。结果想了好些办法才搞定。...

    立即注册
    更新于:2020-03-27 00:19:25

    SQL常用语句

    SQL常用语句一、基础1、说明:创建数据库CREATE DATABASE database-name2、说明:删除数据库drop database dbname3、说明:备份sql server--- 创建 备份数据的 ...

    SQL常用语句

    一、基础
    1、说明:创建数据库
    CREATE DATABASE database-name
    2、说明:删除数据库
    drop database dbname
    3、说明:备份sql server
    --- 创建 备份数据的 device
    USE master
    EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat'
    --- 开始 备份
    BACKUP DATABASE pubs TO testBack
    4、说明:创建新表
    create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..)
    根据已有的表创建新表:
    A:create table tab_new like tab_old (使用旧表创建新表)
    B:create table tab_new as select col1,col2... from tab_old definition only
    5、说明:删除新表
    drop table tabname
    6、说明:增加一个列
    Alter table tabname add column col type
    注:列增加后将不能删除。DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。
    7、说明:添加主键: Alter table tabname add primary key(col)
    说明:删除主键: Alter table tabname drop primary key(col)
    8、说明:创建索引:create [unique] index idxname on tabname(col....)
    删除索引:drop index idxname
    注:索引是不可更改的,想更改必须删除重新建。
    9、说明:创建视图:create view viewname as select statement
    删除视图:drop view viewname
    10、说明:几个简单的基本的sql语句
    选择:select * from table1 where 范围
    插入:insert into table1(field1,field2) values(value1,value2)
    删除:delete from table1 where 范围
    更新:update table1 set field1=value1 where 范围
    查找:select * from table1 where field1 like '%value1%' ---like的语法很精妙,查资料!
    排序:select * from table1 order by field1,field2 [desc]
    总数:select count as totalcount from table1
    求和:select sum(field1) as sumvalue from table1
    平均:select avg(field1) as avgvalue from table1
    最大:select max(field1) as maxvalue from table1
    最小:select min(field1) as minvalue from table1
    11、说明:几个高级查询运算词
    A: UNION 运算符
    UNION 运算符通过组合其他两个结果表(例如 TABLE1 和 TABLE2)并消去表中任何重复行而派生出一个结果表。当 ALL 随 UNION 一起使用时(即 UNION ALL),不消除重复行。两种情况下,派生表的每一行不是来自 TABLE1 就是来自 TABLE2。
    B: EXCEPT 运算符
    EXCEPT 运算符通过包括所有在 TABLE1 中但不在 TABLE2 中的行并消除所有重复行而派生出一个结果表。当 ALL 随 EXCEPT 一起使用时 (EXCEPT ALL),不消除重复行。
    C: INTERSECT 运算符
    INTERSECT 运算符通过只包括 TABLE1 和 TABLE2 中都有的行并消除所有重复行而派生出一个结果表。当 ALL 随 INTERSECT 一起使用时 (INTERSECT ALL),不消除重复行。
    注:使用运算词的几个查询结果行必须是一致的。
    12、说明:使用外连接
    A、left outer join:
    左外连接(左连接):结果集既包括连接表的匹配行,也包括左连接表的所有行。
    SQL: select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c
    B:right outer join:
    右外连接(右连接):结果集既包括连接表的匹配连接行,也包括右连接表的所有行。
    C:full outer join:
    全外连接:不仅包括符号连接表的匹配行,还包括两个连接表中的所有记录。



    二、提升
    1、说明:复制表(只复制结构,源表名:a 新表名:b) (Access可用)
    法一:select * into b from a where 1<>1
    法二:select top 0 * into b from a
    2、说明:拷贝表(拷贝数据,源表名:a 目标表名:b) (Access可用)
    insert into b(a, b, c) select d,e,f from b;
    3、说明:跨数据库之间表的拷贝(具体数据使用绝对路径) (Access可用)
    insert into b(a, b, c) select d,e,f from b in '具体数据库' where 条件
    例子:..from b in '"&Server.MapPath(".")&"\data.mdb" &"' where..
    4、说明:子查询(表名1:a 表名2:b)
    select a,b,c from a where a IN (select d from b ) 或者: select a,b,c from a where a IN (1,2,3)
    5、说明:显示文章、提交人和最后回复时间
    select a.title,a.username,b.adddate from table a,(select max(adddate) adddate from table where table.title=a.title) b
    6、说明:外连接查询(表名1:a 表名2:b)
    select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c
    7、说明:在线视图查询(表名1:a )
    select * from (SELECT a,b,c FROM a) T where t.a > 1;
    8、说明:between的用法,between限制查询数据范围时包括了边界值,not between不包括
    select * from table1 where time between time1 and time2
    select a,b,c, from table1 where a not between 数值1 and 数值2
    9、说明:in 的使用方法
    select * from table1 where a [not] in ('值1','值2','值4','值6')
    10、说明:两张关联表,删除主表中已经在副表中没有的信息
    delete from table1 where not exists ( select * from table2 where table1.field1=table2.field1 )
    11、说明:四表联查问题:
    select * from a left inner join b on a.a=b.b right inner join c on a.a=c.c inner join d on a.a=d.d where .....
    12、说明:日程安排提前五分钟提醒
    SQL: select * from 日程安排 where datediff('minute',f开始时间,getdate())>5
    13、说明:一条sql 语句搞定数据库分页
    select top 10 b.* from (select top 20 主键字段,排序字段 from 表名 order by 排序字段 desc) a,表名 b where b.主键字段 = a.主键字段 order by a.排序字段
    14、说明:前10条记录
    select top 10 * form table1 where 范围
    15、说明:选择在每一组b值相同的数据中对应的a最大的记录的所有信息(类似这样的用法可以用于论坛每月排行榜,每月热销产品分析,按科目成绩排名,等等.)
    select a,b,c from tablename ta where a=(select max(a) from tablename tb where tb.b=ta.b)
    16、说明:包括所有在 TableA 中但不在 TableB和TableC 中的行并消除所有重复行而派生出一个结果表
    (select a from tableA ) except (select a from tableB) except (select a from tableC)
    17、说明:随机取出10条数据
    select top 10 * from tablename order by newid()
    18、说明:随机选择记录
    select newid()
    19、说明:删除重复记录
    Delete from tablename where id not in (select max(id) from tablename group by col1,col2,...)
    20、说明:列出数据库里所有的表名
    select name from sysobjects where type='U'
    21、说明:列出表里的所有的
    select name from syscolumns where id=object_id('TableName')
    22、说明:列示type、vender、pcs字段,以type字段排列,case可以方便地实现多重选择,类似select 中的case。
    select type,sum(case vender when 'A' then pcs else 0 end),sum(case vender when 'C' then pcs else 0 end),sum(case vender when 'B' then pcs else 0 end) FROM tablename group by type
    显示结果:
    type vender pcs
    电脑 A 1
    电脑 A 1
    光盘 B 2
    光盘 A 2
    手机 B 3
    手机 C 3
    23、说明:初始化表table1
    TRUNCATE TABLE table1
    24、说明:选择从10到15的记录
    select top 5 * from (select top 15 * from table order by id asc) table_别名 order by id desc
    三、技巧
    1、1=1,1=2的使用,在SQL语句组合时用的较多
    "where 1=1" 是表示选择全部 "where 1=2"全部不选,
    如:
    if @strWhere !=''
    begin
    set @strSQL = 'select count(*) as Total from [' + @tblName + '] where ' + @strWhere
    end
    else
    begin
    set @strSQL = 'select count(*) as Total from [' + @tblName + ']'
    end
    我们可以直接写成
    set @strSQL = 'select count(*) as Total from [' + @tblName + '] where 1=1 安定 '+ @strWhere
    2、收缩数据库
    --重建索引
    DBCC REINDEX
    DBCC INDEXDEFRAG
    --收缩数据和日志
    DBCC SHRINKDB
    DBCC SHRINKFILE
    3、压缩数据库
    dbcc shrinkdatabase(dbname)
    4、转移数据库给新用户以已存在用户权限
    exec sp_change_users_login 'update_one','newname','oldname'
    go
    5、检查备份集
    RESTORE VERIFYON*** from disk='E:\dvbbs.bak'
    6、修复数据库
    ALTER DATABASE [dvbbs] SET SINGLE_USER
    GO
    DBCC CHECKDB('dvbbs',repair_allow_data_loss) WITH TABLOCK
    GO
    ALTER DATABASE [dvbbs] SET MULTI_USER
    GO
    7、日志清除
    SET NOCOUNT ON
    DECLARE @LogicalFileName sysname,
    @MaxMinutes INT,
    @NewSize INT...

    立即注册
    更新于:2020-03-26 23:46:18

    SQL复杂查询(案例一)

    https://blog.csdn.net/dingchenxixi/article/details/732235721.列出至少有一个员工的所有部门编号、名称,并统计出这些部门的平均工资、最...

    https://blog.csdn.net/dingchenxixi/article/details/73223572

    1.列出至少有一个员工的所有部门编号、名称,并统计出这些部门的平均工资、最低工资、最高工资。

    确定所需要的数据表
    emp表:员工的部门编号,平均工资,最低工资,最高工资
    dept表:部门名称

    确定已知的关联字段
    emp.deptno=dept.deptno
    1.1 先得到员工数大于1的部门

    SELECT deptno,COUNT(empno) FROM emp GROUP BY deptno HAVING COUNT(empno)>1;  
    • 1
    97ae32c321_normal.png

    1.2 找到部门名称

    SELECT d.dname,COUNT(e.empno) FROM emp e ,dept d 
         WHERE e.deptno=d.deptno GROUP BY d.deptno,d.dname     HAVING COUNT(e.empno)>1;
    • 1
    • 2
    50daf5547d_normal.png

    1.3 统计各种信息

    SQL分组:http://blog.csdn.net/dingchenxixi/article/details/70193634

    select子句之后,只能出现分组的字段和统计函数,其它的字段不能出现

    由于AVG(),MAX(),MIN()为统计函数,可以直接使用

    SELECT d.deptno,d.dname,COUNT(e.empno),AVG(sal),MIN(sal),MAX(sal) 
       FROM emp e ,dept d  
       WHERE e.deptno=d.deptno 
       GROUP BY d.deptno,d.dname HAVING COUNT(e.empno)>1;
    • 1
    • 2
    • 3
    • 4
    81499778df_normal.png

    2.列出薪金比“SMITH”或“ALLEN”多的所有员工的编号、姓名、部门名称、其领导姓名。
    确定所需要的数据表
    emp表:列出“SMITH”或“ALLEN”的薪金
    emp表:员工的编号,姓名
    dept表:部门名称

    确定已知的关联字段
    emp.deptno=dept.deptno;
    emp1.mgr = emp2.empno (自关联查询)

    2.1 先查询出“SMITH”或“ALLEN”的薪金

    SELECT sal FROM emp WHERE ename='SMITH' OR ename='ALLEN'
    • 1

    或者

    SELECT sal FROM emp WHERE ename IN('SMITH','ALLEN');
    • 1
    aed25c6697_normal.png

    2.2 子查询,查询比“SMITH”或“ALLEN”薪金多的员工编号,姓名,部门名称...

    立即注册
    更新于:2020-03-27 00:02:59

    Sql常用查询操作

    https://blog.csdn.net/bruce_up/article/details/82750024 1.查询语句模板: 需要注意的是: FROM 才是 SQL ...

    https://blog.csdn.net/bruce_up/article/details/82750024

    1.查询语句模板:

    需要注意的是:

    1. FROM 才是 SQL 语句执行的第一步,并非 SELECT 。
    2. SELETC 是在WHERE语句执行之后执行的,所以不能再WHERE语句后使用SELECT中设置的别名
    3. WHERE是对分组前进行的过滤,HAVING是对分组后进行过滤。

    2.sql中的 与 或 非

    与--and 或--or 非--not 注意的是 :and 优先级高于 or A and B or C and D 最后执行or

    3.设置别名:

    select sal*12 as "年薪" from 表名 t ; sa "年薪" 给 列设置别名 , t 是给表设置别名

    4.查询空值

    select * from emp where comm is null (is not null)

    5.模糊查询:

    %(通配符)表示任意长度的字符 ,_ 表示一个字符。 例如以S开头的 任意结束 (S%)

    select 字段名 from 表名 where 字段名 like '%s%' ;

    6.分组:

    通过性别不同分组查数据:

    select sex, avg(age) as 平均年龄 from user group by sex;

    注意:
    1. 使用分组后select 后面只能写分组条件(group by后面的值)或者组函数
    2. 分组函数 count min max avg sum
    3. 要筛选结果 可以先使用where 再用group by 或者先用group by 再用having
    4. group by 执行过程如下:

    7.单行函数:

    1)数字函数

    --四舍五入 ROUND(input[,n]) n表示小数位如果n被忽略则无小数位SELECT ROUND(12.111) FROM dual;SELECT ROUND(12.111,1) FROM dual;SELECT ROUND(12.164,1) FROM dual;--截取数字 TRUNC (input[,n]) 将数字值截取,n代表截取的小数位,如果n被忽略则默认0SELECT TRUNC(12.113) FROM dual;SELECT TRUNC(12.113,2) FROM dual;--返回m除于n的余数 MOD(m,n)SELECT MOD(3,2) FROM dual

    2)字符函数

    select * from emp;--转换为大写SELECT UPPER(e.ename) FROM emp e;--转换为小写SELECT LOWER(e.ename) FROM emp e;--首字母转换为大写SELECT INITCAP(ename) FROM emp--连接第一个字符到第二个字符等价于“||”SELECT CONCAT(ename,empno) EMPINFO FROM empSELECT ename ||' ' || empno EMPINFO FROM emp --获取字符串中指定的字符,SUBSTR(input,m,[n]) 从m位置开始,取n个字符长度,如果n被忽略,则取到字符串结尾处SELECT SUBSTR(ename,1,3FROM empSELECT SUBSTR(ename,1FROM emp--返回字符串的字符数SELECT ename,LENGTH(ename) as "str_length" FROM emp--返回字符值中查找字符串char的数字位置,m作为查找的开始,n代表第n次发现,m,n默认值为1,及默认是从开始位置查找,报告第一个查询到的位置INSTR(input,char[,m][.n])SELECT ename,INSTR(ename,'A') as "第一次出现a的位置" FROM (SELECT UPPER(ename) as ename FROM emp )--从字符串中查找字符char1,找到则替换为char2SELECT REPLACE(ename,'A','哈哈') FROM emp--左补全函数SELECT LPAD('EMPNO',12,'*') FROM emp--右补全函数SELECT RPAD('EMPNO',12,'*')FROM emp

    3)日期函数 ...

    立即注册
    更新于:2020-03-27 00:13:06

    【知乎】从零学会SQL:复杂查询

    内容太多了,还没来得及看,是想进一步学习SQL的,先在网上找些,有空时再仔细看 20200327 00:18从零学会SQL:复杂查询crazy1.视图1. 在实际的数据库中,每...

    内容太多了,还没来得及看,是想进一步学习SQL的,先在网上找些,有空时再仔细看 20200327 00:18


    从零学会SQL:复杂查询

    1d78879457_normal.jpg

    crazy

    1.视图

    1. 在实际的数据库中,每一张表会有很多个字段,但是不同的用户只想了解自己想了解的字段,对于其他的字段并不感兴趣,这时候使用视图可以把自己想要的一些字段再封装成一张表,这样每次特定用户只需要访问这张封装成的表即可了解自己想知道的字段。再说的专业一点,视图是对SQL语句的封装,这个说法在下面进行解释

    2. 视图是对SQL语句的封装。因为,我们在数据库中建立的一张张表会实际存储到存储设备上,比如磁盘,我们每次使用select语句,实际上就是在访问内存中的表,但是视图并不是,视图保存的并不是数据,而是select语句,每次从视图中读取数据的时候,相当于是在内部执行select语句并创建出一张临时表

    3. 视图的优点:(1)视图不需要保存实际数据,节省存储空间(2)可以将频繁使用的select语句保存成视图,这样就不用每次都书写复杂的SQL了

    4716ee463c_normal.jpg/*

    创建视图

    create view 视图名称(<视图列名1>,<视图列名2>,...)

    as

    <select 查询语句>;

    */

    create view 按性别汇总(性别,人数)

    as

    select 性别,count(*)

    from student

    group by 性别;

    select*

    from 按性别汇总; -- 在from子句中,使用视图名称代替表名称

    -- 视图中存放的是sql查询语句,所以视图中的语句会随着原表的变化而更新,视图也不需要保存数据

    -- 注意事项:避免在视图的基础上再去创建视图;不能往视图插入数据,否则会报错

    2.子查询

    嵌套SELECT语句也叫子查询,一个 SELECT 语句的查询结果能够作为另一个语句的输入值。子查询不但能够出现在Where子句中,也能够出现在from子句中,作为一个临时表使用,也能够出现在select list中,作为一个字段值来返回。

    select 性别,人数
    from (
    select 性别,count(*) as 人数
    from student
    group by 性别 -- 先运行子查询
    ) as 按性别汇总;
    
    select 性别,count(*) as 人数
    from student
    group by 性别;
    
    -- in/any/all(子查询)
    
    -- 找出每个课程里成绩最低的学号
    -- 1.查找出每门课程的最低成绩有哪些值
    select 课程号,min(成绩)
    from score
    group by 课程号;
    
    -- 2.在成绩表里查找这些值对应的学号
    select 学号,成绩
    from score
    where 成绩 in(80,50,40);
    
    -- 这个可以显示正确的结果
    select 学号,成绩
    from score
    where (课程号 =0001 and 成绩 =80) or (课程号 =0002 and 成绩 =50) or (课程号 =0003 and 成绩 =40);
    
    select 学号,成绩
    from score as s1
    where 成绩 =(select min(成绩) 
    from score as s2 
    where s1.课程号 = s2.课程号 -- 在同一课程号中对各学号的成绩与最低成绩进行比较
    group by 课程号);
    
    -- 这个语句查询结果不太对,上面的两块代码可以正确显示每门课程里成绩最低的学号
    select 学号,成绩
    from score
    where 成绩 in (
    select min(成绩)
    from score
    group by 课程号
    );
    
    /*
    any(子查询) 与some(子查询)相同
    select 列名1
    from 表名1
    where 列名 > any(子查询);
    */
    
    /*
    哪些学生的成绩比课程0002的全部成绩里的任意一个高呢?
    第一步:课程0002的全部成绩,比如是(10,30)
    第二步:某个学生的成绩大于任何一个第一步里的成绩,就符合条件
    */
    -- 第一步
    select 成绩
    from score
    where 课程号 = '0002';
    
    -- 第二步
    select 学号,成绩
    from score
    where 成绩 > any(
    select 成绩
    from score
    where 课程号 = '0002'
    );
    
    
    -- 哪些学生的成绩比课程0002的全部成绩都高呢?
    select 学号,成绩
    from score
    where 成绩 > all(
    select 成绩
    from score
    where 课程号 = '0002'
    );
    
    /*
    使用子查询的注意事项
    1.a>3*all(b)是错的,正确格式是a/3=all(b)
    2.避免使用多层嵌套子查询
    3.select...from...子查询 as 子查询名称(可省略)
    */
    

    3.标量子查询

    标量子查询就是返回值只能有一行一列的子查询...

    立即注册
    更新于:2020-03-27 00:18:40
    相关内容

    常用的网络协议学习整理

    HTTP/1.1 302 Found(PHP的get_headers()函数验证链接是否有效)

    HTTP/1.0 200 OK(PHP的get_headers()函数验证链接是否有效)

    php知识点学习整理

    PHP preg_quote() 函数

    PHP str_ireplace() 函数

    查看php位置

    php7.4 查看版本

    PHP提示 cURL error 60: SSL certificate problem: unable to get loca...

    php过滤表单输入的emoji表情

    PHP 中英文混排截取字符串 (用php自带的函数,简单效果又好)

    PHP的源代码BUG整理

    php如何查看扩展是否开启

    linux下安装php的Exif扩展笔记!(用LNMP一键安装脚本安装的php)

    configure: error: Cannot find ldap.h 解决方法

    一个PHP针对数字的加密解密类

    php的Memcache addServer 后set失败

    PHP8 报错Required parameter $r follows optional parameter

    php执行shell不阻塞方法

    CURL超时时间设置

    Mysql问题整理

    Yii2数据库报错-SQLSTATE[HY093]: Invalid parameter number: no para...

    Mysql server has gone away 报错原因分析及解决办法

    mysql 警告 could not be resolved: Name or service not known

    Mysql用特殊字符设置密码遇到的问题

    Mysql的函数substring使用注意事项

    MySQL 5.7内存使用分析

    mysql 命令整理

    【mysql】主键、普通索引、唯一索引和全文索引的比较

    没有接收到要导入的数据。可能是文件名没有提交,也可能是文件大小超出 PHP 限...

    Mysql 报错'SQLSTATE[HY000] [1045] Access denied for user 'root'@'...

    php连接mysql报错The server requested authentication method unknown to ...

    Mysql登录提示ERROR 2003 (HY000): Can't connect to MySQL server o...

    Mysql报错SQLSTATE[HY000]: General error: 1366 Incorrect string ...

    全网最详尽的Centos和Windows系统 Mysql8 root忘记密码解决办法

    mysql数据库操作 报错 #1030 - Got error 176 "Read page with wrong ...

    Linux系统彻底卸载MySQL数据库

    Linux下mysql5.7忘记root密码的解决方法

    ERROR 1130 (HY000): Host '127.0.0.1' is not allowed to connect to...

    mysql创建数据类型为JSON时,显示的longtext数据类型

    mysql 修改编码utf8mb4依旧无法保存表情 Incorrect string value: '\x解决办法

    MySQL 中 不等于 会过滤掉 Null 的问题

    RECOVER_YOUR_DATA勒索恢复

    Mysql知识学习

    MySQL 8.0 索引特性1-函数索引

    MySQL字符串函数substring:字符串截取

    Mysql的临时变量取值3例

    mysql查找字符串出现位置

    mysql 更改AUTO_INCREMENT 失败的解决办法

    MYSQL 数据库导入导出命令

    mysql如何判断不包含某个字符串

    Mysql中不要用操作符和函数名等等来命名字段

    ORM 实例教程

    Mysql中的排序规则utf8_unicode_ci、utf8_general_ci的区别总结

    MySQL 中 datetime 和 timestamp 的区别与选择

    Invalid default value for ‘updated_at‘

    设置MySQL的group_concat_max_len长度为最大值

    MySQL中concat()、concat_ws()、group_concat()函数使用技巧与心得

    mysql的left join和inner join的效率对比,以及如何优化

    mysql 索引优化十例

    MySQL数据表中有自增长主键时如何插入数据

    bill_20210927.sql">mysqldump按条件导出mysql数据库数据

    推荐内容

    分享几个好用的bt搜索bt资源下载网址网站

    影视电影剧集动漫综艺bt资源在线播放网址网站推荐分享

    全网最新bt磁力搜索引擎bt资源bt网站网址分享

    人气美女女优百度指数排行榜(波多野结衣,苍井空,三上悠亚,深田咏美,桥本有菜,北条...

    最强人造人深田咏美,业界的社交女王

    人生起起落落的三上悠亚,成名前的清纯风,怎么搭配出来的?

    业内第一大长腿,桥本有菜的腿究竟有多长

    波多野结衣,岛国业界著作最多的超级劳模

    日本AV界NO.1,苍井空是多少宅男的疯狂?

    美女女优视频混剪 This Girl-Laza Morgan

    怎样使用V2Ray代理和SSTap玩如魔兽世界/绝地求生/LOL台服/战地3/黑色沙漠/彩...

    sstap游戏代理教程 从此玩如魔兽世界/绝地求生/LOL台服/战地3/黑色沙漠/彩虹六...

    影视电影剧集动漫综艺bt资源在线播放网址网站推荐分享