orm使用

这篇博客探讨了Go语言中ORM的使用,涉及用户结构体与订单结构体的一对多和多对一关系。内容包括创建ORM对象来插入、删除、查询和更新用户,以及插入和查询订单的操作。
摘要由CSDN通过智能技术生成

用户结构体,和订单是一对多的关系

type User struct {
	Id int //beego中默认Id为主键,且自增长
	Name string //姓名
	Age int //年龄
	Nickname string  //昵称
	Userorders []*Userorder `orm:"reverse(many)"`
}

订单结构体,和用户是多对多一的关系

type Userorder struct {
	Id int
	Orderdata string
	User *User `orm:"rel(fk)"`
	Products []*Product `orm:"rel(m2m)"`//ManyToMany
}

创建orm对象,插入用户:

func (this *InsertUserController) Get() {
	this.TplName = "insertuser.html"
}
func (this *InsertUserController) Post() {
	name := this.GetString("name")
	age, err := this.GetInt("age")
	if err != nil {
		this.Ctx.WriteString("插入失败!")
	}
	nickname := this.GetString("nickname")
	user := models.User{Name:name, Age:age, Nickname:nickname}
	orm := orm.NewOrm()
	//INSERT INTO USER (NAME, age, nickname)  VALUE('Alice', 24, 'bb')
	n, err := orm.Insert(&user)
	if err == nil && n > 0 {
		this.Ctx.WriteString("插入成功!")
	}else {
		this.Ctx.WriteString("插入失败!")
	}
}

insertuser.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>插入用户</title>
</head>
<body>
    <form action="/insertuser" method="post">
        <table>
            <thead>插入用户</thead>
            <tbody>
                <tr>
                    <td>姓名:</td>
                    <td>
                        <input id="name" name="name
Spring ORM 是 Spring 框架的一个模块,它提供了一种方便的方式来集成 ORM 框架,如 Hibernate、JPA 等,以便于在 Spring 应用中使用 ORM 技术。下面是 Spring ORM使用教程: 1. 添加依赖 在 Maven 或 Gradle 中添加 Spring ORM 依赖: Maven: ```xml <dependency> <groupId>org.springframework</groupId> <artifactId>spring-orm</artifactId> <version>5.3.8</version> </dependency> ``` Gradle: ```groovy implementation 'org.springframework:spring-orm:5.3.8' ``` 2. 配置数据源 在 Spring 应用中使用 ORM 技术,需要先配置数据源。可以使用 Spring 提供的 DriverManagerDataSource 或者使用连接池技术,如 C3P0。 例如,配置 DriverManagerDataSource: ```xml <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <property name="driverClassName" value="com.mysql.jdbc.Driver" /> <property name="url" value="jdbc:mysql://localhost:3306/test" /> <property name="username" value="root" /> <property name="password" value="123456" /> </bean> ``` 3. 配置 ORM 框架 Spring ORM 提供了对多种 ORM 框架的集成支持,如 Hibernate、JPA 等。在使用之前,需要先配置相应的 ORM 框架。 例如,配置 Hibernate: ```xml <bean id="sessionFactory" class="org.springframework.orm.hibernate5.LocalSessionFactoryBean"> <property name="dataSource" ref="dataSource" /> <property name="packagesToScan" value="com.example.entity" /> <property name="hibernateProperties"> <props> <prop key="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</prop> <prop key="hibernate.show_sql">true</prop> </props> </property> </bean> ``` 4. 配置事务管理器 Spring ORM 还提供了事务管理器,通过它可以方便地管理事务。在 Spring 应用中使用 ORM 技术,需要先配置事务管理器。 例如,配置 Hibernate 的事务管理器: ```xml <bean id="transactionManager" class="org.springframework.orm.hibernate5.HibernateTransactionManager"> <property name="sessionFactory" ref="sessionFactory" /> </bean> ``` 5. 配置 DAO 层 DAO 层是 ORM 框架和业务逻辑层之间的桥梁。在 Spring 应用中使用 ORM 技术,需要先配置 DAO 层。 例如,配置 Hibernate 的 DAO 层: ```java @Repository public class UserDaoImpl extends HibernateDaoSupport implements UserDao { public User findUserById(int id) { return getHibernateTemplate().get(User.class, id); } public void saveUser(User user) { getHibernateTemplate().save(user); } public void updateUser(User user) { getHibernateTemplate().update(user); } public void deleteUser(User user) { getHibernateTemplate().delete(user); } } ``` 6. 使用 ORM 技术 配置完成后,就可以在业务逻辑层中使用 ORM 技术了。 例如,使用 Hibernate: ```java @Service @Transactional public class UserServiceImpl implements UserService { @Autowired private UserDao userDao; public User findUserById(int id) { return userDao.findUserById(id); } public void saveUser(User user) { userDao.saveUser(user); } public void updateUser(User user) { userDao.updateUser(user); } public void deleteUser(User user) { userDao.deleteUser(user); } } ``` 以上就是 Spring ORM使用教程,希望能对你有所帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

尹成

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值