mysql 常用总结[增删改查]

  1. 建库
create database;
  1. 建表
create table tablename(字段 类型...)CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
# 实例
create table if not exists first_url_Season(type varchar(15) not null,first_url varchar(200),page smallint not null,url_status tinyint(1) default 0,time varchar(10))CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

#cookies:
#自增长字段:
id int primary key auto_increment,
# 表格符号类型定义
CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
# 时间字段,有多个类型,写入是可用函数记录写入   now(),curdate()

# byte 字段,可以存入json字段
data blob(1024),

# 增加 约束
# 增加  表格  first_url_Season  type first_url 字段 同时唯一约束,约束的名字为lim_first_url
alter table first_url_Season add constraint lim_first_url unique (type,first_url,time)

# 删除某个字段的约束
alter table tableNAME drop index 字段名

# 增加字段
alter table tableNAME add 字段名 字段描述;

# 删除字段
alter table tableNAME drop 字段名;
  1. 写入数据
insert into last_good_msg_Season values(写入的数据...)
#还有其他方法;
  1. 修改数据
# 实例
#          |-----------条件--------------|   |-------修改-----|
# 更新 字段 页数为10   type 为sales  的数据  rank 字段 修改为 55
update second_url_Season set rank=55 where page=10 and type='sales;
# 多个字段修改(用逗号区分开来)
update second_url_Season set rank=55,price=11200 where page=10 and type='sales;
  • 问题总结

  • 字符集已经是utf8mb4,插入表情符号依然报错
    分为三个层级,数据库级,表级,还有列级,查看子字符集类型

# 查看创建表的语句
show create table table_name;
# 查看表字段的语句
show full columns from table_name;
相关修改语句:
alter table table_name modify column_name varchar(100) charset utf8mb4;

以上情况确认,却依然报错,解决办法:
在插入数据前:set names utf8mb4;
再插入数据:

#允许远程访问问题

use mysql; # 选择mysql这个库
# *.*.*.*为指定的ip地址,pwd是访问密码
# 意思就是允许*.*.*.*这个ip以pwd为登录密码远程访问
# 如果要设置所有ip允许访问,将*.*.*.*替换成%,注意要!!!保留单引号''
# 如果出错,请注意不要使用双引号,请用单引号单引号 
GRANT ALL PRIVILEGES ON *.* TO 'root'@'*.*.*.*' IDENTIFIED BY pwd WITH GRANT OPTION;  
# 更新设置
flush privileges;

#多表联查

#  table: t1(id,name,age)  t2(id,t1_id,score,math)
# 联查 t1 t2 除id 的所有有效字段
select t1.name,t1.age,t2.score,t2.math from t1,t2 where t1.id=t2.t1_id;

  1. 单双引号同时存在str中,报错问题
	str_msg='this is "author"'
	insert_sql = "insert into t1 values(0,'%s')"%str_msg
	# 此中情况会报错,处理方法如下
	用pymysql自带的方法处理
	str_msg = pymysql.escape_string(msg_str)
	# 再写入即可
	
  1. 写入列表,cookies等等
	# item 为写入内容
	import json
	item = json.dumps(item)
	# 再插入 blob字段即可
	# 该字段文章顶部可参考/
	
  1. 查询--关于日期的函数
    # 筛选time列中,时间问今天的数据			[准确到天数]
	select id from sku_list where time=curdate();
	# 筛选time列中,时间问当前时刻的数据  [now()准确至秒]
	select id from sku_list where time=now();

更多相关函数请参考mysql日期函数

解决!
参考文章:http://www.thinkphp.cn/topic/54211.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL常用增删改查操作包括插入数据、删除数据、更新数据和查询数据。 1. 插入数据:使用INSERT INTO语句将数据插入到表中。例如,要向student表中插入一条记录,可以使用以下语句: INSERT INTO student (name, age, class_id) VALUES ('John', 20, 1); 2. 删除数据:使用DELETE FROM语句删除表中的数据。可以使用WHERE子句指定删除的条件。例如,要删除student表中id为1的记录,可以使用以下语句: DELETE FROM student WHERE id = 1; 3. 更新数据:使用UPDATE语句更新表中的数据。可以使用SET子句指定要更新的列和新的值,使用WHERE子句指定更新的条件。例如,要将student表中id为1的记录的age字段更新为25,可以使用以下语句: UPDATE student SET age = 25 WHERE id = 1; 4. 查询数据:使用SELECT语句从表中查询数据。可以使用WHERE子句指定查询的条件,使用ORDER BY子句指定查询结果的排序方式。例如,要查询student表中age大于等于18的记录,并按照age字段降序排序,可以使用以下语句: SELECT * FROM student WHERE age >= 18 ORDER BY age DESC; 以上是MySQL常用增删改查操作的基本语法和示例。根据具体的需求和表结构,可以灵活运用这些语句进行数据操作。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* *3* [mysql常用增删改查命令总结](https://blog.csdn.net/weixin_42636632/article/details/107943630)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Mysql基础增删改查语句](https://blog.csdn.net/weixin_53818758/article/details/126047089)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值