mysql 不能新建integer字段
时间: 2023-08-24 09:11:46 浏览: 93
MySQL是支持创建整数类型字段的。你可以使用以下语法来创建一个整数类型的字段:
```
CREATE TABLE table_name (
column_name INT
);
```
在这个例子中,我们创建了一个名为 `table_name` 的表,并在其中创建了一个名为 `column_name` 的整数类型的字段。
如果你遇到了无法创建整数类型字段的问题,可能是你的语法有误或者你正在使用不支持的MySQL版本。请检查你的语法,并确保你的MySQL版本支持整数类型字段。
相关问题
python sqlalchemy 新建MySQL表
好的,我会尽力回答您的问题。对于您的问题,我可以提供以下代码作为参考:
```python
from sqlalchemy import create_engine, Column, Integer, String
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker
# 创建连接
engine = create_engine('mysql+pymysql://username:password@host:port/database')
Base = declarative_base()
# 定义表结构
class User(Base):
__tablename__ = 'users'
id = Column(Integer, primary_key=True)
name = Column(String(50))
age = Column(Integer)
email = Column(String(120))
# 创建所有表
Base.metadata.create_all(engine)
# 创建一个会话
Session = sessionmaker(bind=engine)
session = Session()
# 添加一个用户
user = User(name='Tom', age=25, email='tom@example.com')
session.add(user)
session.commit()
# 查询所有用户
users = session.query(User).all()
for user in users:
print(user.name, user.age, user.email)
```
以上代码假设您已经安装了 SQLAlchemy 和 PyMySQL,同时您需要替换代码中的数据库连接信息、表名和字段名,以及添加您需要的字段类型和验证规则。如果还有其他问题,请随时与我交流。
新建数据库 UserDB,新建表 user,表结构如下: user 表 字段名称 字段类型 备注 id Int 用户编号(主键、自增) username Varchar(20) 用户名称 password Varchar(20) 用户密码通过 JDBC连接数据库,编写 userlist.jsp,显示所有用户信息编写 addUser.jsp,实现用户信息的添加功能,在 UserController.java这个 Servlet中实现用户信息的删除功能编写 userUpdate.jsp,实现用户信息的更新功能。
以下是实现上述要求的代码示例:
#### 1. 创建 UserDB 数据库和 user 表
```sql
CREATE DATABASE UserDB;
USE UserDB;
CREATE TABLE user (
id INT PRIMARY KEY AUTO_INCREMENT,
username VARCHAR(20),
password VARCHAR(20)
);
```
#### 2. 编写 userlist.jsp 显示所有用户信息
```jsp
<%@ page import="java.sql.*" %>
<%@ page language="java" %>
<%@ page contentType="text/html; charset=UTF-8" %>
<html>
<head>
<title>User List</title>
</head>
<body>
<h1>User List</h1>
<%
String url = "jdbc:mysql://localhost:3306/UserDB";
String user = "root";
String password = "password";
Connection conn = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
try {
Class.forName("com.mysql.jdbc.Driver");
conn = DriverManager.getConnection(url, user, password);
String sql = "SELECT * FROM user";
pstmt = conn.prepareStatement(sql);
rs = pstmt.executeQuery();
%>
<table border="1">
<tr>
<th>ID</th>
<th>Username</th>
<th>Password</th>
</tr>
<% while (rs.next()) { %>
<tr>
<td><%= rs.getInt("id") %></td>
<td><%= rs.getString("username") %></td>
<td><%= rs.getString("password") %></td>
</tr>
<% } %>
</table>
<%
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
if (rs != null) rs.close();
if (pstmt != null) pstmt.close();
if (conn != null) conn.close();
} catch (Exception e) {
e.printStackTrace();
}
}
%>
</body>
</html>
```
#### 3. 编写 addUser.jsp 实现用户信息的添加功能
```jsp
<%@ page import="java.sql.*" %>
<%@ page language="java" %>
<%@ page contentType="text/html; charset=UTF-8" %>
<html>
<head>
<title>Add User</title>
</head>
<body>
<h1>Add User</h1>
<form method="post" action="UserController">
<label for="username">Username:</label>
<input type="text" id="username" name="username" required><br>
<label for="password">Password:</label>
<input type="password" id="password" name="password" required><br>
<button type="submit">Add User</button>
</form>
</body>
</html>
```
#### 4. 在 UserController.java 这个 Servlet 中实现用户信息的删除功能
```java
import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class UserController extends HttpServlet {
private static final long serialVersionUID = 1L;
protected void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String action = request.getParameter("action");
if (action == null) {
// do nothing
} else if (action.equals("add")) {
String username = request.getParameter("username");
String password = request.getParameter("password");
String url = "jdbc:mysql://localhost:3306/UserDB";
String user = "root";
String pass = "password";
try {
Class.forName("com.mysql.jdbc.Driver");
Connection conn = DriverManager.getConnection(url, user, pass);
String sql = "INSERT INTO user (username, password) VALUES (?, ?)";
PreparedStatement pstmt = conn.prepareStatement(sql);
pstmt.setString(1, username);
pstmt.setString(2, password);
pstmt.executeUpdate();
pstmt.close();
conn.close();
response.sendRedirect("userlist.jsp");
} catch (Exception e) {
e.printStackTrace();
}
} else if (action.equals("delete")) {
int id = Integer.parseInt(request.getParameter("id"));
String url = "jdbc:mysql://localhost:3306/UserDB";
String user = "root";
String pass = "password";
try {
Class.forName("com.mysql.jdbc.Driver");
Connection conn = DriverManager.getConnection(url, user, pass);
String sql = "DELETE FROM user WHERE id=?";
PreparedStatement pstmt = conn.prepareStatement(sql);
pstmt.setInt(1, id);
pstmt.executeUpdate();
pstmt.close();
conn.close();
response.sendRedirect("userlist.jsp");
} catch (Exception e) {
e.printStackTrace();
}
}
}
}
```
#### 5. 编写 userUpdate.jsp 实现用户信息的更新功能
```jsp
<%@ page import="java.sql.*" %>
<%@ page language="java" %>
<%@ page contentType="text/html; charset=UTF-8" %>
<html>
<head>
<title>Update User</title>
</head>
<body>
<h1>Update User</h1>
<%
int id = Integer.parseInt(request.getParameter("id"));
String url = "jdbc:mysql://localhost:3306/UserDB";
String user = "root";
String password = "password";
Connection conn = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
try {
Class.forName("com.mysql.jdbc.Driver");
conn = DriverManager.getConnection(url, user, password);
String sql = "SELECT * FROM user WHERE id=?";
pstmt = conn.prepareStatement(sql);
pstmt.setInt(1, id);
rs = pstmt.executeQuery();
rs.next();
%>
<form method="post" action="UserController">
<input type="hidden" name="action" value="update">
<input type="hidden" name="id" value="<%= id %>">
<label for="username">Username:</label>
<input type="text" id="username" name="username" value="<%= rs.getString("username") %>" required><br>
<label for="password">Password:</label>
<input type="password" id="password" name="password" value="<%= rs.getString("password") %>" required><br>
<button type="submit">Update User</button>
</form>
<%
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
if (rs != null) rs.close();
if (pstmt != null) pstmt.close();
if (conn != null) conn.close();
} catch (Exception e) {
e.printStackTrace();
}
}
%>
</body>
</html>
```
以上就是实现用户信息增删改查的完整代码示例。注意在 web.xml 中配置 Servlet 映射。
阅读全文