0

0

3.mysql的中文问题,database级操作,表级操作,数据CRUD,分组操作,时间和日期,字符串相关函数,表的约束_MySQL

php中文网

php中文网

发布时间:2016-06-01 13:02:47

|

833人浏览过

|

来源于php中文网

原创



1 连接mysql服务器:mysql–uroot –p123456

  1. 查看中文问题

    show variables like 'character%';

    \

     

    2 修改mysql的字符集,退出mysql提示符界面:

    mysql -uroot -p--default_character_set=gbk;

    \

     

    3 数据库的操作:创建,查看,修改,删除

    *创建:

    创建一个名称为mydb1的数据库。

    createdatabase mydb1;

    创建一个使用utf-8字符集的mydb2数据库。

    create database mydb2character set utf8;

    创建一个使用utf-8字符集,并带校对规则的mydb3数据库。

    createdatabase mydb3 character set utf8 collate utf8_general_ci;

    *查看:

    显示所有数据库

    showdatabases;

    显示创建数据库的语句信息

    showcreate database mydb2;

    *修改:

    修改mydb1的字符集为gbk(不能修改数据库名)

    alterdatabase mydb1 character set utf8;

    *删除:

    删除数据库mydb2

    dropdatabase mydb1;

     

    4 表的操作:创建,查看,修改,删除

    usemydb2;

    *创建:

    根据实体类Person创建表person

    Person{

    intid;

    Stringname;

    }

    createtable person(

    idint,

    namevarchar(20)

    );

    mysql中的数据类型:

    bit1位 但可以指定位数,如:bit

    int2字节 可以指定最大位数,如:int 最大为4位的整数

    float2个字节 可以指定最大的位数和最大的小数位数,如:float 最大为一个5位的数,小数位最多2位

    double 4个字节 可以指定最大的位数和最大的小数位数,如:float 最大为一个6位的数,小数位最多4位

    char 必须指定字符数,如char(5) 为不可变字符 即使存储的内容为'ab',也是用5个字符的空间存储这个数据

    varchar 必须指定字符数,如varchar(5) 为可变字符 如果存储的内容为'ab',占用2个字符的空间;如果为'abc',则占用3个字符的空间

    text:大文本(大字符串)

    blob:二进制大数据 如图片,音频文件,视频文件

    date:日期 如:'1921-01-02'

    datetime:日期时间 如:'1921-01-02 12:23:43'

    timeStamp:时间戳,自动赋值为当前日期时间

     

    创建一个员工表

    createtable employee(id int,name varchar(20),sex bit,birthday date,salarydouble,entry_date date,resume text);

    *查看:

    查看所有的表:

    showtables;

    查看指定表的创建语句

    showcreate table employee;

    mysql表 名称区分大小写

    显示指定表的结构:

    descemployee;

    *删除:

    删除employee表

    droptable employee;

    *修改表:

    create table worker(id int,name varchar(20),sex bit,birthday date,salarydouble,entry_date date,resume text);

    增加一个字段:altertable worker add column height double;

    修改一个字段:altertable worker modify column height float;

    删除一个字段:altertable worker drop column height;

    更改表名:renametable employee to worker;

    修改表的字符集:altertable worker character set gbk;

     

    5 表数据的CRUD

    *C(create增加数据) Insert语句

    新建Employee表并表中添加一些记录

    createtable employee(

    idint,

    namevarchar(20),

    sexbit,

    birthdaydate,

    salarydouble,

    entry_datedate,

    resumetext

    );

     

    insertinto employee(id,name,sex,birthday,salary,entry_date,resume) values(1,'张三',1,'1983-09-21',15000,'2012-06-24','一个大牛');

    insertinto employee(id,name,sex,birthday,salary,entry_date,resume) values(2,'李四',1,'1984-09-21',10000,'2012-07-24','一个中牛');

    insertinto employee(id,name,sex,birthday,salary,entry_date,resume) values(3,'王五',0,'1985-09-21',7000,'2012-08-24','一个小牛');

    deletefrom employee where id=1

     

    createtable employee( id int,namevarchar(20),sex bit,birthday date,salary double,entry_date date,resume text);

     

    *U(update更新数据) Update语句

    将所有员工薪水都增加500元。

    updateemployee set salary=salary+500;

    将王五的员工薪水修改为10000元,resume改为也是一个中牛

    updateemployee set salary=10000,resume='也是一个中牛' where name='王五';

    *D(drop删除数据) Delete语句

    删除表中姓名为王五的记录。

    deletefrom employee where name='王五';

    删除表中所有记录。

    deletefrom employee; --可以有条件,但删除所有记录差了一点

    使用truncate删除表中记录。

    truncateemployee;--无条件效率高

     

    6 *R(Retrieve查找数据) Select语句

    准备环境:

    createtable student(

    idint,

    namevarchar(20),

    chineseint,

    englishint,

    mathint

    );

     

    insertinto student(id,name,chinese,english,math) values(1,'何东',80,85,90);

    insertinto student(id,name,chinese,english,math) values(2,'权筝',90,95,95);

    insertinto student(id,name,chinese,english,math) values(3,'何南',80,96,96);

    insertinto student(id,name,chinese,english,math) values(4,'叶坦',81,97,85);

    Dify AI
    Dify AI

    开源的大语言模型(LLM) 应用开发平台

    下载

    insertinto student(id,name,chinese,english,math) values(5,'何西',85,84,90);

    insertinto student(id,name,chinese,english,math) values(6,'丁香',92,85,87);

    insertinto student(id,name,chinese,english,math) values(7,'何北',75,81,80);

    insertinto student(id,name,chinese,english,math) values(8,'唐娇',77,80,79);

    insertinto student(id,name,chinese,english,math) values(9,'任知了',95,85,85);

    insertinto student(id,name,chinese,english,math) values(10,'王越',94,85,84);

     

    查询表中所有学生的信息。

    select* from student;

    查询表中所有学生的姓名和对应的英语成绩。

    selectname,english from student;

    过滤表中重复数据。

    selectenglish from student;

    selectDISTINCT english from student;

    selectDISTINCT english,name from student;

    selectenglish+chinese+math from student;

    selectenglish+chinese+math as 总分 from student;

    selectname,english+chinese+math as 总分 from student;

    在所有学生英语分数上加10分特长分。

    selectname,english+10 from student;

    统计每个学生的总分。

    selectenglish+chinese+math from student;

    使用别名表示学生分数

    selectname,english+chinese+math as 总分 from student;

    selectname,english+chinese+math 总分 from student;

    查询姓名为何东的学生成绩

    select* from student where name='何东';

    查询英语成绩大于90分的同学

    select* from student where english>90;

    查询总分大于250分的所有同学

    select* from student where english+chinese+math>250;

    查询英语分数在 85-95之间的同学。

    select* from student where english>=85 and english

    select* from student where english between 85 and 95;

    查询数学分数为84,90,91的同学。

    select* from student where math=84 or math=90 or math=91;

    select* from student where math in(84,90,91);

    查询所有姓何的学生成绩。

    select* from student where name like '何%';

    查询数学分>85,语文分>90的同学。

    select* from student where math>85 and chinese>90;

     

    对数学成绩排序后输出。

    select* from student order by math;

    对总分排序后输出,然后再按从高到低的顺序输出

    select* from student order by math+chinese+english desc;

    对姓何的学生成绩排序输出

    select* from student where name like '何%' order by math+chinese+english desc;

    selectname, math+chinese+english from student where name like '何%' order bymath+chinese+english desc;

    统计一个班级共有多少学生?

    selectcount(*) from student;

    统计数学成绩大于90的学生有多少个?

    selectcount(*) from student where math>90;

    统计总分大于250的人数有多少?

    selectcount(*) from student where math+chinese+english>250;

    统计一个班级数学总成绩?

    selectsum(math) from student;

    统计一个班级语文、英语、数学各科的总成绩

    selectsum(math), sum(chinese), sum(english) from student;

    统计一个班级语文、英语、数学的成绩总和

    selectsum(math+chinese+english)from student;

    selectsum(math)+sum(chinese)+sum(english) from student;

     

    求一个班级数学平均分?

    selectavg(math) from student;

    求一个班级总分平均分

    selectavg(math+chinese+english)from student;

    selectavg(math)+avg(chinese)+avg(english) from student;

    求班级最高分和最低分

    selectmax(math+chinese+english),min(math+chinese+english) from student;

    7 综合性练习:为学生表,增加一个班级列,然后训练分组查询

    查出各个班的总分,最高分

    准备环境

    给表添加一个字段:altertable student add column class_id int;

    更新表:

    updatestudent set class_id=1 where id

    updatestudent set class_id=2 where id>5;

    selectsum(math+chinese+english),max(math+chinese+english) from student group byclass_id;

    查询出班级总分大于1300分的班级ID

    selectclass_id from student group by class_id havingsum(math+chinese+english)>1300;

    selectclass_id from student where sum(math+chinese+english)>1300 group by class_id;

    note:where和group区别: 在wehre子句中不能使用分组函数

     

     

     

    8 时间和日期

    mysql>select year (now()), month(now()), day(now()) , date(now());

    +--------------+--------------+------------+-------------+

    |year (now()) | month(now()) | day(now()) | date(now()) |

    +--------------+--------------+------------+-------------+

    | 2014 | 9 | 7 | 2014-09-07 |

    +--------------+--------------+------------+-------------+

     

    selectdate_add(now(), INTERVAL 2 year) from dual;//增加两年

    selectcharset('name') employee;

    selectdate_add(now(), INTERVAL -1 day) 昨天, now() 今天, date_add(now(), INTERVAL +1 day) 明天;

     

    9 字符串相关函数

    selectconcat( charset('name'), 'aaaa') 自定义 from dual;

     

     

    10 表的约束  

    *定义主键约束 primarykey:不允许为空,不允许重复

    *定义主键自动增长 auto_increment

    *定义唯一约束 unique

    *定义非空约束 notnull

    *定义外键约束 constraintordersid_FK foreign key(ordersid) references orders(id)

    *删除主键:altertable tablename drop primary key ;

     

    createtable myclass

    (

    idINT(11) primary key auto_increment,

    namevarchar(20) unique

    );

    createtable student(

    idINT(11) primary key auto_increment,

    namevarchar(20) unique,

    passwdvarchar(15) not null,

    classidINT(11), #注意这个地方不要少逗号

    constraintstu_classid_FK foreign key(classid)references myclass(id)

    );

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
batoto漫画官网入口与网页版访问指南
batoto漫画官网入口与网页版访问指南

本专题系统整理batoto漫画官方网站最新可用入口,涵盖最新官网地址、网页版登录页面及防走失访问方式说明,帮助用户快速找到batoto漫画官方平台,稳定在线阅读各类漫画内容。

127

2026.02.25

Steam官网正版入口与注册登录指南_新手快速进入游戏平台方法
Steam官网正版入口与注册登录指南_新手快速进入游戏平台方法

本专题系统整理Steam官网最新可用入口,涵盖网页版登录地址、新用户注册流程、账号登录方法及官方游戏商店访问说明,帮助新手玩家快速进入Steam平台,完成注册登录并管理个人游戏库。

18

2026.02.25

TypeScript全栈项目架构与接口规范设计
TypeScript全栈项目架构与接口规范设计

本专题面向全栈开发者,系统讲解基于 TypeScript 构建前后端统一技术栈的工程化实践。内容涵盖项目分层设计、接口协议规范、类型共享机制、错误码体系设计、接口自动化生成与文档维护方案。通过完整项目示例,帮助开发者构建结构清晰、类型安全、易维护的现代全栈应用架构。

15

2026.02.25

Python数据处理流水线与ETL工程实战
Python数据处理流水线与ETL工程实战

本专题聚焦 Python 在数据工程场景下的实际应用,系统讲解 ETL 流程设计、数据抽取与清洗、批处理与增量处理方案,以及数据质量校验与异常处理机制。通过构建完整的数据处理流水线案例,帮助开发者掌握数据工程中的性能优化思路与工程化规范,为后续数据分析与机器学习提供稳定可靠的数据基础。

1

2026.02.25

Java领域驱动设计(DDD)与复杂业务建模实战
Java领域驱动设计(DDD)与复杂业务建模实战

本专题围绕 Java 在复杂业务系统中的建模与架构设计展开,深入讲解领域驱动设计(DDD)的核心思想与落地实践。内容涵盖领域划分、聚合根设计、限界上下文、领域事件、贫血模型与充血模型对比,并结合实际业务案例,讲解如何在 Spring 体系中实现可演进的领域模型架构,帮助开发者应对复杂业务带来的系统演化挑战。

1

2026.02.25

Golang 生态工具与框架:扩展开发能力
Golang 生态工具与框架:扩展开发能力

《Golang 生态工具与框架》系统梳理 Go 语言在实际工程中的主流工具链与框架选型思路,涵盖 Web 框架、RPC 通信、依赖管理、测试工具、代码生成与项目结构设计等内容。通过真实项目场景解析不同工具的适用边界与组合方式,帮助开发者构建高效、可维护的 Go 工程体系,并提升团队协作与交付效率。

18

2026.02.24

Golang 性能优化专题:提升应用效率
Golang 性能优化专题:提升应用效率

《Golang 性能优化专题》聚焦 Go 应用在高并发与大规模服务中的性能问题,从 profiling、内存分配、Goroutine 调度、GC 机制到 I/O 与锁竞争逐层分析。结合真实案例讲解定位瓶颈的方法与优化策略,帮助开发者建立系统化性能调优思维,在保证代码可维护性的同时显著提升服务吞吐与稳定性。

9

2026.02.24

Golang 面试题精选:高频问题与解答
Golang 面试题精选:高频问题与解答

Golang 面试题精选》系统整理企业常见 Go 技术面试问题,覆盖语言基础、并发模型、内存与调度机制、网络编程、工程实践与性能优化等核心知识点。每道题不仅给出答案,还拆解背后的设计原理与考察思路,帮助读者建立完整知识结构,在面试与实际开发中都能更从容应对复杂问题。

6

2026.02.24

Golang 运行与部署实战:从本地到云端
Golang 运行与部署实战:从本地到云端

《Golang 运行与部署实战》围绕 Go 应用从开发完成到稳定上线的完整流程展开,系统讲解编译构建、环境配置、日志与配置管理、容器化部署以及常见运维问题处理。结合真实项目场景,拆解自动化构建与持续部署思路,帮助开发者建立可靠的发布流程,提升服务稳定性与可维护性。

5

2026.02.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Swoft2.x速学之http api篇课程
Swoft2.x速学之http api篇课程

共16课时 | 1万人学习

PHP基础入门课程
PHP基础入门课程

共33课时 | 2.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号