一次作业过程及其问题的记录:mysql建立数据库、建表、查询和插入等
前言
这次的作业需要我建立一个小的数据库。
这次作业我使用了mysql,进行了建库、建表、查询、插入等操作。
本文是对本次作业相关的mysql操作过程及过程中出现的问题的记录。
另一篇文章(详情请点击)介绍了如何使用pymysql连接该数据库并使用Flask搭建后端接口,响应前端的GET和POST请求。
正文
作业中对数据库的要求是:
- 建立一个用户信息表,其包括用户名、密码、手机号、邮箱和手机号等属性,并向其中插入几条测试数据。
登录数据库
因为挺久没用数据库,就先测试下自己之前装的mysql还能不能用,于是打开CMD运行如下指令:
mysql
出现如下错误:
ERROR 1045 (28000): Access denied for user 'ODBC'@'localhost' (using password: NO)
看起来是因为没输密码
所以输入密码,运行如下指令:
mysql -u root -p
-u
参数是指username、user之类的,即用户名,我的用户名是root
;-p
参数是指password,运行下面这条指令后,会要求输入密码,输入正确密码即成功登录。
我的mysql环境还可以,直接登录成功。
建库
执行如下指令,创建名为shopdata的数据库,会得到Query OK, 1 row affected (x.xx sec)
。
create database shopdata;
进入/选择数据库
执行如下指令后,会看到Database changed
的信息。
use shopdata;
建表
执行如下指令,创建名为userinfo的表。
我这里对userinfo的定义是:
主键是用户名userid
password是非NULL的
phone和email是unique的
这5个属性的类型都是varchar(15)
最长15,对于email来说不太够用
create table userinfo (
'userid' varchar(15) primary key,
'password' varchar(15) not null,
'company' varchar(15),
'phone' varchar(15) unique,
'email' varchar(15) unique
);
执行上边这条命令后,得到了一个错误:
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ''userid' varchar(15) primary key,
'password' varchar(15) not null,
'comp' at line 2
经查询,发现属性名应该用反引号`而不是单引号',所以将单引号改成反引号,执行如下命令:
create table userinfo (
`userid` varchar(15) primary key,
`password` varchar(15) not null,
`company` varchar(15),
`phone` varchar(15) unique,
`email` varchar(15) unique
);
这条命令执行成功,得到Query OK, 0 rows affected (x.xx sec)
。
查看userinfo表
执行如下命令,查看userinfo表的结构。
describe userinfo;
执行后,得到如下结果:
+----------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| userid | varchar(15) | NO | PRI | NULL | |
| password | varchar(15) | NO | | NULL | |
| company | varchar(15) | YES | | NULL | |
| phone | varchar(15) | YES | UNI | NULL | |
| email | varchar(15) | YES | UNI | NULL | |
+----------+-------------+------+-----+---------+-------+
5 rows in set (0.57 sec)
插入3条数据
执行如下命令,插入3条数据。
insert into userinfo values
('user1','0000','zstu','13777860000','7746@qq.com'),
('user2','0000','zstu','13777860001','7747@qq.com'),
('user3','0000','zstu','13777860002','7748@qq.com');
执行后,得到如下信息:
Query OK, 3 rows affected (0.11 sec)
Records: 3 Duplicates: 0 Warnings: 0
查询数据
执行如下语句,查询所有元组。
select * from userinfo;
执行后,得到如下结果(在我做好作业后、写这篇博客前,我已经插入了一些其他的数据,所以有9条记录):
+------------+----------+---------+-------------+--------------+
| userid | password | company | phone | email |
+------------+----------+---------+-------------+--------------+
| 111 | 111 | 111 | 111 | 111 |
| 112 | 000 | 111 | 000 | 000 |
| aa | 111 | 11 | 11 | 11 |
| test_1 | 00 | NULL | NULL | NULL |
| user_test2 | 0000 | NULL | NULL | NULL |
| user1 | 0000 | zstu | 13777860000 | 7746@qq.com |
| user2 | 0000 | zstu | 13777860001 | 7747@qq.com |
| user3 | 0000 | zstu | 13777860002 | 7748@qq.com |
| 232222 | 0000 | 城站 | 12306 | 12306@qq.com |
+------------+----------+---------+-------------+--------------+
9 rows in set (0.00 sec)
作者:@臭咸鱼
转载请注明出处:https://www.cnblogs.com/chouxianyu/
欢迎讨论和交流!
一次作业过程及其问题的记录:mysql建立数据库、建表、查询和插入等的更多相关文章
- 百万年薪python之路 -- MySQL数据库之 MySQL行(记录)的操作(二) -- 多表查询
MySQL行(记录)的操作(二) -- 多表查询 数据的准备 #建表 create table department( id int, name varchar(20) ); create table ...
- mysql 数据操作 单表查询 limit 限制查询的记录数
mysql; +----+-----------+------+-----+------------+---------+--------------+------------+--------+-- ...
- 统计mysql某个数据库的表数量以及表记录数
统计MySQL中某个数据库中有多少张表 SELECT count(*) TABLES, table_schema FROM information_schema.TABLES where ...
- MySQL数据库 | 数据表-查询命令详细记录
本篇专门记录数据库增删改查中最常用.花招最多的 查. [文章结构] 一.数据的准备 二.基本的查询功能 三.条件查询 四.查询排序 五.聚合函数 六.分组查询 七.分页查询 八.连接查询 九.子查询 ...
- mysql 一个典型的数据库建表建用户过程
cmd 命令不接 ";" mysql 命令后接 ";" 1.以管理员身份登录mysql mysql -u root –p 2.选择mysql数据库 use my ...
- mysql/mariadb学习记录——创建删除数据库、表的基本命令
查看已有的数据库: mysql> show databases; +--------------------+ | Database | +--------------------+ | inf ...
- Kettle 实现mysql数据库不同表之间数据同步——实验过程
下面是试验的主要步骤: 在上一篇文章中LZ已经介绍了,实验的环境和实验目的. 在本篇文章中主要介绍侧重于对Kettle ETL的相应使用方法, 在这里LZ需要说明一下,LZ成为了避免涉及索引和表连接等 ...
- 64位 SQL Server2008链接访问Oracle 过程汇总解决方法记录
64位 SQL Server2008链接访问Oracle 过程汇总解决方法记录 经过几天不停的网上找资料,实验,终于联通了. 环境:系统:win 2008 ,SqlServer2008 R2, 连接O ...
- 关于HTML中,绝对定位,相对定位的理解...(学习HTML过程中的小记录)
关于HTML中,绝对定位,相对定位的理解...(学习HTML过程中的小记录) 作者:王可利(Star·星星) HTML中 相对定位:position:relative; 绝对定位:position ...
随机推荐
- 7-12 产生每位数字相同的n位数 (30 分)
读入2个正整数A和B,1<=A<=9, 1<=B<=10,产生数字AA...A,一共B个A 输入格式: 在一行中输入A和B. 输出格式: 在一行中输出整数AA...A,一共B个 ...
- 一起了解 .Net Foundation 项目 No.14
.Net 基金会中包含有很多优秀的项目,今天就和笔者一起了解一下其中的一些优秀作品吧. 中文介绍 中文介绍内容翻译自英文介绍,主要采用意译.如与原文存在出入,请以原文为准. .NET Core .NE ...
- vue的子组件不能进行router的切换
在用vue开发过程中,偶然一次使用在子组件中进行router的切换,发现不起作用,后来才反应过来,子组件只是一个组件,vue的路由的切换只能是在父组件(也就是真正的页面)里面进行跳转!
- 看完这篇 HTTPS,和面试官扯皮就没问题了
下面我们来一起学习一下 HTTPS ,首先问你一个问题,为什么有了 HTTP 之后,还需要有 HTTPS ?我突然有个想法,为什么我们面试的时候需要回答标准答案呢?为什么我们不说出我们自己的想法和见解 ...
- Effective Go中文版(更新中)
原文链接:https://golang.org/doc/effective_go.html Introduction Go是一种新兴的编程语言.虽然它借鉴了现有语言的思想,但它具有不同寻常的特性,使得 ...
- 【GTS-Fail】GtsSecurityHostTestCases#testNoExemptionsForSocketsBetweenCoreAndVendorBan
[GTS-Fail]GtsSecurityHostTestCases#testNoExemptionsForSocketsBetweenCoreAndVendorBan [问题描述] Gts-7.0- ...
- h5 移动端适配方案思考
基础概念 CSS像素(CSS pixels) 这个是浏览器使用的抽象单位,用来精确度量网页上的内容.平时经常写的width:100px;height:100px;都是与设备无关的. 设备独立像素(de ...
- 原生ajax动态添加数据
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- Codeforces Round #200 (Div. 2)E
Read Time 题意:有一个数组,很多指针指在这个数组上,每次每个指针可以向左或向右移动一个位置.给出一些需要访问的位置,问访问用的最少时间. 一个指针只可能转一次方向.二分答案. #includ ...
- sql 语句系列(多表之链)[八百章之第三章]
新增连接查询而不影响其他连接查询 请看图: 这种情况我们一般会使用左连接的方式. select e.ENAME,d.LOC,eb.RECEIVED from emp e join dept d on( ...