MySql增删改查语句以及python数据库操作

增删改查语句
增删改查的语句命令为

增:insert
删:delete
改:update
查:SELECT或者show

库操作
创建数据库:create database shujukuba;
创建带字符集的数据库:create database mydb2 CHARACTER SET=utf8;
创建带校验的数据库:create database mydb3 CHARACTER SET=utf8 COLLATE utf8_general_ci;
显示数据库:show databases;
删除数据库:DROP DATABASE shujukuba;
修改数据库编码:ALTER DATABASE shujukuba character set gb2312;

表操作
创建数据库表(创建一个表名为:employee,该表中含有id、name、sex、birthday、job字段):

create table employee
(
    id int,
    name varchar(40),
    sex  char(4),
    birthday date,
    job  varchar(100),
);

表中增加image字段:alter table employee add image blob;

修改job值,使其长度为60(原长度为1000):alter table employee modify job varchar(60);

删除sex列:alter table employee drop sex;

表名改为user(原名employee):rename table employee to user;

修改表的字符集为utf-8:alter table user character set utf8;

列name修改为username:alter table user change column name username varchar(100);

删除表:drop table user;

增删改查实例
准备表
新建表employee:

create table employee
(
id int,
name varchar(40),
sex varchar(4),
birthday date,
entry_date date,
salary decimal(8,2),
resume text
);

插入表数据
插入数据:


insert into employee(id,name,sex,birthday,entry_date,salary,resume) values(1,'zhangsan','male','1993-03-04','2016-11-10','1000','i am a developer');

指定某些列插入数据:insert into employee(id) values(6);
插入汉字:insert into employee(id,name) values(6,‘张三’);

修改表数据:
将所有员工薪水修改为5000元:update employee set salary=5000;

将姓名为’zs’的员工薪水修改为3000元:update employee set salary = 3000 where name=‘zhangsan’;

将姓名为’aaa’的员工薪水修改为4000元,job改为ccc:update employee set salary = 4000,job=‘ccc’ where name=‘张三’;

将wu的薪水在原有基础上增加1000元:update employee set salary = salary+1000 where name=‘张三’;

删除表数据
删除表中名称为“zs”的记录:delete from employee where job=‘ccc’;
删除表中所有记录:delete from employee;
使用truncate删除表中记录:truncate table employee;

查询表数据
查询表中所有学生的信息:select id,name,chinese,english,math from student;
查询表中所有学生的姓名和对应的英语成绩:select name,english from student;
查询姓名为wu的学生成绩:select * from student where name=‘张三’;
查询英语成绩大于90分的同学:select * from student where english>‘90’;
查询英语分数在 80-90之间的同学:select * from student where english>=80 and english=<90;

常见的MySQL语句命令
进入mysql 命令行:mysql -uroot -p;
查看所有数据库:show databases;
创建数据库:create database niu charset utf8;
删除数据库:drop database niu;
选择数据库:use databases;
查看所有表:show tables;
查看创建数据库的语句:show create database databasename;
查看创建表的语句:show create table tablename;
查看表结构:desc tablenmae;

常见MySQL字段含义
自增长:auto_increment
非空:not null
默认值:default
唯一:unique
指定字符集:charset
主键:primary key

#基本代码的实现
# conding=utf-8
import pymysql
# 连接数据库 并添加cursor游标
conn = pymysql.connect('localhost','root','0000','myapp')
cursor = conn.cursor()
#  创建数据表的sql 语句  并设置name_id 为主键自增长不为空
sql_createTb = """CREATE TABLE MONEY (
                 name_id INT NOT NULL AUTO_INCREMENT,
                 LAST_NAME  CHAR(20),
                 AGE INT,
                 SEX CHAR(1),
                 PRIMARY KEY(name_id))
                 """
# 插入一条数据到moneytb 里面。
sql_insert = "insert into money(LAST_NAME,AGE,SEX) values('de2',18,'0')"

# 在 execute里面执行SQL语句
cursor.execute(sql_createTb)
cursor.execute(sql_insert)
print(cursor.rowcount)
conn.commit()

conn.close()
cursor.close()

详细的增删改查操作:

import pymysql

# 连接数据库
conn = pymysql.connect(
    host='localhost',
    port=3306,
    user='root',
    passwd='888999',
    db='myapp',
    charset='utf8'
)
# 获取游标
cursor = conn.cursor()

# 使用 execute()  方法执行 SQL 的增删改查 insert delete update select
sql_select = "select * from user"
sql_insert = "insert into user(id,name,age) values(8,'pythonN8','18')"
sql_update = "update user set name='helloPy' where id=7"
sql_delete = "delete from user where d=7"

# 执行 insert 增加的语句  如果出现异常对异常处理
try:
    cursor.execute(sql_insert)
    print(cursor.rowcount)
    cursor.execute(sql_update)
    print(cursor.rowcount)
    cursor.execute(sql_delete)
    print(cursor.rowcount)

    conn.commit()
except Exception as e:
    print(e)
    conn.rollback()



# res = cursor.fetchmany(2)
# print(res)

# res = cursor.fetchall()
# print(res)

cursor.close()
conn.close()



转载自:感谢博客们的资源共享!
https://blog.csdn.net/well2049/article/details/79052233
https://www.shujukuba.com/mysql/99.html

C# VS2012 86系统 mysql-5.5.27-win32 功能:利用动软代码生成器 从 数据库表或者视图中生成 的三层结构代码 实现 数据增删改查。 如果可以,请下载资源中 修改 的动软代码生成器 C#模板生成 1、由于之前使用 动软生成 java 网页源码,比较成功,此处编写C#程序时沿用,感觉更加适合。 2、直接调用动软的相关dll和生成的三层代码,可以较快的实现增删改查操作。 3、由于一些dll版本的问题及动软生成器自身的一些不完善,产生了一些问题并查找了挺久,所以把可以实现的版本发布出来共享。 前提: 使用的是 mysql数据库时才可能会出现以下问题 问题: 1、MySql.Data.dll 必须是5.6.1以上版本,否则会出现 “向信号量添加给定计数将导致其超出它的最大计数” 的问题。 2、动软代码生成时,必须增加该命名空间 using MySql.Data.MySqlClient; 3、动软代码必须修改 “工具”-“选项”弹出窗 后,点击 ”代码生成设置“-”字段类型映射“-”参数符号“中删除 mysql @,添加mysql ? 4、如果不修改3的设置,在增删改时 参数设置会失败。 5、mysql保存或者修改时,中文会出现乱码,这时必须 在DbHelperMySQL类的 连接字中增加Charset=utf8;即 protected static string connectionString = "Server=localhost;User Id=root;Password=root;Persist Security Info=True;Database=mnzfz;Charset=utf8;"; 6、如果要在局域网中远程访问,请 修改 mysql 权限:grant select,update,insert,delete on *.* to 'root'@'192.168.0.1' identified by "123456";
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值