会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132422个问题
JAVA 全系列/第二阶段:JAVA 基础深化和提高/容器(旧) 32686楼

from sqlalchemy.ext.declarative import declarative_base
# 导入常见数据类型
from sqlalchemy import create_engine,Column,Integer,String,Float,DECIMAL,Boolean,\
    Date,DateTime,Time,Text,Enum
from sqlalchemy.dialects.mysql import LONGTEXT

from sqlalchemy.orm import sessionmaker

from sqlalchemy import func,and_,or_,ForeignKey

HOSTNAME = '127.0.0.1'
PORT = '3306'
DATABASE = 'first_sqlalchemy'
USERNAME = 'root'
PASSWORD = '123456'

DB_URI ="mysql+pymysql://{username}:{password}@{host}:{port}/{db}?charset=utf8".format(username=USERNAME,password=PASSWORD,host=HOSTNAME,port=PORT,db=DATABASE)

engine = create_engine(DB_URI)

session = sessionmaker(engine)()
# 1.用`declarative_base`根据`engine`创建一个ORM基类
Base = declarative_base(engine)

# 需求:sqlalchemy中query查询函数可以传递的参数有哪些(3中方式)
'''
1. 模型名。指定查找这个模型中所有的属性(对应查询表为全表查询)。
2. 模型中的属性。可以指定只查找某个模型的其中几个属性。
3. 聚合函数。
    * func.count:统计行的数量。
    * func.avg:求平均值。
    * func.max:求最大值。
    * func.min:求最小值。
    * func.sum:求和。
    `func`上,其实没有任何聚合函数。但是因为他底层做了一些魔术,
    只要mysql中有的聚合函数,都可以通过func调用
'''

# class News(Base):
#     __tablename__='news'
#     id = Column(Integer,primary_key=True,autoincrement=True)
#     title =Column(String(50),nullable=False)
#     price = Column(Integer)
#     content = Column(Text)
#
#     def  __repr__(self):
#         return  "<title:%s,price:%s,content:%s>"%(self.title,self.price,self.content)
# Base.metadata.drop_all()
# Base.metadata.create_all()

# 添加测试数据
# for x in range(1,6):
#     a = News(title="新闻%s"%x,price =random.randint(1,100))
#     session.add(a)
# session.commit()

# 需求:SQLALchemy实现外键及其四种约束讲解

# 主表 / 从表
# user/news
class User(Base):
    __tablename__ = 'user'
    id = Column(Integer,primary_key=True,autoincrement=True)
    uname = Column(String(50),nullable=False)

    def __repr__(self):
        return "<User(uname:%s)>" % self.uname

class News(Base):
    __tablename__ = 'news'
    id = Column(Integer,primary_key=True,autoincrement=True)
    title = Column(String(50),nullable=False)
    content = Column(Text,nullable=False)
    # sqlalchemy实现外键方法:四种约束
    # RESTRICT
    # uid = Column(Integer,ForeignKey("user.id",ondelete='RESTRICT'))
    # NO ACTION
    uid = Column(Integer,ForeignKey("user.id",ondelete='NO ACTION'))
    # NO ACTION
    # uid = Column(Integer, ForeignKey("user.id", ondelete='CASCADE'))
    # NO ACTION
    # uid = Column(Integer, ForeignKey("user.id", ondelete='SET NULL'))

    def __repr__(self):
        return "<News(title:%s,content=%s)>" % (self.title,self.content)

# 创建表
Base.metadata.drop_all()
Base.metadata.create_all()

# 添加测试数据
user = User(uname='momo')
session.add(user)
session.commit()
#
news1= News(title='AAA',content='123',uid=1)
news2= News(title='BBB',content='456',uid=1)
session.add_all([news1,news2])
session.commit()


image.png



image.png

老师,我的代码,好像外键添加不上去,运行sql语句,直接删除了user表中内容。


Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask数据库 32687楼
JAVA 全系列/第八阶段:Linux入门到实战/Maven 32688楼
Python 全系列/第十五阶段:Python 爬虫开发/爬虫基础(旧) 32690楼
Python 全系列/第一阶段:Python入门/控制语句 32692楼

老师,我也是按照您的代码写的,但是运行的时候每次只能一个进程运行,就是只能A窗口卖票或者只能B窗口卖票,我运行了好几次,不能ABC窗口同时卖票

image.png

/**
 * 同步监视器只能是对象,推荐使用共享资源的对象,可以是当前对象this,也可以是其他的对象
 */
public class Ticket2 implements Runnable {
    private int ticket=5;
    @Override
    public void run() {
        for (int i = 0; i <100 ; i++) {
            //调用同步方法
            this.saleTicket();
        }
    }
    //同步方法实现
    private synchronized void saleTicket(){  //无需指定同步监视器,同步监视器只能是当前对象
        if (ticket>0){
            try {
                Thread.sleep(300);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            System.out.println(Thread.currentThread().getName()+"正在卖第"+(ticket--)+"票");
        }
    }
}
public class TestTicket {
    public static void main(String[] args) {
        Ticket2 t = new Ticket2();
        Thread t1 = new Thread(t,"A窗口");
        Thread t2 = new Thread(t,"B窗口");
        Thread t3 = new Thread(t,"C窗口");

        //启动线程
        t1.start();
        t2.start();
        t3.start();
    }
}

image.png

JAVA 全系列/第二阶段:JAVA 基础深化和提高/多线程技术(旧) 32693楼
Python 全系列/第三阶段:Python 网络与并发编程/并发编程 32694楼
Python 全系列/下架-第十二阶段:Python_大型电商项目(5天后下架)/Django项目阶段-电商项目(旧) 32697楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637