先引用命名空间:
using SystemDataSqlClient;
然后在按钮的单击事件里写代码:
string sql="insert 表名 (name,account,password) values(@name,@account,@password) ";
string name=txtNameText;//姓名
string account=txtAccountText;//账号
string password=txtPassWordText;//密码
SqlParameter sName= new SqlParameter("@name", name);
SqlParameter sAccount= new SqlParameter("@account", account);
SqlParameter sPassword= new SqlParameter("@password", password);
string connString="Data Source=服务器名称;Initial Catalog=数据库名称;User ID=数据库登录名;Password=数据库登录密码";
SqlConnection connection = new SqlConnection(connString);
SqlCommand cmd = new SqlCommand(sql, connection);
connectionOpen();
int result = cmdExecuteNonQuery();
connectionClose();
cmdParametersClear();
if(result>0)
{
MessageBoxShow("插入数据库成功");
}
else
{
MessageBoxShow("插入失败,请稍候再试");
}
以下代码是SQL SERVER的,你两个表的名字好像用反了,而且登录表中最好还有一个登录时间
CREATE TABLE [dbo][UserRegister](
[ID] [int] IDENTITY(1,1) NOT NULL,
[UserName] [nvarchar](20) NULL,
[UserPwd] [varchar](50) NULL,
[Pwdquestion] [nvarchar](50) NULL,
[Solution] [nvarchar](50) NULL,
[Sex] [int] NULL,
[Email] [varchar](50) NULL,
[Add] [nvarchar](50) NULL,
[TrueName] [varchar](50) NULL,
[PostCode] [varchar](50) NULL,
[Telephone] [varchar](50) NULL,
CONSTRAINT [PK_UserLogin] PRIMARY KEY CLUSTERED
(
[ID] ASC
)ON [PRIMARY],
CONSTRAINT [IX_UserRegister] UNIQUE NONCLUSTERED
(
[UserName] ASC
) ON [PRIMARY]
) ON [PRIMARY]
CREATE TABLE [dbo][UserLogin](
[ID] [int] IDENTITY(1,1) NOT NULL,
[UserName] [nvarchar](20) NULL,
[UserPwd] [varchar](20) NULL,
[LoginTime] [datetime] NULL,
CONSTRAINT [PK_UserRegister] PRIMARY KEY CLUSTERED
(
[ID] ASC
) ON [PRIMARY]
) ON [PRIMARY]
ALTER TABLE [dbo][UserLogin] WITH CHECK ADD CONSTRAINT [FK_UserLogin_UserRegister] FOREIGN KEY([UserName])
REFERENCES [dbo][UserRegister] ([UserName])
GO
ALTER TABLE [dbo][UserLogin] CHECK CONSTRAINT [FK_UserLogin_UserRegister]
GO
你的问题没有问明确啊
如果你是在编写vb程序的时候新建数据库的话,那么:
1代码新建空数据库
2代码新建一个数据表如“成绩单”,并设置其中姓名为主键,则SQL代码如下:
CREATE TABLE [成绩单]([姓名] int identity primary key '这里“姓名”被设置为主键。
如果你是直接打开数据库设置主键的话,那么:
你用“使用设计器创建表”完毕,在要设置为主键的名称(如姓名)左侧右键单击后出来的菜单内有“主键”二字,点击“主键”即可完成,如下图所示:
数据库主键
主键:表中经常有一个列或多列的组合,其值能唯一地标识表中的每一行。这样的一列或多列称为表的主键,通过它可强制表的实体完整性。当创建或更改表时可通过定义 PRIMARY KEY 约束来创建主键。一个表只能有一个 PRIMARY KEY 约束,而且 PRIMARY KEY 约束中的列不能接受空值。由于 PRIMARY KEY 约束确保唯一数据,所以经常用来定义标识列。
作用:
1)保证实体的完整性;
2)加快数据库的 *** 作速度
3) 在表中添加新记录时,ACCESS会自动检查新记录的主键值,不允许该值与其他记录的主键值重复。
4) ACCESS自动按主键值的顺序显示表中的记录。如果没有定义主键,则按输入记录的顺序显示表中的记录。
在有些数据库中,虽然主键不是必需的,但最好为每个表都设置一个主键,不管是单主键还是复合主键。它存在代表着表结构的完整性,表的记录必须得有唯一区分的字段,主键主要是用于其他表的外键关联,以及本记录的修改与删除。
主键的无意义性
在开发过程中,读者可能会看到将一些表使用有意义的字段表示主键,例如“用户登录信息表”将“登录名”(英文名)作为主键,“订单表”中将“订单编号”作为主键,如此设计主键一般都是没什么问题,因为将这些主键基本不具有“意义更改”的可能性。但是,也有一些例外的情况,例如“订单表”需要支持需求“订单可以作废,并重新生成订单,而且订单号要保持原订单号一致”,那将“订单编号”作为主键就满足不了要求了。因此读者在使用具有实际意义的字段作为主键时,需要考虑是否存在这种可能性。
主键的选择
①编号作主键
此方法就是采用实际业务中的唯一字段的“编号”作为主键设计,这在小型的项目中是推荐这样做的,因为这可以使项目比较简单化,但在使用中却可能带来一些麻烦,比如要进行“编号修改”时,可能要涉及到很多相关联的其他表,就像黎叔说的“后果很严重”;还有就是上面提到的“业务要求允许编号重复时”,我们再那么先知,都无法知道业务将会修改成什么
②自动编号主键
这种方法也是很多朋友在使用的,就是新建一个ID字段,自动增长,非常方便也满足主键的原则,优点是:数据库自动编号,速度快,而且是增量增长,聚集型主键按顺序存放,对于检索非常有利;数字型的,占用空间小,易排序,在程序中传递也方便;如果通过非系统增加记录(比如手动录入,或是用其他工具直接在表里插入新记录,或老系统数据导入)时,非常方便,不用担心主键重复问题。
缺点:其实缺点也就是来自其优点,就是因为自动增长,在手动要插入指定ID的记录时会显得麻烦,尤其是当系统与其他系统集成时,需要数据导入时,很难保证原系统的ID不发生主键冲突(前提是老系统也是数字型的);如果其他系统主键不是数字型那就麻烦更大了,会导致修改主键数据类型了,这也会导致其他相关表的修改,后果同样很严重;就算其他系统也是数字型的,在导入时,为了区分新老数据,可能想在老数据主键前统一加一个“o”(old)来表示这是老数据,那么自动增长的数字型又面临一个挑战。
以上就是关于在c#窗体程序中,注册界面有姓名,帐号,密码,如何实现,点击注册按钮,就将以上信息保存到相应的数据库全部的内容,包括:在c#窗体程序中,注册界面有姓名,帐号,密码,如何实现,点击注册按钮,就将以上信息保存到相应的数据库、关于数据库建表主外键关系方面的问题:现在有两个表,一个是用户登录表一个是用户注册表、在新建数据库(Access)中,如何设置主键等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)