热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

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

65279;65279;1连接MYSQL服务器:mysql–uroot–p123456查看中文问题showvariableslikecharacter%;2修改mysql的字符集,退出mysql提示符界面:mysql-uroot-p--default_ch


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<3>

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

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

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

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

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

    text:大文本(大字符串)

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

    date:日期 如:&#39;1921-01-02&#39;

    datetime:日期时间 如:&#39;1921-01-02 12:23:43&#39;

    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,&#39;张三&#39;,1,&#39;1983-09-21&#39;,15000,&#39;2012-06-24&#39;,&#39;一个大牛&#39;);

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

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

    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=&#39;也是一个中牛&#39; where name=&#39;王五&#39;;

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

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

    deletefrom employee where name=&#39;王五&#39;;

    删除表中所有记录。

    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,&#39;何东&#39;,80,85,90);

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

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

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

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

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

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

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

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

    insertinto student(id,name,chinese,english,math) values(10,&#39;王越&#39;,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=&#39;何东&#39;;

    查询英语成绩大于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<=95;

    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 &#39;何%&#39;;

    查询数学分>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 &#39;何%&#39; order by math+chinese+english desc;

    selectname, math+chinese+english from student where name like &#39;何%&#39; 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<=5;

    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(&#39;name&#39;) employee;

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

    9 字符串相关函数

    selectconcat( charset(&#39;name&#39;), &#39;aaaa&#39;) 自定义 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)

    );


推荐阅读
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • PHP设置MySQL字符集的方法及使用mysqli_set_charset函数
    本文介绍了PHP设置MySQL字符集的方法,详细介绍了使用mysqli_set_charset函数来规定与数据库服务器进行数据传送时要使用的字符集。通过示例代码演示了如何设置默认客户端字符集。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 本文介绍了在Hibernate配置lazy=false时无法加载数据的问题,通过采用OpenSessionInView模式和修改数据库服务器版本解决了该问题。详细描述了问题的出现和解决过程,包括运行环境和数据库的配置信息。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • 本文介绍了解决Netty拆包粘包问题的一种方法——使用特殊结束符。在通讯过程中,客户端和服务器协商定义一个特殊的分隔符号,只要没有发送分隔符号,就代表一条数据没有结束。文章还提供了服务端的示例代码。 ... [详细]
  • Linux服务器密码过期策略、登录次数限制、私钥登录等配置方法
    本文介绍了在Linux服务器上进行密码过期策略、登录次数限制、私钥登录等配置的方法。通过修改配置文件中的参数,可以设置密码的有效期、最小间隔时间、最小长度,并在密码过期前进行提示。同时还介绍了如何进行公钥登录和修改默认账户用户名的操作。详细步骤和注意事项可参考本文内容。 ... [详细]
  • 本文介绍了在rhel5.5操作系统下搭建网关+LAMP+postfix+dhcp的步骤和配置方法。通过配置dhcp自动分配ip、实现外网访问公司网站、内网收发邮件、内网上网以及SNAT转换等功能。详细介绍了安装dhcp和配置相关文件的步骤,并提供了相关的命令和配置示例。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • 本文介绍了使用AJAX的POST请求实现数据修改功能的方法。通过ajax-post技术,可以实现在输入某个id后,通过ajax技术调用post.jsp修改具有该id记录的姓名的值。文章还提到了AJAX的概念和作用,以及使用async参数和open()方法的注意事项。同时强调了不推荐使用async=false的情况,并解释了JavaScript等待服务器响应的机制。 ... [详细]
  • Java实战之电影在线观看系统的实现
    本文介绍了Java实战之电影在线观看系统的实现过程。首先对项目进行了简述,然后展示了系统的效果图。接着介绍了系统的核心代码,包括后台用户管理控制器、电影管理控制器和前台电影控制器。最后对项目的环境配置和使用的技术进行了说明,包括JSP、Spring、SpringMVC、MyBatis、html、css、JavaScript、JQuery、Ajax、layui和maven等。 ... [详细]
  • Centos7.6安装Gitlab教程及注意事项
    本文介绍了在Centos7.6系统下安装Gitlab的详细教程,并提供了一些注意事项。教程包括查看系统版本、安装必要的软件包、配置防火墙等步骤。同时,还强调了使用阿里云服务器时的特殊配置需求,以及建议至少4GB的可用RAM来运行GitLab。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • 本文介绍了如何找到并终止在8080端口上运行的进程的方法,通过使用终端命令lsof -i :8080可以获取在该端口上运行的所有进程的输出,并使用kill命令终止指定进程的运行。 ... [详细]
author-avatar
布丁宝宝-_932
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有